ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Python – 实现数值方程求解器(Newton-Raphson)

2019-07-18 01:58:27  阅读:753  来源: 互联网

标签:python while-loop numerical-methods


我警告你,这可能会令人困惑,我写的代码更多的是思维导图而不是完成代码.

我正在尝试使用Newton-Raphson方法来求解方程.
我无法弄清楚的是如何写这个

Python中的等式,用于计算最后一次近似(xn)的下一个近似值(xn 1).我必须使用循环,越来越接近真实的答案,并且当近似值之间的变化小于变量h时,循环应该终止.

>我如何编写等式的代码?
>当近似值不再变化时,如何终止循环?

计算方程f的导数,在点x,精度为h(这用于求解方程式())

def derivative(f, x, h):
    deriv = (1.0/(2*h))*(f(x+h)-f(x-h))
    return deriv

数值方程求解器

假设循环直到近似值之间的差异小于h

def solve(f, x0, h):
    xn = x0
    prev = 0

    while ( approx - prev > h):
         xn = xn - (f(xn))/derivative(f, xn, h)

    return xn

解决方法:

以下是N-R求解器的实现,扩展了您上面所写的内容(完整,有效).我添加了一些额外的行来显示正在发生的事情……

def derivative(f, x, h):
      return (f(x+h) - f(x-h)) / (2.0*h)  # might want to return a small non-zero if ==0

def quadratic(x):
    return 2*x*x-5*x+1     # just a function to show it works

def solve(f, x0, h):
    lastX = x0
    nextX = lastX + 10* h  # "different than lastX so loop starts OK
    while (abs(lastX - nextX) > h):  # this is how you terminate the loop - note use of abs()
        newY = f(nextX)                     # just for debug... see what happens
        print "f(", nextX, ") = ", newY     # print out progress... again just debug
        lastX = nextX
        nextX = lastX - newY / derivative(f, lastX, h)  # update estimate using N-R
    return nextX

xFound = solve(quadratic, 5, 0.01)    # call the solver
print "solution: x = ", xFound        # print the result

输出:

f( 5.1 ) =  27.52
f( 3.31298701299 ) =  6.38683083151
f( 2.53900845771 ) =  1.19808560807
f( 2.30664271935 ) =  0.107987672721
f( 2.28109300639 ) =  0.00130557566462
solution: x =  2.28077645501

编辑 – 你也可以检查newY的值并在它“足够接近零”时停止 – 但通常你会继续这样做,直到x的变化为< = h(你可以争论=符号的值)一个数值方法 - 我更倾向于更加强调<我自己,认为再多一次迭代不会受到伤害.)

标签:python,while-loop,numerical-methods
来源: https://codeday.me/bug/20190718/1491733.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有