2017-05-29 14 views
-3
library(tidyverse) # Includes the packages ggplot2 and tidyr, which we   use below 

# Get the time values for the time series 
Time = attributes(co2)[[1]] 
Time = seq(Time[1],Time[2], length.out=(Time[2]-Time[1])*Time[3]) 

# Convert td to data frame 
dat = cbind(Time, with(td, data.frame(Observed=x, Trend=trend,   Seasonal=seasonal, Random=random))) 

ggplot(gather(dat, component, value, -Time), aes(Time, value)) + 
facet_grid(component ~ ., scales="free_y") + 
    geom_line() + 
    theme_bw() + 
    labs(y=expression(CO[2]~(ppm)), x="Year") + 
    ggtitle(expression(Decomposed~CO[2]~Time~Series)) + 
    theme(plot.title=element_text(hjust=0.5)) 

私はそれがggplotで時系列分解について知っています。私は3行目と4行目の説明がほとんど必要です。私は毎月のタイムシリーズをコードに適用したい。私はこのrコードを解釈してください

答えて

0

あなたは少なくとも3

seq(Time[1],Time[2], length.out=(Time[2]-Time[1])*Time[3]) 

の長さのベクトルTimeを有するように見えるTime[1]からTime[2]の配列を作成し、得られたベクターはTime[2]-Time[1])*Time[3]で計算されるよう長さを有しています。

次の行は、一部のオブジェクトを作業中のdata.frameにバインドするだけです。 ggplot2でプロットするには、Data.framesが必要です。 ggplot2コードは多かれ少なかれあなた自身を識別できるはずの基本定型文です(superb documentationを参照)。

データがない場合でも、自分で試すことができます。

Time <- c(1, 10, 5) 
seq(from = Time[1], to = Time[2], length.out = (Time[2] - Time[1]) * Time[3]) 

[1] 1.000000 1.204545 1.409091 1.613636 1.818182 2.022727 2.227273 
[8] 2.431818 2.636364 2.840909 3.045455 3.250000 3.454545 3.659091 
[15] 3.863636 4.068182 4.272727 4.477273 4.681818 4.886364 5.090909 
[22] 5.295455 5.500000 5.704545 5.909091 6.113636 6.318182 6.522727 
[29] 6.727273 6.931818 7.136364 7.340909 7.545455 7.750000 7.954545 
[36] 8.159091 8.363636 8.568182 8.772727 8.977273 9.181818 9.386364 
[43] 9.590909 9.795455 10.000000 

私はデータでリセットするように指示します。

+0

@economia申し訳ありませんが、質問から私には分かりません... –

関連する問題