时间:2021-05-22
本文实例讲述了python计算方程式根的方法。分享给大家供大家参考。具体实现方法如下:
''' roots = polyRoots(a). Uses Laguerre's method to compute all the roots of a[0] + a[1]*x + a[2]*x^2 +...+ a[n]*x^n = 0. The roots are returned in the array 'roots',''' from evalPoly import *from numpy import zeros,complexfrom cmath import sqrtfrom random import randomdef polyRoots(a,tol=1.0e-12): def laguerre(a,tol): x = random() # Starting value (random number) n = len(a) - 1 for i in range(30): p,dp,ddp = evalPoly(a,x) if abs(p) < tol: return x g = dp/p h = g*g - ddp/p f = sqrt((n - 1)*(n*h - g*g)) if abs(g + f) > abs(g - f): dx = n/(g + f) else: dx = n/(g - f) x = x - dx if abs(dx) < tol: return x print 'Too many iterations' def deflPoly(a,root): # Deflates a polynomial n = len(a)-1 b = [(0.0 + 0.0j)]*n b[n-1] = a[n] for i in range(n-2,-1,-1): b[i] = a[i+1] + root*b[i+1] return b n = len(a) - 1 roots = zeros((n),dtype=complex) for i in range(n): x = laguerre(a,tol) if abs(x.imag) < tol: x = x.real roots[i] = x a = deflPoly(a,x) return roots raw_input("\nPress return to exit")希望本文所述对大家的Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
复制代码代码如下:在线一元二次方程式计算器解二次方程式计算x2+x+=0一元二次方程的解法x1=x2=MadebyCRoot
在solidworks中,利用方程式可以有效地管理模型的尺寸,提高修改模型的效率,对系列零件的建模有很大的帮助。下面用一个简单的例子分享添加尺寸方程式的方法。1
不知不觉已经毕业多年了,不知道大家是否还记得怎么配平化学方程式呢?反正小编我是已经记不太清了,所以今天的文章除了分享如何用python配平化学方程式,顺带着还会
wps2019中想要插入方程式,该怎么插入方程式呢?下面我们就来看看详细的教程。软件名称:wpsoffice2019正式版v11.1.0.10000中文最新安装
五角星形线的笛卡尔坐标方程式可设为:r=10+(3*sin(θ*2.5))^2 x=r*cos(θ)y=r*sin(θ)(0≤θ≤2π)根据这个曲线