コンテンツにスキップ

自己回帰和分移動平均モデル

出典: フリー百科事典『ウィキペディア(Wikipedia)』

統計学計量経済学、特に時系列分析において、自己回帰和分移動平均(じこかいきわぶんいどうへいきん、: Autoregressive integrated moving average、略称: ARIMA)モデルは、自己回帰移動平均(ARMA)モデルの一般化である。これらのモデルは、データの理解を深めるため、または将来のポイントを予測するために、時系列データに適用される。

ARIMAモデルは、データが(分散/自己共分散ではなく)平均に関して非定常性を示す場合に適用され、初期の差分ステップ(モデルの「Integrated 和分」部分に対応)を 1回以上適用して平均関数(すなわち、トレンド)の非定常性を排除することができる[1]。時系列に季節性が見られる場合は、季節成分を除去するために季節的差分を適用することができる[2]。ウォルドの分解定理によれば、ARMAモデルは規則的な(つまり純粋に非決定論的な)広義の定常時系列を記述するのに理論的には十分であるので、ARMAモデルを使用する前に、例えば差分を使用して非定常時系列を定常化することが主な動機となる[3][4][5][6]。時系列に予測可能なサブプロセス(純粋な正弦波や複素数指数プロセス)が含まれている場合、予測可能な成分はARIMAのフレームワークでは平均非ゼロで周期的な(つまり季節的な)成分として扱われるので、季節的な差分処理によって除去されることに注意が必要である。

ARIMAのAR(autoregressive、自己回帰)の部分は、関心のある展開する変数がそれ自体の遅延した値(すなわち、以前の値)に回帰されることを示している。MA(moving average、移動平均)の部分は、回帰誤差が実際には、同時期および過去の様々な時点で発生した誤差項の線型結合であることを示している[7]。I (integrated 和分)の部分は、データの値が過去の値との差分に置き換えられていることを示している(この差分処理は複数回行われる場合もある)。これらの特徴の目的は、モデルがデータにできるだけ適合するようにすることである。

非季節ARIMAモデルは、一般に と表記される。パラメータpdqは非負の整数で、pは自己回帰モデルの次数(タイムラグの数)、dは差分の階数(データの過去の値を差し引いた回数)、q移動平均モデルの次数を表す。

季節ARIMAモデルは、通常 と表記される。ここで、mは各季節の期間の数を意味し、大文字のPDQはARIMAモデルの季節部分の自己回帰項、差分項、移動平均項を意味する[2] [8]

3つの項のうち2つがゼロの場合、モデルを表す頭字語のうちゼロではないパラメータを用いてモデルを記載することができる。例えば、 と記載される。

ARIMAモデルは、ボックス・ジェンキンス法に従って推定することができる。

定義

[編集]

時系列データXttは整数インデックス、Xtは実数)が与えられたとき、 モデルは下記のようになる。

または同等に

ここで、はラグ演算子、はモデルの自己回帰部分のパラメーター、は移動平均部分のパラメータ、は誤差項である。誤差項は、一般に、平均ゼロの正規分布からサンプリングされた独立同分布の変数であるとみなされる。

ここで、多項式 が多重度d単位根(因子1 - L)を持つ場合、次のように書き換えることができる。

プロセスでは、p = p'-dで用いて、次のように表す。

したがって、d個の単位根を持つ自己回帰多項式を持つ プロセスの特殊なケースと考えることができる。 このため、d > 0 のARIMAモデルで正確に記述されるプロセスは広義の定常ではない。

上記は次のように一般化できる。

これは、ドリフト を伴う プロセスを定義する。

差分

[編集]

定常時系列の性質は、観測された時刻に依存しない。具体的には、広義の定常時系列では、平均と分散/自己共分散は時間の経過とともに一定になる。統計における差分とは、非定常時系列を平均的な意味で定常化するために(つまり、非定常トレンドを除去するために)適用される変換であり、分散/自己共分散の非定常性とは関係がない。同様に、季節性時系列に季節差分を適用して季節成分を除去する。信号処理、特にフーリエ・スペクトル解析理論の観点からは、トレンドは非定常時系列のスペクトルにおける低周波数部分であり、季節はそのスペクトルにおける周期的な周波数部分である。したがって、差分はハイパス(つまり、ローストップ)フィルタとして、季節差分はコムフィルタとして機能し、それぞれ低周波のトレンドと周期的な周波数の季節を(時間領域で直接ではなく)スペクトル領域で抑制することができる[6]。この観点から、差分と季節差分の哲学、数学、力、欠点を説明することができる。

データの差分を取るために、連続した観測値の差を計算する。数学的には次のようになる。

差分は時系列のレベルの変化を取り除き、トレンドと季節性を排除し、結果的に時系列の平均値を安定させる[6]

定常時系列を得るために、2回に渡ってデータの差分を取る必要がある場合もあり、これは 2次差分と呼ばれる。

データの差分を取るもう一つの方法として、季節差分がある。これは、観測値と前の季節(例えば1年)の対応する観測値との差を計算するものである。これは次のように示される。

そして、この差分を取ったデータを用いて、ARMAモデルを推定する。

[編集]

いくつかのよく知られていた特殊なケースは、自然に生じたり、他の一般的な予測モデルと数学的に同等であったりする。例えば:

  • モデル(または モデル)は次の式で与えられ、ランダムウォークを示す。
  • 定数項を伴う モデルは次の式で与えられ、ドリフトを伴うランダムウォークを示す。
  • モデルはホワイトノイズモデルである。
  • モデルは、減衰を伴う Holt のモデルである。
  • 定数項のない モデルは、基本的な指数平滑化モデルである。 [9]
  • モデルは次の式で与えられ、加法誤差または二重指数平滑化を使用したHoltの線型法と同等である[9]

次数の選択

[編集]

次数pおよびqは、サンプル自己相関関数(ACF)、偏自己相関関数(PACF)、拡張自己相関関数(EACF)法を用いて決定することができる[10]

その他の代替法として、AIC、BICなどがある[10]。非季節性ARIMAモデルの次数を決定するためには赤池情報量規準(AIC)が有用である。AICは次のように書かれる。

ここで、Lはデータの尤度、p自己回帰モデル部分の次数、q移動平均モデル部分の次数であり、k' はARIMAモデルの切片を表す。AICでは k = 1の場合はARIMAモデルに切片があり(c ≠ 0)、k = 0 の場合はARIMAモデルに切片がない(c = 0)ことになる。

ARIMAモデルの補正AICは、次のように書くことができる。

ベイズ情報量規準(BIC)は、次のように書くことができる。

目標は、良いモデルのAIC、AICc、BICの値を最小化することである。調査するモデルの範囲でこれらの基準の一つの値が低ければ低いほど、そのモデルはデータに適している。AICとBICは 2つのまったく異なる目的で使用される。AICがモデルを現実の状況に近づけようとするのに対し、BICは完全な適合性をみつけようとする。BICのアプローチは、現実の複雑なデータに完璧にフィットすることはないと批判されることが多いが、AICに比べてパラメータが多いことでモデルに大きなペナルティを与えるため、選択のための有効な手法であることに変わりはない。

AICcは、差分の次数が等しいARIMAモデルの比較にのみ使用できる。差分の次数が異なるARIMAモデルについては、RMSEをモデルの比較に使用することができる。

係数の推定

[編集]

ARIMAモデルを使用した予測

[編集]

ARIMAモデルは、2つのモデルの「カスケード」と見なすことができる。1つ目は非定常である:

2番目は広義の定常である:

こうして、プロセスYtを自己回帰予測法の一般化を用いて予測することができる。

予測区間

[編集]

ARIMAモデルの予測区間(予測の信頼区間)は、残差が無相関で正規分布しているという仮定に基づいている。これらの仮定のいずれかが当てはまらない場合、予測間隔が正しくない可能性がある。このため、研究者は予測区間を作成する前に、過程をチェックするために残差のACFとヒストグラムをプロットする。

95%の予測区間は

ここで、 の分散である

のとき、パラメータや次数に関係なく、すべてのARIMAモデルに適用される。対して。

の場合、

[要出典][要出典]

一般に、ARIMAモデルからの予測区間は、予測期間が長くなるにつれて広がる。

バリエーションと拡張

[編集]

ARIMAモデルにはいくつかのバリエーションがある。複数の時系列を使用する場合は をベクトルと考えることができ、VARIMAモデルが適切な場合がある。モデルに季節効果が疑われるときは、モデルのARやMAの次数を増やすよりも、SARIMA(季節ARIMA)モデルを使用する方が一般的には良いと考えられる[11]。時系列が長距離依存性を示すと疑われる場合、フラクショナルARIMA(FARIMAまたはARFIMA)モデルとも呼ばれる自己回帰フラクショナル和分移動平均モデルでは、d パラメーターに非整数値を持たせることができる。

ソフトウェアの実装

[編集]

ARIMAモデルに適切なパラメータを見つけるため、Box-Jenkinsパラメータ最適化のような方法論を適用する様々なパッケージがある。

  • EViews:広範なARIMAおよびSARIMA機能を備えている
  • Julia:TimeModelsパッケージにARIMA実装が含まれている[12]
  • MathematicaARIMAProcess関数が含まれている
  • MATLABEconometrics Toolbox には、ARIMAモデルARIMAエラーを伴う回帰が含まれる
  • NCSS:ARIMA ィッティングと予測のためのいくつかの手順が含まれる [13] [14] [15]
  • Pythonstatsmodelsパッケージには、時系列分析のモデル(AR、ARIMA、VARなど)や時系列分析のプロセスモデルが含まれている。
  • R:標準のR statsパッケージには、 ARIMA Modelling of Time Series に記載されている arima 関数が含まれている。この他に の部分では、この関数は季節要因、切片項、外性変数(xreg 、「外部回帰因子」と呼ばれる)も含む。CRAN task view on Time Series が参考になり、さらに多くのリンクがある。Rforcast パッケージは auto.arima() 関数を用いて与えられた時系列のARIMAモデルを自動的に選択することができ、また、simulate.simulate() 関数を用いて季節性および非季節性のARIMAモデルをシミュレートすることができる[16]
  • Rubystatsample-timeseries gemは、ARIMAモデルやカルマンフィルターなどの時系列分析に使用される。
  • JavaScriptarima パッケージには、時系列分析と予測のモデルが含まれている(ARIMA、SARIMA、SARIMAX、AutoARIMA)
  • Cctsa パッケージには、ARIMA、SARIMA、SARIMAX、AutoARIMA、および時系列分析のための複数の方法が含まれている
  • SAFE TOOLBOXESARIMA モデリングARIMAエラーを伴う回帰が含まる
  • SAS:計量経済学および時系列分析システム(SAS/ETS)に広範なARIMA処理が含まれている
  • IBM SPSS:StatisticsパッケージとModeler statisticalパッケージにARIMAモデリングが含まれている。デフォルトのExpert Modeler機能は、様々な季節性および非季節性の自己回帰 p、和分 d、移動平均 q の設定と、7つの指数平滑化モデルを評価する。Expert Modelerは、対象となる時系列データを平方根や自然対数に変換することもできる。 また、Expert ModelerをARIMAモデルに限定したり、Expert Modelerを使用せずにARIMAの季節性および非季節性の pdq 設定を手動で入力するオプションもある。7種類の外れ値の自動検出が可能で、この機能が選択されている場合、検出された外れ値は時系列モデルに収容される。
  • SAP:SAP ERPのAPO-FCSパッケージ[17] は ARIMA モデルの作成とボックス・ジェンキンスの方法論によるフィッティングを可能にする
  • SQL Server Analysis Services:MicrosoftのデータマイニングアルゴリズムとしてARIMAが含まれている
  • Stata:Stata 9以降のARIMAモデリング(arimaコマンドを使用)が含まれている
  • StatSimForecastWeb アプリにARIMAモデルが含まれている
  • Teradata Vantage:機械学習エンジンの一部としてARIMA機能を備えている
  • TOL(Time Oriented Language):ARIMAモデル(SARIMA、ARIMAX、DSARIMAXを含む)をモデル化するように設計されている[1]
  • Scalaspark-timeseriesライブラリには、Scala、Java、Python用のARIMA実装が含まれ、Apache Spark上で動作するように設計されている
  • PostgreSQL / MadLib:Time Series Analysis/ARIMA
  • X-12-ARIMA:米国国勢調査局

関連項目

[編集]

脚注

[編集]

出典

[編集]
  1. ^ For further information on Stationarity and Differencing see https://www.otexts.org/fpp/8/1
  2. ^ a b Hyndman, Rob J; Athanasopoulos, George. 8.9 Seasonal ARIMA models. oTexts. https://www.otexts.org/fpp/8/9 19 May 2015閲覧。 
  3. ^ Triacca (19 Feb 2021). “The Wold Decomposition Theorem”. 2021年8月4日閲覧。
  4. ^ Hamilton, James (1994). Time Series Analysis. Princeton University Press. ISBN 9780691042893 
  5. ^ Papoulis, Athanasios (2002). Probability, Random Variables, and Stochastic processes. Tata McGraw-Hill Education 
  6. ^ a b c Wang, Shixiong; Li, Chongshou (18 December 2019). "Why Are the ARIMA and SARIMA not Sufficient". arXiv:1904.07632 [stat.AP]。
  7. ^ Box, George E. P. (2015). Time Series Analysis: Forecasting and Control. WILEY. ISBN 978-1-118-67502-1 
  8. ^ Notation for ARIMA Models”. Time Series Forecasting System. SAS Institute. 19 May 2015閲覧。
  9. ^ a b Introduction to ARIMA models”. people.duke.edu. 2016年6月5日閲覧。
  10. ^ a b Missouri State University. “Model Specification, Time Series Analysis”. 2021年8月4日閲覧。
  11. ^ Swain, S (2018). “Development of an ARIMA Model for Monthly Rainfall Forecasting over Khordha District, Odisha, India”. Recent Findings in Intelligent Computing Techniques. Advances in Intelligent Systems and Computing. 708. 325–331). doi:10.1007/978-981-10-8636-6_34. ISBN 978-981-10-8635-9 
  12. ^ TimeModels.jl www.github.com
  13. ^ ARIMA in NCSS,
  14. ^ Automatic ARMA in NCSS,
  15. ^ Autocorrelations and Partial Autocorrelations in NCSS
  16. ^ 8.7 ARIMA modelling in R | OTexts. https://www.otexts.org/fpp/8/7 2016年5月12日閲覧。 
  17. ^ Box Jenkins model”. SAP. 8 March 2013閲覧。

参考文献

[編集]

外部リンク

[編集]