次のプロットで、3つのグループ(変数 "outcome"に基づいて)の周りに楕円を追加したいと思います。そのVSDが要因の結果とバッチとDESeq2オブジェクトであることに注意してください:DESeq2のPCA上のグループの楕円
pcaData <- plotPCA(vsd, intgroup=c("outcome", "batch"), returnData=TRUE)
percentVar <- round(100 * attr(pcaData, "percentVar"))
ggplot(pcaData, aes(PC1, PC2, color=outcome, shape=batch)) +
geom_point(size=3) +
xlab(paste0("PC1: ",percentVar[1],"% variance")) +
ylab(paste0("PC2: ",percentVar[2],"% variance")) +
geom_text(aes(label=rownames(coldata_WM_D56C)),hjust=.5, vjust=-.8, size=3) +
geom_density2d(alpha=.5) +
coord_fixed()
私はそれが上から美学を継承するだろうと考え、楕円を追加しようとしたが、それは、各ポイントのために楕円を作ってみました。
stat_ellipse() +
少なすぎる点が楕円に
geom_pathを計算する:各グループは一つだけ観察から成ります。あなたはグループの美学を調整する必要がありますか?
は、計算は
stat_density2d()
に失敗しました:TRUE/FALSE必要な
提案欠損値を?前もって感謝します。マウリッツエヴァースとして
> dput(pcaData)
structure(list(PC1 = c(-15.646673151638, -4.21111051849254, 13.1215703467274,
-6.5477433859415, -3.22129766721873, 4.59321517871152, 1.84089686598042,
37.8415172383233, 40.9996810499267, 37.6089348653721, -24.5520575763498,
-46.5840253031228, -4.01498554781508, -31.227922394463), PC2 = c(31.2712754127142,
5.89621557021357, -10.2425538634254, -3.44497747426626, 2.21504480008043,
0.315695833259479, -4.66467589267529, -4.27504355920903, -1.08666029542243,
-2.69753368235982, 5.89767436709778, -24.2836532766506, 4.43980653642228,
0.659385524221137), group = structure(c(4L, 5L, 6L, 7L, 8L, 5L,
8L, 1L, 2L, 3L, 6L, 9L, 9L, 9L), .Label = c("ctrl : 1", "ctrl : 2",
"ctrl : 3", "non : 1", "non : 2", "non : 3", "preg : 1", "preg : 2",
"preg : 3"), class = "factor"), outcome = structure(c(2L, 2L,
2L, 1L, 1L, 2L, 1L, 3L, 3L, 3L, 2L, 1L, 1L, 1L), .Label = c("preg",
"non", "ctrl"), class = "factor"), batch = structure(c(1L, 2L,
3L, 1L, 2L, 2L, 2L, 1L, 2L, 3L, 3L, 3L, 3L, 3L), .Label = c("1",
"2", "3"), class = "factor"), name = structure(1:14, .Label = c("D5-R-N-1",
"D5-R-N-2", "D5-R-N-3", "D5-R-P-1", "D5-R-P-2", "D5-Z-N-1", "D5-Z-P-1",
"D6-C-T-1", "D6-C-T-2", "D6-C-T-3", "D6-Z-N-1", "D6-Z-P-1", "D6-Z-P-2",
"D6-Z-P-3"), class = "factor")), .Names = c("PC1", "PC2", "group",
"outcome", "batch", "name"), row.names = c("D5-R-N-1", "D5-R-N-2",
"D5-R-N-3", "D5-R-P-1", "D5-R-P-2", "D5-Z-N-1", "D5-Z-P-1", "D6-C-T-1",
"D6-C-T-2", "D6-C-T-3", "D6-Z-N-1", "D6-Z-P-1", "D6-Z-P-2", "D6-Z-P-3"
), class = "data.frame", percentVar = c(0.47709343625754, 0.0990361123451665
))
は私は2〜3の結果タイプに楕円を描いたグループAESを追加した、示唆しています。
「dput(pcaData)」としてください。 –
あなたの例はまだ再現性がなく、自己一貫性がありません: 'coldata_WM_D56C'はどこにも定義されていません。いずれにしても、私の解決策に基づくプロットは期待通りです。 **あなたは3点のみで信頼性楕円を計算/描画することはできません。 '?stat_ellipse'で詳細を見つけることができます。これは' car :: ellipse'とFoxとWeisbergの "応用回帰に対するRコンパニオン"にリンクしています。 –
私はあなたが楕円を計算するために> 3ポイントが必要であることを気付かなかったので、その情報とヘルプに感謝します。 –