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
複数の時系列チャート-