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

改进的欧拉公式
流程图以及方程式如下(以下代码是按照方程式写就)
在这里插入图片描述
在这里插入图片描述
由于使用改进的欧拉公式需要已知函数表达式的具体形式,故而这里用了书上的具体的习题
习题如下:
在这里插入图片描述
代码如下:

# 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<N1:
        n+=1;
        #先计算预测 再计算校正
        #这是预测
        x1=x_initial+h1;
        y1_pre=y_initial+h1*compute_fx(x_initial,y_initial);
        #这是校正
        y1_modify=y_initial+(compute_fx(x_initial, y_initial)+compute_fx(x1, y1_pre))*h1/2;
        y1.append(y1_modify);
        x_initial=x1;
        y_initial=y1_modify;
    return y1;

x0=y0=h=N=0;
x0,y0,h,N=RawDataIn(x0, y0, h, N);
result=[];
result=Modified_Euler(x0, y0, h, N);
for i in range(1,int(N)+1):
    X=x0+h*i;
    print("{x:.3f}  -->  {y:.5f}".format(x=X, y=result[i-1]));

代码运行结果:
在这里插入图片描述
书上结果:
在这里插入图片描述
在这里插入图片描述

遇事不决,可问春风

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值