无约束最优化方法-牛顿法

2024-02-02 14:38

本文主要是介绍无约束最优化方法-牛顿法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


无约束最优化算法-Newton法原理及c++编程实现
6536人阅读 评论(5) 收藏 举报
本文章已收录于:
分类:
作者同类文章 X

    无约束最优化方法-牛顿法

    牛顿法Newton'smethod)又称为牛顿-拉弗森方法Newton-Raphson method),它是一种在实数域和复数域上近似求解方程的方法,迭代的示意图如下:


    总结@郑海波 blog.csdn.net/nuptboyzhb/

    参考:斯坦福大学machine learning

    本博客中所有源代码:http://download.csdn.net/detail/nuptboyzhb/4886786

    求解问题:

    1.无约束函数f的0点。

    2.无约束函数f的最小值,最大值。



    函数的曲线(matlab画出)



    #include <iostream>

    #include <math.h>

    using namespace std;

    #define f(x)  (pow(x,3)-4.0*pow(x,2)+3.0*x)

    #define  df(x)    (3.0*pow(x,2)-8.0*x+3)

    int main()

    {

           doublex=9;//设置迭代的初始值

           doubleerr=1.0e-10;//设置精度

           intcount=0;

        while(true)

        {

                  x=x-f(x)/df(x);

                  if(abs(f(x))<err)

                  {

                         break;

                  }

                  cout<<""<<count++<<"迭代x="<<x<<" f(x)="<<f(x)<<endl;

        }

           cout<<"函数f0点为:"<<x<<endl;

           return0;

    }

    结果讨论:

    迭代结果与初始值有关,迭代的结果总是初始值x附近的0。如:

    1.初始值x=9时,运行结果如下:

    0迭代 x=6.51724 f(x)=126.47

    1迭代 x=4.90174 f(x)=36.3714

    2迭代 x=3.88768 f(x)=9.96551

    3迭代 x=3.30967 f(x)=2.36715

    函数f0点为:3.05742

    Press any key tocontinue

    2.初始值x=1.3时,运行结果如下:

    函数f0点为:1.01545

    Press any key tocontinue

    3.初始值为-10时,运行结果如下:

    0迭代 x=-6.26632 f(x)=-421.924

    1迭代 x=-3.79793 f(x)=-123.873

    2迭代 x=-2.18197 f(x)=-35.9783

    3迭代 x=-1.14629 f(x)=-10.201

    4迭代 x=-0.51317 f(x)=-2.72803

    函数f0点为:-0.167649

    Press any key tocontinue


    [cpp] view plain copy print ?
    1. #include <iostream>  
    2. #include <math.h>  
    3. using namespace std;  
    4. #define  f(x)   (pow(x,3)-4.0*pow(x,2)+3.0*x)  
    5. #define df(x)    (3.0*pow(x,2)-8.0*x+3)  
    6. #define ddf(x)    (6.0*x-8)  
    7. int main()  
    8. {  
    9.     double x=1.2;//初始值  
    10.     double err=1.0e-10;  
    11.     int count=0;  
    12.     while (true)  
    13.     {  
    14.         x=x-df(x)/ddf(x);  
    15.         if (abs(df(x))<err)  
    16.         {  
    17.             break;  
    18.         }  
    19.         cout<<"第"<<count++<<"迭代x="<<x<<" df(x)="<<df(x)<<endl;  
    20.     }  
    21.     cout<<"函数f极点为:("<<x<<","<<f(x)<<")"<<endl;  
    22.     return 0;  
    23. }  
    #include <iostream>
    #include <math.h>
    using namespace std;
    #define  f(x)   (pow(x,3)-4.0*pow(x,2)+3.0*x)
    #define df(x)    (3.0*pow(x,2)-8.0*x+3)
    #define ddf(x)    (6.0*x-8)
    int main()
    {double x=1.2;//初始值double err=1.0e-10;int count=0;while (true){x=x-df(x)/ddf(x);if (abs(df(x))<err){break;}cout<<"第"<<count++<<"迭代x="<<x<<" df(x)="<<df(x)<<endl;}cout<<"函数f极点为:("<<x<<","<<f(x)<<")"<<endl;return 0;
    }
    


    结果讨论:

    迭代结果与初始值有关,迭代的结果总是初始值x附近的极值。如:

    1.初始值x=9时,运行结果如下:

    0迭代x=5.21739df(x)=42.9244

    1迭代x=3.37549df(x)=10.1778

    2迭代x=2.54484df(x)=2.06992

    函数f极点为:(2.26008,-2.1072)

    Press any key tocontinue

    2.初始值x=1.2时,运行结果如下:

    0迭代x=-1.65df(x)=24.3675

    1迭代x=-0.288687df(x)=5.55952

    函数f极点为:(0.282567,0.550886)

    Press any key tocontinue

    3.初始值为-10时,运行结果如下:

    0迭代x=-4.36765df(x)=95.1702

    1迭代x=-1.58537df(x)=23.2232

    2迭代x=-0.259259df(x)=5.27572

    函数f极点为:(0.292851,0.560622)

    Press any key tocontinue

    注意:对于只有1个0点的函数求解或只有一个极值的函数求解时,迭代结果一般与初始值的关系不大,但迭代次数会受影响。

    转载请声明,未经允许,不得用以商业目的


    这篇关于无约束最优化方法-牛顿法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



    http://www.chinasem.cn/article/671016

    相关文章

    Nginx设置连接超时并进行测试的方法步骤

    《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

    Java判断多个时间段是否重合的方法小结

    《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

    Python使用国内镜像加速pip安装的方法讲解

    《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

    IDEA编译报错“java: 常量字符串过长”的原因及解决方法

    《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

    Linux使用nload监控网络流量的方法

    《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

    Java覆盖第三方jar包中的某一个类的实现方法

    《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

    JavaScript中的reduce方法执行过程、使用场景及进阶用法

    《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

    C#中读取XML文件的四种常用方法

    《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

    C++初始化数组的几种常见方法(简单易懂)

    《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

    oracle DBMS_SQL.PARSE的使用方法和示例

    《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行