热门问题
时间线
聊天
视角
欧拉方法
来自维基百科,自由的百科全书
Remove ads
在数学和计算机科学中,欧拉方法(英語:Euler method[註 1]),是一种一阶数值方法,用以对给定初值的常微分方程[註 2]求解。
![]() | 此條目可参照英語維基百科相應條目来扩充。 (2021年9月25日) |
欧拉方法是常微分方程數值方法中最基本的显式方法;是一阶的方法,意味着其局部截断误差[註 3]正比于步长的平方,并且其全局截断误差正比于步长。[註 4]
非正式的几何描述

考虑计算這樣的一个未知曲線的形状:它具有给定的起点并且满足一个给定的微分方程。 这里,所谓“微分方程”可以看作能够通过曲线上任意点的位置而计算出这一点的切线斜率的公式。
思路是,一开始只知道曲線的起点(假设为),曲線其他部份是未知的,不過通过微分方程,的斜率可以被计算出来,也就得到了切线。
顺着切线向前走一小步到点。如果假设是曲线上的一点(实际上通常不是),那么同样的道理就可以确定下一条切线,依此类推。在经过几步之后,一条折线就被计算出来了。一般情况下,这条折线与原先的未知曲线偏离不远,并且任意小的误差都可以通过减少步长来得到。
Remove ads
欧拉方法的推导


以以下微分方程為例
希望用 y 在點 (t0,y(t0)) 附近的線性近似來得到其近似解(也就是 y 的泰勒展開式的前二項)。利用時間 tn 時的數值,若用單步的欧拉方法,可得到時間 tn+1 = tn + h 時的近似值如下:
欧拉方法是一種顯型方法,也就是說 的解是 , 的顯函數。
欧拉方法可以求解一階的微分方程,而任何階的微分方程都可以表示成一階的微分方程。
對於微分方程
可以通過新設輔助變量 ,得到以下的等價方程
這是一個以為變量的一階系統,因此可以用歐拉法求解,也可以使用其他的一階數值方法。[1]
Remove ads
应用例题
设微分方程为 ,初始值为 ,试用欧拉方法求 的近似值,步长为 。
欧拉法為:
首先求(当),的定義為,因此有
透過以上步驟,求得解曲線在点的切线斜率。回顾直線斜率的定义:变化量和变化量的比值,亦記作。
接著是
重复以上步骤求出 和 的值。
由于欧拉法属于递归算法,把運算整理成表格也許有助於避免計算錯誤。
Remove ads
局部截尾误差
欧拉法的局部截尾误差(Local truncation error, LTE)是指在实施一次欧拉法所产生的误差,是指经过一步的数值解与在时精确解的误差。数值解由以下给出:
对于精确解,使用泰勒级数展开给出:
欧拉法的局部截尾误差为:
当拥有三阶有界导数时,这个结果是成立的。[2]
结果显示:当步长很小时,局部截尾误差近似与 成比例。也就是说,欧拉法精确度不如其他的高阶方法(如龙格-库塔法和线性多步法),这些方法的局部截尾误差与(p>2)成比例。
Remove ads
全局截尾误差
全局截尾误差(Global truncation error, GTE)是指在一个固定时间时的误差,但是很多步之后该方法需要以从初始时间到达该时间来计算。全局截尾误差可以看做是一个每一步的局部截尾误差的累积效应。[3] 经过的步骤數為,而每步的误差则正比于。因此,可以预期全局截尾误差是正比于的。[4]
这个直观的推测可以被嚴謹地證明。如果解存在二阶有界导数,并且關於是利普希茨连续的,那么全局截尾误差是有界的:
其中 是在给定区间内的二阶导数的上界, 是的利普希茨常数。[5]
这种精确的形式其实是没有什么意义的,通常情况下这个上界都會嚴重高估了欧拉法所造成的实际误差。[6]重要的是,这顯示了全局截尾误差是近似正比于的,所以欧拉法被稱为是一阶的。[7]
Remove ads
相關條目
- 克兰克-尼科尔森方法
- 梯度下降法,也是用有限步進行,計算函數的最小值。
- 龍格-庫塔法列表
- 線性多步法
- 數值積分(計算定積分)
- 常微分方程數值方法
註腳
参考资料
参考文献
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads