4

X軸上に変数のグループのラベルを付ける方法を見つけることができるggplot2でプロットをbluidしようとしています。これが私のコードの最小バージョンです:

Bzero   <-100*matrix(runif(100),ncol=10,nrow=10)

B   <-99
LNtype  <-c(1,1,1,1,2,2,2,3,3,3)
LNnames <-c('grp1','grp2','grp3')

tB  <-t(Bzero)/(B+1)
dfB <-data.frame(tB)
dfB$grp <-LNtype
dfB$vid <-1:nrow(tB)


mB0 <- melt(dfB,id.vars=c('grp','vid'))
mB0 <- mB0[order(mB0$grp,mB0$vid),]

gg0 <- ggplot(mB0,aes(x=vid,y=variable))
gg0 <- gg0 + geom_tile(aes(fill = value),colour = "white")
gg0 <- gg0 + scale_fill_gradient(low = "green", high = "red",na.value='white',limits=c(0,1),name='p0i')
gg0 <- gg0 + xlab('Equation')+ylab('Covariate')

結果のプロットは次のとおりです。

結果のプロット:

そして、これが私が欲しいものです: ここに画像の説明を入力してください

私はスケール、ブレイク、ラベルをいじくり回してきましたが無駄になりました。大量のグーグルでさえ、その種の軸を持つプロットを明らかにしました。私が欲しいものを手に入れる方法はありますか?

4

1 に答える 1

5

scale_x_continuous()希望の位置にブレークを使用して設定することで、数値をグループに置き換えることができます。を使用geom_segment()すると、これらの黒い線をグループデータに追加できます。

gg0+
 geom_segment(aes(x=0.5,y=0.5,xend=10.5,yend=0.5))+
 geom_segment(aes(x=c(0.5,4.5,7.5,10.5),
                  xend=c(0.5,4.5,7.5,10.5),y=rep(0.5,4),yend=rep(1,4)))+
  scale_x_continuous("",breaks=c(2.5,6,9),labels=c("Group1","Group2","Group3"))

ここに画像の説明を入力してください

于 2013-03-07T17:06:52.550 に答える