Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 01.06.2017
Сообщений: 18

Минимизация Методом Ньютона уравнения с двумя переменными

01.06.2017, 15:46. Показов 2830. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день... я тут новичок...очень нужна ваша помощь. Программу для уравнения где одна перменная ищущая минимум написал, а как две перменные сделать не очень понимаю. Вот задание Минимизировать ƒ(x1, x2)=x1^2+x2^2 и Минимизировать функцию Розенброка ƒ(x1, x2)=100(x1–x22)^2+(1–x2)^2 . Критерии останова: e=0.1, 0.01, 0.001.Вот примерный код для одномерного метода Ньютона
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#include "stdafx.h"
#include <math.h>
#include <conio.h>
#include <stdio.h>
#include <iostream>
 
 
double f(double x)
{
    double f;
    f = exp(-x)*log(x);
    return f;
}
double df(double x)
{
    double f;
    f = -exp(-x)*log(x) + (exp(-x) / x);
    return f;
}
 
void main()
{
    double e;
    std::cout << "Vvedite e" << std::endl;
    std::cin >> e;  
    double y1, y2, z1, z2, s, z, y, x, a = 1, b = 3;
    int N;
    //N=0; //Schetchik iteracii
    y1 = f(a);
    y2 = f(b);
    z1 = df(a);
    z2 = df(b);
    N = 4;
    do
    {
        s = ((z2*b - z1*a) - (y2 - y1)) / (z2 - z1);
        y = f(s);
        z = df(s);
        N += 2;
        if (z == 0) { x = s; break; }
        if (z>0) { b = s; y2 = y; z2 = z; }
        else { a = s; y1 = y; z1 = z; }
    } while ((b - a)/2>e);
    if (z != 0) { x = (a + b) / 2; y = f(x); }
    printf("Metod Newtona-Rafsona \n \n");
    printf("x = %.5f \n", x);
    printf("y = %.5f \n \n", y);
    printf("Chislo iteracii: %i", N);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.06.2017, 15:46
Ответы с готовыми решениями:

Минимизация двумерным методом Ньютона Функции Химмельблау и Розенброка
Доброго дня суток! Очень нужна ваша помощь! Необходимо минимизировать методом Ньютона функции Розенброка и Химмельблау , т.е. ...

Найти корень уравнения методом хорд и модифицированным методом Ньютона
Требуется решить уравнение 5sinx – x = 0 на отрезке с точностью E методом хорд и модифицированным методом Ньютона.

Решение уравнения методом Ньютона
Здравствуйте, использую код с данного форума для нахождения корня нелинейного уравнения методом Ньютона, но возникла проблема. При...

2
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,631
01.06.2017, 20:46
http://www.codeguru.com/cpp/ar... amming.htm

Добавлено через 7 минут
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#include <iostream>
#include <vector>
#include <ctime>
#include <algorithm>
#include <iterator>
#include <cmath>
#include "simplex.h"
using namespace std;
 
template<class Con>
void printcon(const Con& c){
  std::cout.precision(12);
  copy( c.begin(), 
    c.end(), 
    ostream_iterator<typename Con::value_type>(cout, "  ") );
  cout<<endl;
}
 
class Rosenbrock{
public:
  double  operator()(vector<double> x){
    return 100*pow(x[1]-pow(x[0],2),2)+pow(1-x[0],2);
  }
};
 
double rosenbrock(vector<double> x){
  return 100*pow(x[1]-pow(x[0],2),2)+pow(1-x[0],2);
}
 
double polynomial_fun(vector<double> x){
  return pow( pow(x[0],2) + pow(x[1],2), 2 ) - pow(x[0]-3*x[1],2);
}
 
int main(){
 
  //initial guessing value for Rosenbrock function
  vector<double> init;
  init.push_back(1.23);
  init.push_back(10.96);
 
  //initial trial simplex
  double a0[]={-1.5, -1}, a1[]={-2, -2}, a2[]={ 2.5, 1.5};
  vector<vector<double> > simplex;
  simplex.push_back( vector<double>(a0,a0+2) );
  simplex.push_back( vector<double>(a1,a1+2) );
  simplex.push_back( vector<double>(a2,a2+2) );
 
  //optimizating...
  //printcon is a function printing container values
 
  using BT::Simplex;
  cout<<"Rosenbrock function achieves minimum at:"<<endl;
  printcon( Simplex(Rosenbrock(), init) );  cout<<endl;
  cout<<"Rosenbrock function achieves minimum at:"<<endl;
  printcon( Simplex(rosenbrock, init, 1e-7, simplex, 1E5) ); cout<<endl;
  cout<<"Polynomial function achieves minimum at:"<<endl;
  printcon( Simplex(polynomial_fun, init, 1e-7, simplex) );  cout<<endl;
}

simplex.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
#include <vector>
#include <limits>
#include <algorithm>
#include <functional>
#include <iostream>
 
namespace BT{
 
  template<class D, class OP>
  std::vector<D> Simplex(OP f,                   //target function
             std::vector<D> init,    //initial guess of the parameters
             D tol=1E8*std::numeric_limits<D>::epsilon(), //termination criteria
             std::vector<std::vector<D> > x =  std::vector<std::vector<D> >(),
             //x: The Simplex
             int iterations=1E5){    //iteration step number
 
    int N=init.size();                         //space dimension
    const double a=1.0, b=1.0, g=0.5, h=0.5;   //coefficients
                                               //a: reflection  -> xr  
                                               //b: expansion   -> xe 
                                               //g: contraction -> xc
                                               //h: full contraction to x1
    std::vector<D> xcentroid_old(N,0);   //simplex center * (N+1)
    std::vector<D> xcentroid_new(N,0);   //simplex center * (N+1)
    std::vector<D> vf(N+1,0);            //f evaluated at simplex vertexes       
    int x1=0, xn=0, xnp1=0;         //x1:   f(x1) = min { f(x1), f(x2)...f(x_{n+1} }
                                    //xnp1: f(xnp1) = max { f(x1), f(x2)...f(x_{n+1} }
                                    //xn:   f(xn)<f(xnp1) && f(xn)> all other f(x_i)
    int cnt=0; //iteration step number
 
    if(x.size()==0) //if no initial simplex is specified
      { //construct the trial simplex
    //based upon the initial guess parameters
      std::vector<D> del( init );
      std::transform(del.begin(), del.end(), del.begin(), 
             std::bind2nd( std::divides<D>() , 20) );//'20' is picked 
                                                             //assuming initial trail close to true
      
      for(int i=0; i<N; ++i){
    std::vector<D> tmp( init );
    tmp[i] +=  del[i];
    x.push_back( tmp );
      }
      x.push_back(init);//x.size()=N+1, x[i].size()=N
      
      //xcentriod
      std::transform(init.begin(), init.end(), 
        xcentroid_old.begin(), std::bind2nd(std::multiplies<D>(), N+1) );
      }//constructing the simplex finished
    
    //optimization begins
    for(cnt=0; cnt<iterations; ++cnt){
 
      for(int i=0;i<N+1;++i){
    vf[i]= f(x[i]);
      }
      
      x1=0; xn=0; xnp1=0;//find index of max, second max, min of vf.
      
      for(int i=0;i<vf.size();++i){
    if(vf[i]<vf[x1]){
      x1=i;
    }
    if(vf[i]>vf[xnp1]){
      xnp1=i;
    }
      }
      
      xn=x1;
      
      for(int i=0; i<vf.size();++i){ 
    if( vf[i]<vf[xnp1] && vf[i]>vf[xn] )
      xn=i;
      }
      //x1, xn, xnp1 are found
 
      std::vector<D> xg(N, 0);//xg: centroid of the N best vertexes
      for(int i=0; i<x.size(); ++i){
    if(i!=xnp1)
      std::transform(xg.begin(), xg.end(), x[i].begin(), xg.begin(), std::plus<D>() );
      }
      std::transform(xg.begin(), xg.end(), 
        x[xnp1].begin(), xcentroid_new.begin(), std::plus<D>());
      std::transform(xg.begin(), xg.end(), xg.begin(), 
        std::bind2nd(std::divides<D>(), N) );
      //xg found, xcentroid_new updated
 
      //termination condition
      D diff=0;          //calculate the difference of the simplex centers
                         //see if the difference is less than the termination criteria
      for(int i=0; i<N; ++i)     
    diff += fabs(xcentroid_old[i]-xcentroid_new[i]);
 
      if (diff/N < tol) break;              //terminate the optimizer
      else xcentroid_old.swap(xcentroid_new); //update simplex center
      
      //reflection:
      std::vector<D> xr(N,0); 
      for( int i=0; i<N; ++i)
    xr[i]=xg[i]+a*(xg[i]-x[xnp1][i]);
      //reflection, xr found
      
      D fxr=f(xr);//record function at xr
      
      if(vf[x1]<=fxr && fxr<=vf[xn])
    std::copy(xr.begin(), xr.end(), x[xnp1].begin() );
      
      //expansion:
      else if(fxr<vf[x1]){
    std::vector<D> xe(N,0);
    for( int i=0; i<N; ++i)
      xe[i]=xr[i]+b*(xr[i]-xg[i]);
    if( f(xe) < fxr )
      std::copy(xe.begin(), xe.end(), x[xnp1].begin() );
    else
      std::copy(xr.begin(), xr.end(), x[xnp1].begin() );
      }//expansion finished,  xe is not used outside the scope
      
      //contraction:
      else if( fxr > vf[xn] ){
    std::vector<D> xc(N,0);
    for( int i=0; i<N; ++i)
      xc[i]=xg[i]+g*(x[xnp1][i]-xg[i]);
    if( f(xc) < vf[xnp1] )
      std::copy(xc.begin(), xc.end(), x[xnp1].begin() );
    else{
      
      for( int i=0; i<x.size(); ++i ){
        if( i!=x1 ){ 
          for(int j=0; j<N; ++j) 
        x[i][j] = x[x1][j] + h * ( x[i][j]-x[x1][j] );
        }
      }
      
    }
      }//contraction finished, xc is not used outside the scope
 
    }//optimization is finished
 
    if(cnt==iterations){//max number of iteration achieves before tol is satisfied
      std::cout<<"Iteration limit achieves, result may not be optimal"<<std::endl;
    }
    return x[x1];
  }
}
0
0 / 0 / 0
Регистрация: 01.06.2017
Сообщений: 18
02.06.2017, 14:50  [ТС]
Спасибо конечно, но мне нужно выполнить решение методом Ньютона, а не симплексом
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.06.2017, 14:50
Помогаю со студенческими работами здесь

Вычислить методом Ньютона корень уравнения
Помогите, пожалуйста, написать программу, вычисляющую методом Ньютона`(x_(k+1)=x_k-A^(-1) (x_k )f(x_k )) где уравнений с положительными...

Решение квадратного уравнения методом Ньютона
напишите прогу метод ньютона на С

Найти корни уравнения методом Ньютона
Задание Найти корень уравнения с помощью указанного метода return pow(0.2*(x),3)-cos(x) ;//моя функия #include...

Вычислить методом Ньютона корень уравнения
Уважаемый программисты,помогите пожалуйста вот такую курсовую задали,я не то что на с++,а просто так не смогу решить этот пример ...

Вычислить корень уравнения методом Ньютона
Добрый день! Помогите пожалуйста вычислить корень уравнения f(x) = 0 для функции x*cos(x)=0 методом Ньютона Формат выходных данных:...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита табличной части. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru