[数学]Euler‘s Method 欧拉方法
1-思想原理
求解一阶的常微分方程ODE,欧拉想出一种数值方法,得到一种线性近似Linear approximation
他并非求解出具体的y的方程,而是根据给定的初始值\((x_0,y_0=f(x_0)\)求得下个想要求得的点\(x_n\)的函数值\(y_n=f(x_0)\),当然这样就得到了想要的点的坐标\((x_n,y_n=f(x_n)\)。
那么他是怎么做的呢?
欧拉是利用倒数的几何意义即斜率来求得下个点的坐标值
欧拉说 下个点的函数值近似等于 \[y_n = y_0 + \frac{dy}{dx}|_{x=x_0} * (x_n-x_0)\]
欧拉是借鉴了 这样的一个事实: \[\frac{y_1-y_0}{x_1-x_0}=tan\alpha\]
欧拉说如果\(h=x_1-x_0\)足够小,那么就结果值越精确
2-案例
下图是一个example,初始值为(0,2),求得在区间[0,1]上的函数值,分成等长的四段,每段长0.25,这里就体现了线性近似(看结果图)
![[数学]Euler‘s Method 欧拉方法 [数学]Euler‘s Method 欧拉方法](https://cdn.ancii.com/article/image/v1/sw/wV/kP/PkwwVsGDmjDG9swnOi7SkjVAsMQAarn73E9S3mmSmcCsa2DkyTn5Nq6McNOasyAuOlzFq_KVqSRGqcaPAjuv8Q.png)
对比图
![[数学]Euler‘s Method 欧拉方法 [数学]Euler‘s Method 欧拉方法](https://cdn.ancii.com/article/image/v1/sw/wV/kP/PkwwVsGDmjDG9swnOi7SkjVAsMQAarn73E9S3mmSmcCsa2DkyTn5Nq6McNOasyAusVL1VeHAPq0lB_2UAKeTuQ.png)
MATLAB 代码
fun = @(x,y) (x+y);
% 欧拉近似值
re = euler_method(fun,0,2,1,0.25);
fprintf('result is %f\n',re);
% 准确值
xx = 0:0.25:1;
yy = 3*exp(xx)-xx-1;
p1=plot(xx,yy,'b');
legend('Euler','Point','Exact');
% Euler Method
% f 表示一阶常微分方程
% (x0,y0):初始值
% xn要求的函数值的自变量的值
% h 步长
function y = euler_method(f,x0,y0,xn,h)
n = round((xn-x0)/h);
y = y0;
x = x0;
xa = [];
xa(1) =x0;
re = [];
re(1) = y;
for i=1:n
y = y + h*f(x,y);
x = x + h;
% 保存段点值,用于绘图
xa(i+1)=x;
re(i+1)=y;
end
p2=plot(xa,re,'r');
legend(p2,'ds');
hold on;%不清除画面
p3=scatter(xa,re,'*');% 描点
legend(p3,'ds');
endResult:
![[数学]Euler‘s Method 欧拉方法 [数学]Euler‘s Method 欧拉方法](https://cdn.ancii.com/article/image/v1/sw/wV/kP/PkwwVsGDmjDG9swnOi7SkjVAsMQAarn73E9S3mmSmcCsa2DkyTn5Nq6McNOasyAukHK4fuy-gH5hEeZwlP0xuA.png)
![[数学]Euler‘s Method 欧拉方法 [数学]Euler‘s Method 欧拉方法](https://cdn.ancii.com/article/image/v1/sw/wV/kP/PkwwVsGDmjDG9swnOi7SkjVAsMQAarn73E9S3mmSmcCsa2DkyTn5Nq6McNOasyAuiuX0iG9zHrtEd3cFiyREWA.png)
相关推荐
xceman 2020-10-13
算法与数学之美 2020-10-07
Anscor 2020-10-05
liwg0 2020-09-08
数学爱好者 2020-08-31
thermodynamicB 2020-08-11
夕加加 2020-07-20
willowwgx 2020-07-18
kuoying 2020-07-16
Anscor 2020-07-14
starletkiss 2020-07-08
kingzone 2020-06-27
xceman 2020-06-27
算法与数学之美 2020-06-21
kuoying 2020-06-21
秒懂数学 2020-06-17