python如何求解微分方程_如何使用Python内置函数odeint求解微分方程?

这里有几个问题.首先,你的等式显然是

(3x-1)y” – (3x 2)y’ – (6x-8)y = 0; y(0)= 2,y'(0)= 3

(注意y中术语的符号).对于此等式,您的分析解决方案和y2的定义是正确的.

其次,正如@Warren Weckesser所说,你必须将2个参数作为y传递给g:y [0](y),y [1](y’)并返回它们的导数y’和y”.

第三,你的初始条件是x = 0,但你要整合的x网格从-2开始.从odeint的文档中,这个参数,在他们的调用签名描述中:

odeint(func,y0,t,args =(),…):

t : array

A sequence of time points for which to solve for y. The initial

value point should be the first element of this sequence.

因此,您必须从0开始积分或提供从-2开始的初始条件.

最后,您的整合范围涵盖了x = 1/3处的奇点. odeint可能在这里度过了不愉快的时光(但显然没有).

这是一种似乎有效的方法:

import numpy as np

import scipy as sp

from scipy.integrate import odeint

import matplotlib.pyplot as plt

def g(y, x):

y0 = y[0]

y1 = y[1]

y2 = ((3*x+2)*y1 + (6*x-8)*y0)/(3*x-1)

return y1, y2

# Ini

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值