python scipy求解非线性方程的方法(fsolve/root)

作者:落叶_小唱 时间:2022-01-06 15:46:00 

使用scipy.optimize模块的root和fsolve函数进行数值求解线性及非线性方程,下面直接贴上代码,代码很简单


from scipy.integrate import odeint
import numpy as np
import matplotlib.pyplot as plt
from scipy.optimize import root,fsolve
#plt.rc('text', usetex=True) #使用latex
## 使用scipy.optimize模块的root和fsolve函数进行数值求解方程

## 1、求解f(x)=2*sin(x)-x+1
rangex1 = np.linspace(-2,8)
rangey1_1,rangey1_2 = 2*np.sin(rangex1),rangex1-1
plt.figure(1)
plt.plot(rangex1,rangey1_1,'r',rangex1,rangey1_2,'b--')
plt.title('$2sin(x)$ and $x-1$')

def f1(x):
return np.sin(x)*2-x+1

sol1_root = root(f1,[2])
sol1_fsolve = fsolve(f1,[2])
plt.scatter(sol1_fsolve,2*np.sin(sol1_fsolve),linewidths=9)
plt.show()

## 2、求解线性方程组{3X1+2X2=3;X1-2X2=5}
def f2(x):
return np.array([3*x[0]+2*x[1]-3,x[0]-2*x[1]-5])

sol2_root = root(f2,[0,0])
sol2_fsolve = fsolve(f2,[0,0])
print(sol2_fsolve) # [2. -1.5]

a = np.array([[3,2],[1,-2]])
b = np.array([3,5])
x = np.linalg.solve(a,b)
print(x) # [2. -1.5]
## 3、求解非线性方程组
def f3(x):
return np.array([2*x[0]**2+3*x[1]-3*x[2]**3-7,
    x[0]+4*x[1]**2+8*x[2]-10,
    x[0]-2*x[1]**3-2*x[2]**2+1])

sol3_root = root(f3,[0,0,0])
sol3_fsolve = fsolve(f3,[0,0,0])
print(sol3_fsolve)

## 4、非线性方程
def f4(x):
return np.array(np.sin(2*x-np.pi)*np.exp(-x/5)-np.sin(x))
init_guess =np.array([[0],[3],[6],[9]])
sol4_root = root(f4,init_guess)
sol4_fsolve = fsolve(f4,init_guess)
print(sol4_fsolve)
t = np.linspace(-2,12,2000)
y1 = np.sin(2*t-np.pi)*np.exp(-t/5)
y2 = np.sin(t)
plt.figure(2)
a , = plt.plot(t,y1,label='$sin(2x-\pi)e^{-x/5}$')
b , = plt.plot(t,y2,label='$sin(x)$')
plt.scatter(sol4_fsolve,np.sin(sol4_fsolve),linewidths=8)
plt.title('$sin(2x-\pi)e^{-x/5}$ and $sin(x)$')
plt.legend()

python scipy求解非线性方程的方法(fsolve/root)

python scipy求解非线性方程的方法(fsolve/root)

来源:https://blog.csdn.net/ouening/article/details/78653774

标签:python,scipy,fsolve,root
0
投稿

猜你喜欢

  • 在IE 浏览器中使用 jquery的fadeIn() 效果 英文字符字体加粗

    2011-06-06 10:28:00
  • 详解Python_shutil模块

    2023-06-24 00:32:19
  • Python中层次聚类的详细讲解

    2022-07-02 06:07:13
  • pytorch + visdom CNN处理自建图片数据集的方法

    2023-05-03 06:33:16
  • golang逐行读取文件的操作

    2023-07-10 14:39:56
  • DIV与Table布局在大型网站的可用性比较

    2007-10-08 12:46:00
  • Python中BeautifulSoup模块详解

    2023-07-21 21:53:15
  • asp在sql server2000中新建帐号和给帐号权限代码

    2008-01-29 13:46:00
  • javascript 实现子父窗体互相传值的简单实例

    2023-08-09 09:52:52
  • 优化MySQL数据库性能的八大“妙手”

    2007-11-18 14:49:00
  • javascript同步服务器时间和同步倒计时小技巧

    2023-08-27 22:10:58
  • python_mask_array的用法

    2022-05-10 06:25:27
  • 用Python编写一个每天都在系统下新建一个文件夹的脚本

    2021-11-08 22:39:16
  • Python网络爬虫信息提取mooc代码实例

    2022-01-02 12:18:23
  • golang 网络框架之gin的使用方法

    2023-07-19 02:35:37
  • 编写一个asp代码执行器

    2007-09-24 16:05:00
  • 利用python绘制正态分布曲线

    2021-04-09 06:59:40
  • pandas创建DataFrame的方式小结

    2021-10-25 13:26:23
  • python dataframe向下向上填充,fillna和ffill的方法

    2021-11-07 18:16:47
  • python-itchat 获取微信群用户信息的实例

    2022-11-09 18:15:41
  • asp之家 网络编程 m.aspxhome.com