R-時系列分析

時系列は、各データポイントがタイムスタンプに関連付けられている一連のデータポイントです。簡単な例は、特定の日のさまざまな時点での株式市場の株式の価格です。別の例は、1年のさまざまな月における地域の降雨量です。R言語は、時系列データを作成、操作、およびプロットするために多くの関数を使用します。時系列のデータは、と呼ばれるRオブジェクトに格納されます。time-series object。これは、ベクトルやデータフレームのようなRデータオブジェクトでもあります。

時系列オブジェクトは、 ts() 関数。

構文

の基本構文 ts() 時系列分析の関数は−

timeseries.object.name <-  ts(data, start, end, frequency)

以下は、使用されるパラメーターの説明です-

  • data 時系列で使用される値を含むベクトルまたは行列です。

  • start 時系列の最初の観測の開始時刻を指定します。

  • end 時系列の最後の観測の終了時刻を指定します。

  • frequency 単位時間あたりの観測数を指定します。

パラメータ「data」を除いて、他のすべてのパラメータはオプションです。

2012年1月以降の場所での年間降雨量の詳細を検討します。12か月間のR時系列オブジェクトを作成し、プロットします。

# Get the data points in form of a R vector.
rainfall <- c(799,1174.8,865.1,1334.6,635.4,918.5,685.5,998.6,784.2,985,882.8,1071)

# Convert it to a time series object.
rainfall.timeseries <- ts(rainfall,start = c(2012,1),frequency = 12)

# Print the timeseries data.
print(rainfall.timeseries)

# Give the chart file a name.
png(file = "rainfall.png")

# Plot a graph of the time series.
plot(rainfall.timeseries)

# Save the file.
dev.off()

上記のコードを実行すると、次の結果とチャートが生成されます-

Jan    Feb    Mar    Apr    May     Jun    Jul    Aug    Sep
2012  799.0  1174.8  865.1  1334.6  635.4  918.5  685.5  998.6  784.2
        Oct    Nov    Dec
2012  985.0  882.8 1071.0

時系列チャート-

異なる時間間隔

の値 frequencyts()関数のパラメーターは、データポイントが測定される時間間隔を決定します。値12は、時系列が12か月であることを示します。その他の値とその意味は以下のとおりです。

  • frequency = 12 1年の毎月のデータポイントをペグします。

  • frequency = 4 1年の四半期ごとにデータポイントをペグします。

  • frequency = 6 1時間の10分ごとにデータポイントをペグします。

  • frequency = 24*6 1日の10分ごとにデータポイントをペグします。

複数の時系列

両方の系列を行列に結合することにより、1つのグラフに複数の時系列をプロットできます。

# Get the data points in form of a R vector.
rainfall1 <- c(799,1174.8,865.1,1334.6,635.4,918.5,685.5,998.6,784.2,985,882.8,1071)
rainfall2 <- 
           c(655,1306.9,1323.4,1172.2,562.2,824,822.4,1265.5,799.6,1105.6,1106.7,1337.8)

# Convert them to a matrix.
combined.rainfall <-  matrix(c(rainfall1,rainfall2),nrow = 12)

# Convert it to a time series object.
rainfall.timeseries <- ts(combined.rainfall,start = c(2012,1),frequency = 12)

# Print the timeseries data.
print(rainfall.timeseries)

# Give the chart file a name.
png(file = "rainfall_combined.png")

# Plot a graph of the time series.
plot(rainfall.timeseries, main = "Multiple Time Series")

# Save the file.
dev.off()

上記のコードを実行すると、次の結果とチャートが生成されます-

Series 1  Series 2
Jan 2012    799.0    655.0
Feb 2012   1174.8   1306.9
Mar 2012    865.1   1323.4
Apr 2012   1334.6   1172.2
May 2012    635.4    562.2
Jun 2012    918.5    824.0
Jul 2012    685.5    822.4
Aug 2012    998.6   1265.5
Sep 2012    784.2    799.6
Oct 2012    985.0   1105.6
Nov 2012    882.8   1106.7
Dec 2012   1071.0   1337.8

複数の時系列チャート-