ggplot を使用して、さまざまなイベントを日付 (x 軸) と開始時刻 (y 軸) の関数としてプロットしています。データ/コードは次のとおりです。
date<-c("2013-06-05","2013-06-05","2013-06-04","2013-06-04","2013-06-04","2013-06-04","2013-06-04",
"2013-06-04","2013-06-04","2013-06-03","2013-06-03","2013-06-03","2013-06-03","2013-06-03",
"2013-06-02","2013-06-02","2013-06-02","2013-06-02","2013-06-02","2013-06-02","2013-06-02")
start <-c("07:36:00","01:30:00","22:19:00","22:12:00","20:16:00","19:19:00","09:00:00",
"06:45:00","01:03:00","22:15:00","19:05:00","08:59:00","08:01:00","07:08:00",
"23:24:00","20:39:00","18:53:00","16:57:00","15:07:00","14:33:00","13:24:00")
duration <-c(0.5,6.1,2.18,0.12,1.93,0.95,10.32,
2.25,5.7,2.78,3.17,9.03,0.95,0.88,
7.73,2.75,1.77,1.92,1.83,0.57,1.13)
event <-c("AF201","SS431","BE201","CD331","HG511","CD331","WQ115",
"CD331","SS431","WQ115","HG511","WQ115","CD331","AF201",
"SS431","WQ115","HG511","WQ115","CD331","AS335","CD331")
df<-data.frame(date,start,duration,event)
library(ggplot2)
library(scales)
p <- ggplot(df, aes(as.Date(date),as.POSIXct(start,format='%H:%M:%S'),color=event))
p <- p+geom_point(alpha = I(6/10),size=5)
p + ylab("time (hr)") + xlab("date") + scale_x_date(labels = date_format("%m/%d")) +
scale_y_datetime(labels = date_format("%H"))+
scale_colour_hue(h=c(360, 90))
theme(axis.text.x = element_text(hjust=1, angle=0))
結果のプロットは次のようになります。
質問:イベントの開始時刻を 1 つのポイント (上図) で示すだけでなく、イベントの期間全体にわたるバーをプロットするにはどうすればよいですか? 上記のデータ フレームに示すように、この期間データ (時間単位) があります。または、「停止時間」を指定することもできます (表示されていません)。
ソリューションは積み上げ棒グラフのようになると想像しています。ただし、棒グラフは、棒がプロットの下部から始まり、垂直に積み上げられたイベント間に隙間がないことを前提としているため、正確ではありません。私のイベントは、連続していない可能性があります。y 軸に沿ったさまざまな位置で「開始」および「停止」しています。ソリューションでは、1) 一部のイベントが最終的に同時発生する (時間が重複する) 可能性があること、および 2) 一部のイベントが複数日にまたがることも考慮する必要があります。
どんな提案にもとても感謝しています!