python用fsolve、leastsq对非线性方程组进行求解
来源:互联网 发布:加强网络舆情监测 编辑:程序博客网 时间:2024/06/06 16:59
背景:
实现用python的optimize库的fsolve对非线性方程组进行求解。可以看到这一个问题实际上还是一个优化问题,也可以用之前拟合函数的leastsq求解。下面用这两个方法进行对比:
代码:
from scipy.optimize import fsolve,leastsqfrom math import sin,cosdef f(x): x0 = float(x[0]) x1 = float(x[1]) x2 = float(x[2]) return [ 5*x1+3, 4*x0*x0 - 2*sin(x1*x2), x1*x2-1.5 ]x0 = [1,1,1]result = fsolve(f,x0)print("===================")print()print("求解函数名称:",fsolve.__name__)print("解:",result)print("各向量值:",f(result))#拟合函数来求解h = leastsq(f,x0)print("===================")print()print("求解函数名称:",leastsq.__name__)print("解:",h[0])print("各向量的值:",f(h[0]))
结果:
===================
求解函数名称: fsolve
解: [-0.70622057 -0.6 -2.5 ]
各向量值: [0.0, -9.126033262418787e-14, 5.329070518200751e-15]
===================
求解函数名称: leastsq
解: [-0.70622057 -0.6 -2.5 ]
各向量的值: [0.0, -2.220446049250313e-16, 0.0]
求解函数名称: fsolve
解: [-0.70622057 -0.6 -2.5 ]
各向量值: [0.0, -9.126033262418787e-14, 5.329070518200751e-15]
===================
求解函数名称: leastsq
解: [-0.70622057 -0.6 -2.5 ]
各向量的值: [0.0, -2.220446049250313e-16, 0.0]
阅读全文
1 0
- python用fsolve、leastsq对非线性方程组进行求解
- MATLAB中用solve和fsolve求解非线性方程组
- python/scipy求解非线性方程(fsolve/root)
- fsolve函数求解非线性方程
- 使用matlab进行非线性方程组求解
- MATLAB求解非线性方程组
- 迭代法求解非线性方程组
- MATLAB求解非线性方程组
- Newton_Raphson法求解非线性方程组
- Python 非线性方程组
- Newton-Raphson 法求解非线性方程组
- matlab实现牛顿迭代法求解非线性方程组
- 二分法,newton迭代法求解非线性方程组
- matlab实现牛顿迭代法求解非线性方程组
- 利用牛顿迭代法求解非线性方程组
- 关于非线性方程组的求解问题
- R语言非线性方程组求解dfsane,nleqslv
- 数值计算——求解非线性方程组
- 输入一个十进制正整数,将该数转换成n进制数;
- spring架构流程
- eclipse环境下如何配置tomcat,并且把项目部署到Tomcat服务器上
- 2017 ACM-ICPC南宁网络赛: I. GSM Base Station Identification(线性变换)
- 课外知识:人工智能简明入门学习指南
- python用fsolve、leastsq对非线性方程组进行求解
- Python学习(2、3)设计一个小游戏、字符串
- 将一个数组中奇数放左边偶数放右边,不用考虑数字的相对位置
- Java基础编程小练习——日历
- VTK图形处理之剪切
- 第十三节集合和泛型
- 2017年9月24日训练日记
- 38241415106——胡应兰(实验一)
- 找出100-201之间的素数,除了1和它本身不能被整除的数