数学建模社区-数学中国
标题:
用 Euler 法、Heun 法和改进的 Euler 法求解常微分方程
[打印本页]
作者:
2744557306
时间:
2023-12-31 15:58
标题:
用 Euler 法、Heun 法和改进的 Euler 法求解常微分方程
这是一个 MATLAB 函数,用 Euler 法、Heun 法和改进的 Euler 法求解常微分方程,并比较它们的结果。以下是对你的代码的主要部分的解释:
% T8 I+ O/ n9 D) |7 k9 |
function y = Euler1(a, b, N, af)
1 v4 t) [+ i' f
h = (b - a) / N;
# N3 c2 Y' j: [# _5 v
x(1) = a;
% g' e1 z4 [7 m. y+ ^( @
y(1) = af;
- c4 \1 G3 d6 U- S. L; q. B6 f
yg(1) = af;
" a9 K; [; V, {$ p/ f7 C( ]! X7 _
yh(1) = af;
: T- t7 u ^- A% M Q" y
jqj(1) = af;
* l. G( Q- @4 B- y" \$ }
% g/ X; O8 O/ V& ]
% 迭代计算
' T& Q" Z+ X: x' B
for i = 2:N+1
. ?1 |, y) o$ u0 T* {! E. g
% Euler 法
" M) N7 K( X+ o+ V" P" X
y(i) = y(i-1) + h * f(x(i-1), y(i-1));
; L. I7 Y* t3 P" z$ s& ]! t6 j4 E
+ k: y# ?7 [" n) z6 J- d* n/ E1 _
% Heun 法
- E- c0 e- M% N& R0 \7 z4 `
yh(i) = yh(i-1) + (h/4) * (f(x(i-1), yh(i-1)) + 3 * f(x(i-1) + 2 * h/3, yh(i-1) + 2 * h * f(x(i-1), yh(i-1)) / 3));
: ]) p# i9 L7 s5 \. p% i9 {0 S& i! k
3 m1 p6 ?8 t V& S! R) [# u# W
% 改进 Euler 法
: Q, k7 A) y2 ]" ^1 G
yg(i) = yg(i-1) + h * (f(x(i-1), y(i-1)) + f(x(i), y(i) + h * f(x(i-1), y(i-1)))) / 2;
: a0 c" `5 D- ^0 w/ `, c7 w; l8 X
2 z! t! \) U4 K
x(i) = a + (i-1) * h;
' q C' [9 `8 h4 K! i1 J$ Q
jqj(i) = x(i) + exp(-x(i));
, d0 `; }, z/ c5 i- O+ f5 M
end
, }/ v3 x2 U6 a" I$ E
2 } t) a2 [7 [( D! D7 b
% 计算误差
- _/ L1 z+ @$ O9 |4 p; a# H! m- g
er = sum((y - jqj).^2); % Euler 法误差
7 i) {2 S/ N9 v9 q; o( `
erg = sum((yg - jqj).^2); % 改进 Euler 法误差
O( V! G$ \2 L8 B
erh = sum((yh - jqj).^2); % Heun 法误差
+ x( U3 @4 F! k$ x
1 `* |/ e% }5 k* a. r
% 输出结果和误差
/ T) d5 k' `2 I' H
[x', y', yg', yh', jqj']
8 b: E% F; O/ S! h B% \
disp(['Euler法误差: ', num2str(er)]);
( j" ]4 j6 i! \! R' {3 L
disp(['改进Euler法误差: ', num2str(erg)]);
2 I2 @: J/ {) F3 `* W5 k
disp(['Heun法误差: ', num2str(erh)]);
* p c: u( S& j3 b
8 }/ x; [9 u% r' j
% 绘制结果
9 s% I1 Z! {, @& X% t/ j- {
plot(x, y, 'r', x, yg, 'b', x, yh, 'k', x, jqj, 'g');
! T5 r% s- \! z* I9 P$ T+ Y
legend('Euler法', '改进Euler法', 'Heun法', '精确解');
9 P; M) A3 V2 S8 W5 Y
end
# |( Z y2 D0 U; R/ o) G
9 N1 Y4 }$ Q+ e5 v9 K' k
% 待解的常微分方程的右侧函数
& `% }# M6 {/ L. E- T$ e: M
function result = f(x, y)
( |' K2 f' g4 n% Q
result = -y - exp(-x);
2 z6 w: y% r1 `3 k+ c
end
# ]9 M; t4 o8 Y
3 {% g( O6 E0 `/ _0 G) j- _
这个函数接受四个参数:
0 X, H7 P9 i3 }( q7 w1 v$ R W
& M8 G/ h/ C5 K2 o- J
1.a 和 b:求解ODE的时间范围。
& b# p+ @ |5 ]8 s
2.N:迭代步数。
4 k! Z* ^/ J# i+ S/ _6 T* M, B
3.af:初始条件。
6 D& `( z _3 u8 {: d$ w6 a6 f1 y
) V+ a& F3 @. i9 p1 L& P* Q4 ~
在函数内部,它使用 Euler 法、Heun 法和改进的 Euler 法分别计算解,并计算了它们与精确解的误差。最后,它输出结果矩阵、误差,并通过 plot 函数将结果绘制出来。
4 Y7 J4 B5 Y1 Y" m- u; `
你可以通过调用这个函数并提供合适的参数来运行它,例如:
4 L r6 r$ M1 m! t% X% J
Euler1(0, 1, 10, 1);
* W0 @3 w7 B/ E& p, f
& a& Z9 R- g4 t2 F9 K
这将演示在给定的时间范围内使用三种不同的数值方法求解简单的常微分方程,并比较它们的结果。
. F; G! z% Y: Q$ c# o0 R. f
3 W, \; } c; V, [& D, [
+ [ B* M" U9 b$ ~
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5