スペクトル法は、主に高速フーリエ変換を用いた微分方程式の数値解法の総称であり、応用数学や科学計算で使用されている。 微分方程式の解をある「基底関数」の和によって近似し、方程式を充足する和の係数を求める。基底関数の選び方としては、例えば正弦波を用いる方法があり、この場合の解の近似表現はフーリエ級数になる。
スペクトル法は有限要素法と密接に関連しており、基本的にはどちらも同じアイデアに基づいている。これらの主な違いは、近似に用いる基底関数の定義域にある。スペクトル法は近似対象とする関数の定義域全体に渡って非零になるような基底関数を使用するため全体をカバーできるのに対し、有限要素法はある点の近傍など限られた範囲にのみ基底関数を用い、残りはゼロであると仮定する。こうした理由から、スペクトル法と有限要素法はそれぞれ、大域的アプローチ、局所的アプローチと呼ばれ区別される。
大域的アプローチの性質から、スペクトル法は解が滑らかな関数である場合に誤差が指数関数に従い収束するという特性(「指数収束」)を持ち、有限要素法よりも遥かに高速に収束することが知られている。 ただし、指数収束は解が滑らかでない場合には保証されないため、たとえば単連結な三次元定義域における衝撃捕捉(英語版)[1]といった課題に対しては一般に成立しない。これはインパルス波の微分不可能性に起因する。なお、有限要素法の分野でも、要素の次数がグリッド幅hと反比例して大きくなるような手法を「スペクトル要素法(英語版)」と呼ぶことがあるが、これはスペクトル法とは厳密には異なる手法である。(「#スペクトル要素法との関係」で後述)
スペクトル法を使用すると、 常微分方程式 (ODE)や偏微分方程式 (PDE)などの微分方程式を含む固有値問題を解くことができる。 時間依存のPDEにスペクトル法を適用した場合、解は時間依存の係数を持つ基底関数の合計として記述される。これをPDEに代入すると、ODEの任意の数値法を使用して解くことができる係数のODEシステムが生成される。 ODEの固有値問題も同様に行列固有値問題に変換される[要出典] 。
スペクトル法は、1969年より数学者のスティーブン・オルザグによって出版された複数編に渡る論文により確立されたものであるが、一連の論文は今日で多く実装されている周期幾何問題を対象にしたフーリエ級数を用いたもの以外にも、以下のような手法を含んでいる。
- 有限幾何・非有界幾何のための多項式スペクトル法
- 高次非線形問題のための擬球スペクトル法
- 定常問題の高速解法のためのスペクトル反復法
これらのスペクトル法は、通常、選点法やガラーキン法(英語版)、およびタウ法のいずれかを用いることで実装される。
スペクトル法は有限要素法よりも計算コストが低くなるが、複素幾何や不連続係数の問題では精度が低下する。 この誤差の増加は、 ギブス現象によるものである。
具体例(線形の場合)
ここでは、基本的な多変量計算とフーリエ級数の理解を前提としている。 もしが2つの実変数を取る既知の複素関数であり、gがx, yに関して周期的であるとき(つまり、 である場合 )、以下を満たす関数 f(x, y) を見つけることを考える。
ただし、左辺はx, yにおけるfの2次偏微分係数をそれぞれ示している。これはポアソン方程式であり、物理的には熱伝導の問題、またはポテンシャル理論の問題として解釈できる。
フーリエ級数でfとgを書くと、
であり、これを微分方程式に代入すると、次の方程式が得られる。
ここで偏微分を無限和と交換している。これは、たとえばfに連続的な2次導関数があると仮定した場合に正当である。フーリエ展開の一意性定理により、フーリエ係数を項ごとに等しくする必要がある。
- (*)
これは、フーリエ係数aj,kの陽な表現である。
周期的境界条件から、ポアソン方程式はb0,0 = 0の場合に限り解を持つ。したがって、我々は自由に解の平均値a0,0を選択することができる。これは、積分定数の選択に対応する。
ここからアルゴリズムを構成するため、有限数の周波数のみを解く。 これにより、に比例する誤差が発生する。ただしであり、は処理対象の最大周波数である。
アルゴリズム
- gのフーリエ変換(bj,k) を計算
- 式(*)を用いてfのフーリエ変換(aj,k)を計算
- (aj,k)の逆フーリエ変換を実行してfを計算
ここでは幅nの周波数の有限窓のみに関心があるため、このアルゴリズムは高速フーリエ変換を使用して実行できる。したがって、アルゴリズムはグローバルにO(n log n)時間で実行できる。
非線形の場合
スペクトルアプローチを使用し、強制的な非定常非線形バーガース方程式を解く。
与えられた周期領域で 、次式を満たすを見つけることを考える。
ここで、 ρは粘度係数である。 弱保存形では、これは次式のようになる。
ただし、 :=\int _{0}^{2\pi }f(x){\overline {g(x)}}\,dx}
は内積である。 部分積分と周期性により、
フーリエ- ガラーキン法を適用するには、以下の両方を選択する。
ただし、 。 これにより、の探索は以下の問題に帰着される。
ここで、直交関係を利用している。ただしはクロネッカーデルタである。上記の3つの項をについて整理すると次のようになる。
これらの3つの項をについてまとめることで次式を得る。
両辺をで除することで、最終的に次式を得る。
フーリエ変換後の初期条件と外力 を入力として与えることで、この常微分方程式の結合系の時間発展は、ルンゲ=クッタ法などを使った数値積分によって解くことができる。 第一項(非線形項)は畳み込み演算であるため、これも効率的に評価するための変換がいくつか存在する。 BoydおよびCanutoらの参考文献を参照してください。詳細については。
pp 235, Spectral Methods: evolution to complex geometries and applications to fluid dynamics, By Canuto, Hussaini, Quarteroni and Zang, Springer, 2007.
- Bengt Fornberg (1996) A Practical Guide to Pseudospectral Methods. Cambridge University Press, Cambridge, UK
- Chebyshev and Fourier Spectral Methods by John P. Boyd.
- Canuto C., Hussaini M. Y., Quarteroni A., and Zang T.A. (2006) Spectral Methods. Fundamentals in Single Domains. Springer-Verlag, Berlin Heidelberg
- Javier de Frutos, Julia Novo: A Spectral Element Method for the Navier–Stokes Equations with Improved Accuracy
- Polynomial Approximation of Differential Equations, by Daniele Funaro, Lecture Notes in Physics, Volume 8, Springer-Verlag, Heidelberg 1992
- D. Gottlieb and S. Orzag (1977) "Numerical Analysis of Spectral Methods : Theory and Applications", SIAM, Philadelphia, PA
- J. Hesthaven, S. Gottlieb and D. Gottlieb (2007) "Spectral methods for time-dependent problems", Cambridge UP, Cambridge, UK
- Steven A. Orszag (1969) Numerical Methods for the Simulation of Turbulence, Phys. Fluids Supp. II, 12, 250–257
- Press, WH; Teukolsky, SA; Vetterling, WT; Flannery, BP (2007). “Section 20.7. Spectral Methods”. Numerical Recipes: The Art of Scientific Computing (3rd ed.). New York: Cambridge University Press. ISBN 978-0-521-88068-8. http://apps.nrbook.com/empanel/index.html#pg=1083
- Jie Shen, Tao Tang and Li-Lian Wang (2011) "Spectral Methods: Algorithms, Analysis and Applications" (Springer Series in Computational Mathematics, V. 41, Springer), ISBN 354071040X
- Lloyd N. Trefethen (2000) Spectral Methods in MATLAB. SIAM, Philadelphia, PA