计算机数值分析(常微分方程的差分方法):改进的欧拉公式(python实现

改进的欧拉公式
流程图以及方程式如下(以下代码是按照方程式写就)
计算机数值分析(常微分方程的差分方法):改进的欧拉公式(python实现_第1张图片
在这里插入图片描述
由于使用改进的欧拉公式需要已知函数表达式的具体形式,故而这里用了书上的具体的习题
习题如下:
计算机数值分析(常微分方程的差分方法):改进的欧拉公式(python实现_第2张图片
代码如下:

# coding=gbk;
#改进的欧拉方法需要函数的具体表达式  
#这里就暂且用书上的题目所给公式了
def compute_fx(x,y):
    return y-2*x/y;

#进行数据初始化
#需要输入初值x0 y0 步长h 以及计算的次数N
def RawDataIn(x,y,h1,N1):
    temp_list=input("请输入初值x0,y0;步长h以及总共需要计算的次数N:  ").split(" ");
    x=float(temp_list[0]);
    y=float(temp_list[1]);
    h1=float(temp_list[2]);
    N1=float(temp_list[3]);
    return x,y,h1,N1;

def Modified_Euler(x_initial,y_initial,h1,N1):
    n=0;
    y1=[];  #用来记录矫正之后的y的值
    while n  {y:.5f}".format(x=X, y=result[i-1]));

代码运行结果:
计算机数值分析(常微分方程的差分方法):改进的欧拉公式(python实现_第3张图片
书上结果:
在这里插入图片描述
计算机数值分析(常微分方程的差分方法):改进的欧拉公式(python实现_第4张图片

遇事不决,可问春风

你可能感兴趣的:(计算机数值分析,计算机数值分析,python)