時系列-素朴な方法

前書き

時間「t」での予測値を時間「t-1」での変数の実際の値または級数の移動平均であると仮定するなどの単純な方法を使用して、統計モデルと機械学習モデルのパフォーマンスを評価します。そして彼らの必要性を強調します。

この章では、時系列データの機能の1つでこれらのモデルを試してみましょう。

最初に、データの「温度」機能の平均とその周囲の偏差を確認します。最高温度値と最低温度値を確認することも役立ちます。ここでは、numpyライブラリの機能を使用できます。

統計の表示

[135]で:

import numpy
print (
   'Mean: ',numpy.mean(df['T']), '; 
   Standard Deviation: ',numpy.std(df['T']),'; 
   \nMaximum Temperature: ',max(df['T']),'; 
   Minimum Temperature: ',min(df['T'])
)

等間隔のタイムラインにわたるすべての9357の観測値の統計があり、データを理解するのに役立ちます。

ここで、最初の単純な方法を試して、現在の予測値を前回の実際の値と等しく設定し、その二乗平均平方根誤差(RMSE)を計算して、この方法のパフォーマンスを定量化します。

1件ナイーブ方法を

[136]で:

df['T']
df['T_t-1'] = df['T'].shift(1)

[137]で:

df_naive = df[['T','T_t-1']][1:]

[138]で:

from sklearn import metrics
from math import sqrt

true = df_naive['T']
prediction = df_naive['T_t-1']
error = sqrt(metrics.mean_squared_error(true,prediction))
print ('RMSE for Naive Method 1: ', error)

ナイーブメソッド1のRMSE:12.901140576492974

次の素朴な方法を見てみましょう。ここでは、現時点での予測値は、その前の期間の平均と等しくなります。この方法のRMSEも計算します。

2番目の素朴な方法を示す

[139]で:

df['T_rm'] = df['T'].rolling(3).mean().shift(1)
df_naive = df[['T','T_rm']].dropna()

[140]で:

true = df_naive['T']
prediction = df_naive['T_rm']
error = sqrt(metrics.mean_squared_error(true,prediction))
print ('RMSE for Naive Method 2: ', error)

RMSE for Naive Method 2: 14.957633272839242

ここでは、考慮したい「ラグ」とも呼ばれる以前のさまざまな期間を試すことができます。これは、ここでは3として保持されます。このデータでは、ラグの数を増やすとエラーが増えることがわかります。ラグを1に保つと、以前に使用したナイーブな方法と同じになります。

Points to Note

  • 二乗平均平方根誤差を計算するための非常に単純な関数を書くことができます。ここでは、パッケージ「sklearn」の平均二乗誤差関数を使用して、その平方根を取りました。

  • パンダでは、df ['column_name']をdf.column_nameと書くこともできますが、このデータセットでは、df.Tはデータフレームを転置する関数であるため、df.Tはdf ['T']と同じようには機能しません。したがって、df ['T']のみを使用するか、他の構文を使用する前にこの列の名前を変更することを検討してください。