を使用して叙階パッケージに取り組んでいますggplot2
。現在、ローディングを矢印で表す従来の方法でバイプロットを作成しています。キャリブレーションされた軸を使用し、負荷軸を原点を通る線として表し、負荷ラベルをプロット領域の外側に表示することにも興味があります。ベースRでは、これは実装されています
library(OpenRepGrid)
biplot2d(boeker)
しかし、私は解決策を探していggplot2
ます。でこのようなことを達成する方法を考えている人はいますggplot2
か? プロット領域の外側に変数名を追加することは、ここのように行うことができると思いますが、プロット領域の外側の線分をどのようにプロットできますか?
現在私が持っているのは
install.packages("devtools")
library(devtools)
install_github("fawda123/ggord")
library(ggord)
data(iris)
ord <- prcomp(iris[,1:4],scale=TRUE)
ggord(ord, iris$Species)
積載量はord$rotation
PC1 PC2 PC3 PC4
Sepal.Length 0.5210659 -0.37741762 0.7195664 0.2612863
Sepal.Width -0.2693474 -0.92329566 -0.2443818 -0.1235096
Petal.Length 0.5804131 -0.02449161 -0.1421264 -0.8014492
Petal.Width 0.5648565 -0.06694199 -0.6342727 0.5235971
原点、外側の目盛り、および軸領域の外側のラベルを通る線を追加するにはどうすればよいですか (ラベルの重なりに対して上記で適用されたクールなジッターを含む可能性があります)。
注意: クリッピングをオフにしたくありません。プロット要素の一部がバウンディング ボックスの外に出てしまうことがあるためです。
編集:他の誰かが以前に同様の質問をしたようですが、質問にはまだ答えがありません。ベースRでこのようなことを行うには(醜い方法ではありますが)、たとえばできることを指摘しています。
plot(-1:1, -1:1, asp = 1, type = "n", xaxt = "n", yaxt = "n", xlab = "", ylab = "")
abline(a = 0, b = -0.75)
abline(a = 0, b = 0.25)
abline(a = 0, b = 2)
mtext("V1", side = 4, at = -0.75*par("usr")[2])
mtext("V2", side = 2, at = 0.25*par("usr")[1])
mtext("V3", side = 3, at = par("usr")[4]/2)
最小限の実行可能な例は次のとおりggplot2
です
library(ggplot2)
df <- data.frame(x = -1:1, y = -1:1)
dfLabs <- data.frame(x = c(1, -1, 1/2), y = c(-0.75, -0.25, 1), labels = paste0("V", 1:3))
p <- ggplot(data = df, aes(x = x, y = y)) + geom_blank() +
geom_abline(intercept = rep(0, 3), slope = c(-0.75, 0.25, 2)) +
theme_bw() + coord_cartesian(xlim = c(-1, 1), ylim = c(-1, 1)) +
theme(axis.title = element_blank(), axis.text = element_blank(), axis.ticks = element_blank(),
panel.grid = element_blank())
p + geom_text(data = dfLabs, mapping = aes(label = labels))
しかし、ラベルには運がないことがわかるので、クリッピングをオフにする必要のない解決策を探しています。
EDIT2:関連する質問のビットは、因子負荷の座標系を表示するために、X軸の上部とY軸の右側にカスタムブレーク/目盛りとラベルを赤で追加する方法です? (矢印をより明確にするために因子スコアに相対的にスケーリングする場合、通常は単位円と組み合わせます)