5

シリーズ情報用に独自のラベルを追加しようとしているプロット (サンプル コードを下に貼り付け) があります。「p1s1」「p1s2」「p3s4」をプロットする代わりに、「処理1」「処理2」「処理3」をお願いします。level(series_id) を使用して一意のシリーズ名を取得し、ルックアップ テーブルを使用して説明を取得しました。(これは、プロットされているのと同じ順序でそれらを取得すると思いますか?) そして、これらの説明を Treatment_descriptions と呼ばれるベクトルに入れています。

ドキュメントから、ここではスケールを使用する必要があると思いますが、どれを使用するか、またはどのように使用するかわかりません。次のようなもの: scale_something(name="治療の説明"、breaks=NULL、labels=治療の説明、formatter=NULL) ? しかし、これはどこに行くべきですか?

library(ggplot2)

# Create a long data.frame to store data...
growth_series = data.frame ("read_day" = c(0, 3, 9, 0, 3, 9, 0, 2, 8), 
"series_id" = c("p1s1", "p1s1", "p1s1", "p1s2", "p1s2", "p1s2", "p3s4", "p3s4", "p3s4"),
"mean_od" = c(0.6, 0.9, 1.3, 0.3, 0.6, 1.0, 0.2, 0.5, 1.2),
"sd_od" = c(0.1, 0.2, 0.2, 0.1, 0.1, 0.3, 0.04, 0.1, 0.3),
"n_in_stat" = c(8, 8, 8, 8, 7, 5, 8, 7, 2)
)

> # Now gives us some example long form data...
> > growth_series 
>  read_day series_id mean_od sd_od        n_in_stat   
>   1       p1s1     0.6      0.10         8 2       
>   3       p1s1     0.9      0.20         8 3    
>   9       p1s1     1.3      0.20         8 4    
>   0       p1s2     0.3      0.10         8 5    
>   3       p1s2     0.6      0.10         7 6    
>   9       p1s2     1.0      0.30         5 7    
>   0       p3s4     0.2      0.04         8 8    
>   2       p3s4     0.5      0.10         7 9    
>   8       p3s4     1.2      0.30         2 2

# Plot using ggplot...
ggplot(data = growth_series, aes(x = read_day, y = mean_od, group = series_id, color = series_id)) +
geom_line(size = 1.5) +
geom_point(aes(size = n_in_stat)) +
geom_errorbar(aes(ymin = mean_od - sd_od, ymax = mean_od + sd_od), size = 1, width = 0.3) +
xlab("Days") + ylab("Log (O.D. 730 nm)") +
scale_y_log2() +
scale_colour_hue('my legend', breaks = levels(growth_series$series_id), labels=c('t1', 't2', 't3'))
4

1 に答える 1

6

多分あなたはあなたの因子にラベルを付け直すことができますか?

growth_series$series_id <- factor(
     growth_series$series_id, 
     labels=c('treatment 1', 't2', 't3'))

または、まだ scale_something を探している場合は、scale_colour_hue() である必要があります。

... + scale_colour_hue('my legend', 
   breaks = levels(growth_series$series_id), 
   labels=c('t1', 't2', 't3'))
于 2010-02-26T07:11:29.290 に答える