3

我正在尝试在 R 中制作一个 4 路维恩图。我有这些数据,我想把它放在图中:

在此处输入图像描述

谁能给我一个建议怎么做?我尝试使用函数 vennDiagram() 但这不起作用,因为它是一个 4way 图。

我也在尝试使用 VennDiagram 包,但数据“分配”到图中正确位置的方式确实令人困惑。我正在使用这段代码:

library (VennDiagram)
venn.diagram(
    x=list(
    I=c(1:18,19:31,32:119,125:129,130:192,193:144,145:326,327:373),
    VI=c(516:542,510:515,420:497,498:509,145:326,327:373,130:192,193:144),
    II=c(19:31,32:119,145:326,327:373,374:378,378:419,420:497,498:509),
    III=c(506:509,378:419,32:119,125:129,130:192,145:326,420:497,510:515)
    ),
    filename = "4Way_Venn.tiff",
    col = "black",
    lty = "dotted",
    lwd = 4,
    fill = c("cornflowerblue", "green", "yellow", "darkorchid1"),
    alpha = 0.50,
    label.col = c("orange", "white", "darkorchid4", "white", "white", "white", 
                  "white", "white", "darkblue", "white", "white", "white", 
                  "white", "darkgreen", "white"),
    cex = 2.5,
    fontfamily = "serif",
    fontface = "bold",
    cat.col = c("darkblue", "darkgreen", "orange", "darkorchid4"),
    cat.cex = 2.5,
    cat.fontfamily = "serif"
    );

谁能帮我?也许使用比使用 VennDiagram 包更简单的解决方案。

4

4 回答 4

4

我可能在这里遗漏了重点,但我不确定你想如何使用这些“计数”来制作你的维恩图?从“c1”到“c4”列,您可以使用venneuler包非常轻松地制作维恩图:

require(venneuler)
#here I replicate your data
#because it's repeatable, you can use `rep` function to generate it
c1 <- rep(c(0,1),each=8)
c2 <- rep(c(0,1),each=4,times=2)
c3 <- rep(c(0,1),each=2,times=4)
c4 <- rep(c(0,1),times=8)
#put your data into matrix
m <- as.matrix(data.frame(C1=c1,C2=c2,C3=c3,C4=c4))
#plot it
v = venneuler(m)
plot(v)

在此处输入图像描述

于 2012-04-11T19:03:07.687 回答
3

请注意:我尝试在几个支持这种功能的包中构建 4(和更高)维恩图,但至少在一种情况下,子空间没有正确绘制。例如,一个完全包含在另一个子集中的子集被绘制,其部分区域延伸到父子集之外。不幸的是,我不记得是哪个包做到了。
所以,我的回答是:venneuler像 GOA 所说的那样尝试,尝试require(sos); ???venn,并确保仔细测试每个包,以确保它正确地呈现交叉点。

于 2012-04-11T19:18:53.483 回答
1

使用新版本的 nVennR 包 (0.2.0),您可以通过两种方式进行操作:

1)根据您提供的代码,

myV <- plotVenn(list(I=c(1:18,19:31,32:119,125:129,130:192,193:144,145:326,327:373), 
IV=c(516:542,510:515,420:497,498:509,145:326,327:373,130:192,193:144), 
II=c(19:31,32:119,145:326,327:373,374:378,378:419,420:497,498:509), 
III=c(506:509,378:419,32:119,125:129,130:192,145:326,420:497,510:515)),
setColors = c("cornflowerblue", "green", "yellow", "darkorchid1"), borderWidth=3, opacity=0.2)

结果

2) 直接从第一次上市,

myV2 <- createVennObj(nSets = 4, sNames = c("c1", "c2", "c3", "c4"), sSizes = c(26, 27, 4, 6, 5, 12, 42, 78, 18, 52, 4, 63, 13, 47, 88, 182))
myV2 <- plotVenn(nVennObj = myV2)

结果2

第一种方法的优点之一是可以查询每个区域中的元素:

getVennRegion(myV, c("I", "III"))
[1] 125 126 127 128 129
于 2018-04-11T17:31:39.177 回答
0

VennDiagram 包有一个用于 4 路维恩的函数,即 draw.quad.venn() 函数:

http://cran.r-project.org/web/packages/VennDiagram/VennDiagram.pdf

于 2014-08-08T09:45:46.937 回答