python解非线性方程_python解非线性方程的问题

本文介绍了使用Python求解非线性方程的三种方法:sympy库的nonlinsolve函数、scipy.optimize.fsolve函数。然而,遇到的问题包括nonlinsolve无法解决特定方程,fsolve需要多次调用以获取不同根,并且在传入多个初始猜测值时出现错误。作者寻求一次性求解方程所有根的方法。
摘要由CSDN通过智能技术生成

废话不多说,上代码

方法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

各位大佬,如何才能把三个根一次性解出来呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值