| 查看: 1201 | 回复: 0 | ||
| 【悬赏金币】回答本帖问题,作者xjzeng将赠送您 10 个金币 | ||
xjzeng木虫 (小有名气)
|
[求助]
python解非线性方程的问题
|
|
|
废话不多说,上代码 方法1: from sympy import * t=symbols('t') eq=eq(10**20*exp(-12000/t)/(0.01+10**14*exp(-12000/t))-18700*(t-300)) #eq=[10**20*exp(-12000/t)/(0.01+10**14*exp(-12000/t))-18700*(t-300)]#改成这样结果也是一样的 result=nonlinsolve(eq,t) print(result) 程序运行,返回的是一个conditionset对象,说明不能解这个方程。 方法2: import numpy as np from scipy.optimize import fsolve def f(t): return 10**20*np.exp(-12000/t)/(0.01+10**14*np.exp(-12000/t))-18700*(t-300) result=fsolve(f,[300]) print(result) 运行结果报错 minpack.error: result from function call is not a proper array of floats. 方法3 import math from scipy.optimize import fsolve def f(t): return 10**20*math.exp(-12000/t)/(0.01+10**14*math.exp(-12000/t))-18700*(t-300) result=fsolve(f,[300]) print(result) 第3种方法能解出一个根 [303.3],但是方程有3个根。如果把“result=fsolve(f,[300])”这句改成“result=fsolve(f,[320])“,可以得到第二个根 [323.7];如果“result=fsolve(f,[300])”这句改成“result=fsolve(f,[360])“,可以得到第三个根 [349.4]。 如果把“result=fsolve(f,[300])”这句改成“result=fsolve(f,[300,320.360])“,则会报错 typeerror: only size-1 arrays can be converted to python scalars 各位大佬,如何才能把三个根一次性解出来呢? |
» 猜你喜欢
评审有感
已经有31人回复
提交了我也来说说感想
已经有12人回复
青B发送上会通知了吗
已经有9人回复
西安交大新媒学院副院长用撤稿论文结题
已经有6人回复
论文撤稿了
已经有8人回复
博士申请
已经有7人回复
化学专业申博
已经有4人回复
河北省自然科学基金
已经有9人回复
某211大学教师把个人教师官方主页改成:我跑了我跑了我跑了!官宣跑路!
已经有5人回复
26/27申博自荐
已经有9人回复












回复此楼