热门问题
时间线
聊天
视角
牛頓法
来自维基百科,自由的百科全书
Remove ads
牛頓法(英語:Newton's method)又稱為牛頓-拉弗森方法(英語:Newton-Raphson method),它是一種在實數體和複數體上近似求解方程式的方法。方法使用函數的泰勒級數的前面幾項來尋找方程式的根。

起源
牛頓法最初由艾薩克·牛頓在《流數法》(Method of Fluxions,1671年完成,在牛頓去世後於1736年公開發表)中提出。約瑟夫·鮑易也曾於1690年在Analysis Aequationum中提出此方法。
方法說明

首先,選擇一個接近函數零點的,計算相應的和切線斜率(這裡表示函數的導數)。然後我們計算穿過點並且斜率為的直線和軸的交點的坐標,也就是求如下方程式的解:
我們將新求得的點的坐標命名為,通常會比更接近方程式的解。因此我們現在可以利用開始下一輪疊代。疊代公式可化簡為如下所示:
已有證明牛頓疊代法的二次收斂[1]必須滿足以下條件:
; 對於所有,其中為區間[α − r, α + r],且在區間其中內,即 的;
對於所有,是連續的;
足夠接近根 α。
然而當在處有m重根時,這時牛頓法會降為線性收斂,雖然使用牛頓法也可以繼續算下去,但收斂速度會減慢。[2]
Remove ads
其它例子
求方程式的根。令,兩邊求導,得。由於,則,即,可知方程式的根位於和之間。我們從開始。
Remove ads
牛頓法亦可發揮與泰勒展開式,對於函式展開的功能。
求的次方根。
設,
而a的m次方根,亦是x的解,
以牛頓法來疊代:
(或 )
Remove ads
應用
牛頓法也被用於求函數的極值。由於函數取極值的點處的導數值為零,故可用牛頓法求導函數的零點,其疊代式為
求反曲點的公式以此類推
Remove ads
電腦程式
可以用程式寫出牛頓法:
例題: 求x
用Python:
from math import pow
def f(x):
y = pow(x,3)-(10*x*x)+x+1
return y
def dx(x):
y = (3*x*x)-(20*x)+1
return y
x = 1
for i in range(1000):
x = x - (f(x)/dx(x))
print(x)
用C語言:
#include <stdio.h>
#include <math.h>
double x = 1.0;
double f(double x){
double y = pow(x,3)-(10*x*x)+x+1;
return y;}
double dx(double x){
double y = (3*x*x)-(20*x)+1;
return y;}
int main (){
for(int i=0;i<1000;i++){
x = x - (f(x)/dx(x));}
printf(" %f",x);
return 0;
}
只要修改f(x)和dx(x)函數就可以解其他方程式
Remove ads
註解
外部連結
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads