我是靠谱客的博主 细腻乐曲,最近开发中收集的这篇文章主要介绍牛顿迭代算法求根,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

公式推导:f(Xn)+f‘(Xn)*(X-Xn)(切线方程)

让求解的切线方程为0,即:f(Xn)+f‘(Xn)*(Xn+1 - Xn)=0

进而推导出:Xn+1 = Xn - f(Xn)/f‘(Xn)

当Xn+1 与Xn之间差值无限接近时,即得到最终解。

例如求取方根,令f(Xn)= Xn^2 - n 代入即可 

 

python3.5代码实现:

#coding:__utf-8__
import math
class Solution:
def qiugen(self,n,m):
"""
牛顿迭代法
https://www.cnblogs.com/liuyu124/p/7332493.html
公式:Xn+1 = Xn - f(Xn) / f'(Xn)
:param n:
要求根的数
:param m:
求根次数
:return:
"""
eps = 0.0001
#精度
result = float(n)
while True:
last_value = result
result = (m - 1) / m * result + n / m / result**(m-1)
if math.fabs(result - last_value) < eps:
break
print(result)
if __name__ == "__main__":
sl = Solution()
# n, m = map(int, input().split(' '))
sl.qiugen(125,3)

 相关理解:https://www.cnblogs.com/liuyu124/p/7332493.html

最后

以上就是细腻乐曲为你收集整理的牛顿迭代算法求根的全部内容,希望文章能够帮你解决牛顿迭代算法求根所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(38)

评论列表共有 0 条评论

立即
投稿
返回
顶部