牛顿迭代法
牛顿迭代法(Newton's method)又称为牛顿-拉夫逊(拉弗森)方法(Newton-Raphson method),它是牛顿在17世纪提出的一种在实数域和复数域上近似求解方程的方法。
牛顿迭代公式
设r是f(x)=0的根,选取x0作为r的初始近似值,过点(x0,f(x0)) ,做曲线 y=f(x)的切线L,L的方程为y=f(x0)+f′(x0)(x−x0) ,求出L与x轴交点的横坐标
x1=x0−f(x0)f′(x0)
称x1为r的一次近似值。过点(x1,f(x1)) 做曲线 y=f(x)的切线,并求该切线与x轴交点的横坐标
x2=x1−f(x1)f′(x1)
称x2为r的二次近似值。重复以上过程,得r的近似值序列,其中,
xn+1=xn−f(xn)f′(xn)
称为r的n+1次近似值,上式称为牛顿迭代公式。
用牛顿迭代法解非线性方程,是把非线性方程f(x)=0线性化的一种近似方法。把 f(x)在点 x0的某邻域内展开成泰勒级数
f(x)=f(x0)+f′(x0)(x−x0)+f″(x0)(x−x0)22!+…+f(n)(x0)(x−x0)nn!+Rn(x)
取其线性部分(即泰勒展开的前两项),并令其等于0,即 f(x0)+f′(x0)(x−x0)=0,以此作为非线性方程 f(x)=0的近似方程,若f′(x0)≠0,则其解为
x1=x0−f(x0)f′(x0)
这样,得到牛顿迭代法的一个迭代关系式:
xn+1=xn−f(xn)f′(xn)
从下面的图中,我们可以看到牛顿迭代的几何意义,每次迭代,都会更加逼近f(x)=0的解。
下面用牛顿迭代法在matlib解出方程x2+2xex+e2x=0的根,首先画出函数的图像,猜测根的大致位置。
函数图像如下图所示:
近似结果:

x=-1:0.01:1; y= x.^2+2*x.*exp(x)+exp(2*x) plot(x,y); grid on; clc;clear; %syms x; %diff(x^2+2*x*exp(x)+exp(2*x),x,1) %clear; x=0.0 for i=1:100 x1=x-(x^2+2*x*exp(x)+exp(2*x))/(2*x + 2*exp(2*x) + 2*exp(x) + 2*x*exp(x)) if(abs(x1-x)>0.0001) x=x1; else break; end end i
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程