# data
set.seed (123)
xvar <- c(rnorm (1000, 50, 30), rnorm (1000, 40, 10), rnorm (1000, 70, 10))
yvar <- xvar + rnorm (length (xvar), 0, 20)
myd <- data.frame (xvar, yvar)
# density plot for xvar
upperp = 80 # upper cutoff
lowerp = 30 # lower cutoff
x <- myd$xvar
plot(density(x))
dens <- density(x)
x11 <- min(which(dens$x <= lowerp))
x12 <- max(which(dens$x <= lowerp))
x21 <- min(which(dens$x > upperp))
x22 <- max(which(dens$x > upperp))
with(dens, polygon(x = c(x[c(x11, x11:x12, x12)]),
y = c(0, y[x11:x12], 0), col = "green"))
with(dens, polygon(x = c(x[c(x21, x21:x22, x22)]),
y = c(0, y[x21:x22], 0), col = "red"))
abline(v = c(mean(x)), lwd = 2, lty = 2, col = "red")
# density plot with yvar
upperp = 70 # upper cutoff
lowerp = 30 # lower cutoff
x <- myd$yvar
plot(density(x))
dens <- density(x)
x11 <- min(which(dens$x <= lowerp))
x12 <- max(which(dens$x <= lowerp))
x21 <- min(which(dens$x > upperp))
x22 <- max(which(dens$x > upperp))
with(dens, polygon(x = c(x[c(x11, x11:x12, x12)]),
y = c(0, y[x11:x12], 0), col = "green"))
with(dens, polygon(x = c(x[c(x21, x21:x22, x22)]),
y = c(0, y[x21:x22], 0), col = "red"))
abline(v = c(mean(x)), lwd = 2, lty = 2, col = "red")
双方向密度プロットをプロットする必要があります。次よりも良い方法があるかどうかはわかりません。
ggplot(myd,aes(x=xvar,y=yvar))+
stat_density2d(aes(fill=..level..), geom="polygon") +
scale_fill_gradient(low="blue", high="green") + theme_bw()
3つのタイプすべてを1つに結合したい(ggplotで双方向プロットを作成できるかどうかはわかりませんでした)。ソリューションがggplotであるか、ベースであるか、混合であるかについての傾向はありません。Rの堅牢性を考えると、これが実行可能なプロジェクトであることを願っています。私は個人的にggplot2を好みます。
注:このプロットの下の陰影は正しくありません。xvarおよびyvarグラフでは、赤は常に下に、緑は上にある必要があります。これは、xy密度プロットの影付きの領域に対応します。
編集:グラフの最終的な期待(非常に近い答えをくれたsethとjonに感謝します)(1)スペースと軸の目盛りラベルなどを削除してコンパクトにし
ます(2)グリッドの配置。ラベルとプロットのサイズは同じように見えます。