科学网对公式支持不太好,在博客园有相同博文

牛顿迭代法可以推广到多元非线性方程组 $boldsymbol{F}(boldsymbol{x})=boldsymbol{0}$的情况,称为牛顿-- 拉夫逊方法 (Newton-Raphson method). 当 $boldsymbol{F}(boldsymbol{x})$ 关于$boldsymbol{x}$ 的 Jacobi 矩阵 $boldsymbol{J}(boldsymbol{x}) = (cfrac{partial boldsymbol{F}}{partial boldsymbol{x}})$ 可逆时, 有

$$boldsymbol{x}^{(k+1)}=boldsymbol{x}^{(k)}- boldsymbol{J}^{-1}(boldsymbol{x}^{(k)})boldsymbol{F}(boldsymbol{x}^{(k)}),$$

求解非线性方程组的Newton-Raphson方法:

1、 取初始点 $boldsymbol{x}^{(0)}$,最大迭代次数 $N$ 和精度要求 $varepsilon$, 置 $k=0$;

2、 求解线性方程组 $boldsymbol{J}(boldsymbol{x}^{(k)})boldsymbol{d} = -boldsymbol{F}(boldsymbol{x}^{(k)})$;

3、 若 $|boldsymbol{d}|

$boldsymbol{x}^{(k+1)} = boldsymbol{x}^{(k)}+boldsymbol{d}^{(k)}$;

4、 若 $k=N$, 则停止计算;否则,置 $k = k+1$, 转(2).

function [x_star, it] = NewtonRapshon(fun,dfun,x0,ep,it_max)

if nargin <6 it_max = 100; end

if nargin<5 ep =1e-5; end

k = 1; err = 0; n = length(x0);

while k

d = -feval(dfun,x0)feval(fun,x0);

x1 = x0 + d;

err = norm(d,inf);

if err

x0 = x1; k = k+1;

end

x_star = x1; it = k;

用 Newton 法求非线性方程组$$begin{cases}

x_1^2+x_2^2-5=0,\

(x_1+1)x_2-(3x_1+1)=0,

end{cases}$$ $\begin{cases}

x_1^2+x_2^2-5=0,\\

(x_1+1)x_2-(3x_1+1)=0,

\end{cases}$

取初始点$boldsymbol{x}^{(0)}=[1,1]^T$, 精度要求 $varepsilon = 10^{-3}$.

在 MATLAB 中,

>> [x_star, it] = NewtonRapshon(Fun,JFun,[1;1])

x_star =

1.0000

2.0000

it =

5

转载本文请联系原作者获取授权,同时请注明本文来自王福昌科学网博客。

链接地址:http://blog.sciencenet.cn/blog-292361-1012797.html

上一篇:解多元非线性方程组F(x)=0的拟牛顿法及其MATLAB 程序

下一篇:一个一阶微分方程初值问题的解析解

python牛顿法解非线性方程组_科学网—求解多元非线性方程组F(x)=0的Newton-Raphson方法及其MATLAB实现 - 王福昌的博文...相关推荐

  1. matlab trapz二重积分函数_科学网—MATLAB中的数值积分方法 - 王福昌的博文

    实际应用中在MATLAB里面都有开发好的命令可以使用,如  quad(), quadl(),quad2d(),triplequad() .需要掌握这些命令的用法. 1. 定积分 trapz(),qua ...

  2. matlab回归分析结果输出,科学网—回归分析的MATLAB和R程序实现 - 王福昌的博文...

    前面博客中已经讲过MATLAB中常用的命令拟合polyfit() , lsqcurvefit() ,nlinfit()  和 cftool等,这里简单介绍简单的回归分析的MATLAB和R语言实现. 例 ...

  3. 单纯性搜索算法 matlab函数,科学网—一种有效的最优化方法——Nelder-Mead单纯形直接搜索算法 - 王福昌的博文...

    虽然MATLAB本身自带了fminsearch()函数,可以求解目标函数无梯度的最优化问题,但是感觉下面的程序在很多时候更好用,特别是自变量有边界和非线性约束的时候. 这里是John D'Errico ...

  4. matlab对数收益直方图,科学网—MATLAB中绘制数据直方图的新函数histogram2 - 王福昌的博文...

    MATLAB中有命令hist3() 可以绘制直方图,竖坐标是频数,这与一些教科书中用纵轴表示频率的做法不一致,有些时候不便于使用.当然,使用者可以自己编写定制能够在纵轴绘出频率的直方图.在MATLAB ...

  5. python shell背景颜色改变_科学网—Python Shell Background Color - 李旭的博文

    ArcGIS在安装时就已经默认在本机安装了Python.可是,Python Shell的界面看起来太亮了,对眼睛不太好啊,如图1. 图1 在网上搜索一番,之前也有和我同样问题的帖子,不过,时间有点久了 ...

  6. python的安装包下载_科学网—[转载]python常用的安装包下载 - 林清莹的博文

    Python常用的安装包下载 1.首先应该下载dlib安装包(例如:dlib-19.8.1-cp36-cp36m-win_amd64.whl) 可以通过此网址进行下载对应的dlib包   https: ...

  7. python爬pdf的曲线_科学网—Python爬PDF - 胡鹏程的博文

    最近用Python爬了两本书,分享下代码,仅作为交流和分享. #下载# import requests #先导入库 import re #正则表达式 import os #创建路径 import ra ...

  8. python写一个笔记软件_科学网—python学习笔记(1)——创建应用 - 高雪峰的博文...

    创建应用的步骤打开命令行 进入manage.py的同级目录 命令行输入:python manage.py startapp blog 添加应用名到sittings.py中的Installed_apps ...

  9. python求导并作图_科学网—python-符号运算(求导等) - 夏江江的博文

    cmd 命令下 pip install sympy #求导 from sympy import * y = Symbol('x') diff(y**2,y) #2*x diff(f, *symbols ...

最新文章

  1. linux创建mysql视图_MySQL视图基本操作
  2. Mac上PDF中插入替换删除页面
  3. 看Quick Audience 如何有效提升营销活动管理效率
  4. leetcode 738. Monotone Increasing Digits | 738. 单调递增的数字(Java)
  5. 12-图像梯度-Scharr算子和laplacian算子
  6. 如何使用 Microsoft Azure Media Services 现场直播,(Live Streaming) 直播流媒体系统
  7. 论文浅尝 | Iterative Cross-Lingual Entity Alignment Based on TransC
  8. MKNetwork网络请求过程中onCompletion调用两次的问题
  9. 设计师应该知道的配色工具,有效提高效率和审美
  10. XSS-Payloads集合
  11. Mapreduce和yarn-内存设置
  12. 一网打尽Android UI 控件教程
  13. python 实现简单画板_Python图像处理之简单画板实现方法示例
  14. Leetcode Top100题目和答案(Java完整版 面试必备)
  15. Ubuntu下安装RabbbitVCS(图形化svn管理工具)-- Ubuntu也有TortoiseSVN
  16. springboot下载依赖包
  17. super在python中是什么意思_python中super()的作用是什么
  18. 让数据怎么发挥价值?先看看华为云数据使能的力量
  19. 嵌入式 ARM 控制器采用 NXP 的高性能处理器 I.MX6ULL
  20. VUE中created被重复调用(每次进入页面之后都会调用created)

热门文章

  1. 营销中的4P、4C、4S、4R、4V、4I
  2. 巴菲特的护城河- 帕特·多尔西
  3. gpio模拟mdc/mdio通信
  4. VUE+Echart+Geojson实现全国地图map数据展示
  5. Friendship Cards 友情卡片
  6. 揭秘: 优秀CIO的OA选型标准
  7. 添物零基础到大型全栈架构师 不花钱学计算机及编程(预备篇)- 概述
  8. 你是左脑思考还右脑思考?
  9. 读简单的php程序,PHP+MYSQL实现读写分离简单实战
  10. OSPF 报文 链路状态更新报文 LSU