香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

python计算方程式根的方法


时间:2021-11-29 16:25 作者:admin610456


本文实例讲述了python/' target='_blank'>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程序设计有所帮助。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)