How to | フィットしたモデルの結果を得る方法
データをモデルにフィットさせる場合,データをフィットした関数と比べるために結果を余分に得ることが重要であることが多い.パラメータの有意性をチェックし,モデルの仮定,データ点の影響,フィットの度合を判断したいことがあるかもしれない.Mathematica では,これらの結果をLinearModelFit,NonlinearModelFit,GeneralizedLinearModelFit等のモデルをフィットさせる関数によって返されるFittedModelオブジェクトから直接得ることができる.
まず使用するデータ集合を定義する:
LinearModelFitを使って簡単な線形回帰モデルをフィットさせることができる:
| Out[13]= |  |
出力はフィットさせるデータおよびもとのデータに関する情報を含むFittedModelオブジェクトである.オブジェクトから直接結果と診断を得ることができる.
Normalを使ってフィットしたモデルの関数的形式を与える:
| Out[14]= |  |
特定の点においてモデルを評価することもできる.
もとの変数
の関数としてではなく,
の関数としてモデルを評価する:
| Out[15]= |  |
数値で評価すると,
がその数値のときに関数が予測する値を返す:
| Out[16]= |  |
FittedModelオブジェクトは関数のように評価するので,Plotを使ってそれを直接プロットすることができる:
| Out[17]= |  |
Showを使ってデータ点のListPlotを前のプロットと組み合せることによって,データ点をフィットした関数と一緒に可視化することができる:
| Out[18]= |  |
FittedModelオブジェクトは,オブジェクトが表すモデルの型(この場合は線形モデル)に関連する数多くの結果と診断も含む.FittedModelを
で評価して,そのモデルで使用できる特性の完全リストを得ることができる.
以下ではLengthを使ってこのモデルに既知である特性の数を得る:
| Out[19]= |  |
パラメータ推測値が統計的に有意であるかどうか,つまりパラメータ値が0から大きく異なるかどうかをチェックすることが重要であることが多い.例えば,線形モデルにおいて,そのパラメータに関連する
統計の
値を見るという場合がある.
値は,得られた
統計と少なくとも同じくらい0から離れたt統計を得る確率である.
をFittedModelで使ってパラメータ推定値,
統計,
値をまとめた表を表示する:
| Out[20]= |  |
別の特性を使って別々に
統計と
値を得ることもできる.これはこれらの特性に基づいて別の結果を計算したい場合に特に便利である.
をFittedModelで使って
値だけを見る:
| Out[21]= |  |
特性のリストを入力して,複数の特性を一度に見る.
統計と
値を一緒に見る:
| Out[22]= |  |
パラメータの信頼区間を得ることもできる:
| Out[23]= |  |
デフォルトで95%信頼区間が返される.別のレベルの信頼を異なる区間で得たい場合にはConfidenceLevelオプションを使う.
パラメータの99%信頼区間を見る:
| Out[24]= |  |
残差等のその他の点別の診断も含まれている.
以下ではフィットしたモデルの残差を計算し
に割り当てる:
| Out[25]= |  |
ListPlotを使って残差を可視化する:
| Out[26]= |  |
使用できる特性はいくらか異なるものの,非線形と一般線形のモデルの結果と診断も同じ方法で求めることができる.これらの型のモデルは,NonlinearModelFit,GeneralizedLinearModelFit,LogitModelFit,ProbitModelFitのいずれかを使ってフィットさせることができる.
使用する別のデータ集合を定義する:
NonlinearModelFitを使ってデータを指数モデルにフィットさせる:
| Out[16]= |  |
線形モデルの場合と同様に,Showを使ってデータ点のプロットとモデルを組み合せる:
| Out[17]= |  |
個々の点における推定値の表形式の結果を見ることもできる.
をFittedModelと使って,予測値を誤差推定および信頼区間と一緒に表で見る:
| Out[18]= |  |
関連する予測帯を可視化することもできる.
まずフィットした関数の80%,90%,95%,99%の予測帯についての関数を定義する:
帯で囲まれる領域をフィットした関数と一緒に可視化し,Fillingを使ってそれぞれの信頼レベルの領域をより分かりやすく見られるようにする:
| Out[20]= |  |