annotate mytools/venn.xml @ 9:87eb5c5ddfe9

Uploaded
author xuebing
date Fri, 09 Mar 2012 20:01:43 -0500
parents f0dc65e7f6c0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
1 <tool id="venn" name="Venn Diagram">
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
2 <description>from summary counts</description>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
3 <command interpreter="python">$script_file $labels $counts $output $script</command>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
4 <inputs>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
5 <param name="labels" type="text" value="A,B" size="50" label="Set Labels"/>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
6 <param name="counts" type="text" value="30,10,20" size="80" label="Counts in each region" help="region order: two sets: A, B, AB; three sets: A,B,C,AB,BC,AC,ABC"/>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
7 </inputs>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
8 <configfiles>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
9 <configfile name="script_file">
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
10 import os
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
11 labels = '${labels}'.replace(' ','_').split(',')
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
12 counts = '${counts}'.replace(' ','').split(',')
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
13 counts = map(int,counts)
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
14 rscript = open('${script}','w')
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
15 rscript.write("options(warn=-1)\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
16 rscript.write("pdf('"+"${output}"+"')\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
17 rscript.write("library(grid)\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
18 rscript.write("library(VennDiagram)\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
19 if len(labels)==2:
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
20 for i in range(2):
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
21 counts[i+1] = counts[i+1]+counts[i]
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
22 rscript.write("venn =venn.diagram(\n\tx=list(\n\t\t"+labels[0]+"=c(1:"+str(counts[0])+","+str(counts[1]+1)+":"+str(counts[2])+"),\n\t\t"+labels[1]+"="+str(counts[0]+1)+":"+str(counts[2])+"),\n\tfilename=NULL,\n\tfill=c('red','blue'),\n\tcol='transparent',\n\talpha=0.5,\n\tlabel.col='black',\n\tcex=2,\n\tlwd=0,\n\tfontfamily='serif',\n\tfontface='bold',\n\tcat.col = c('red', 'blue'),\n\tcat.cex=2,\n\tcat.fontfamily='serif',\n\tcat.fontface='bold')\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
23 else:
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
24 for i in range(6):
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
25 counts[i+1] = counts[i+1]+counts[i]
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
26 rscript.write("venn =venn.diagram(\n\tx=list(\n\t\t"+labels[0]+"=c(1:"+str(counts[0])+","+str(counts[2]+1)+":"+str(counts[3])+","+str(counts[4]+1)+":"+str(counts[6])+"),\n\t\t"+labels[1]+"=c("+str(counts[0]+1)+":"+str(counts[1])+","+str(counts[2]+1)+":"+str(counts[4])+","+str(counts[5]+1)+":"+str(counts[6])+"),\n\t\t"+labels[2]+"=c("+str(counts[1]+1)+":"+str(counts[2])+","+str(counts[3]+1)+":"+str(counts[6])+")),\n\tfilename=NULL,\n\tfill=c('red','blue','green'),\n\tcol='transparent',\n\talpha=0.5,\n\tlabel.col='black',\n\tcex=2,\n\tlwd=0,\n\tfontfamily='serif',\n\tfontface='bold',\n\tcat.col = c('red', 'blue','green'),\n\tcat.cex=2,\n\tcat.fontfamily='serif',\n\tcat.fontface='bold')\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
27 rscript.write("grid.draw(venn)\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
28 rscript.write("dev.off()\n")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
29 rscript.close()
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
30 os.system("cat "+"${script}"+" | R --vanilla --slave")
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
31 </configfile>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
32 </configfiles>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
33
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
34 <outputs>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
35 <data format="txt" name="script" label="${tool.name} on ${on_string}: (script)" />
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
36 <data format="pdf" name="output" label="${tool.name} on ${on_string}: (plot)" />
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
37
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
38 </outputs>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
39
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
40 <help>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
41 .. class:: infomark
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
42
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
43 This is a wrapper for R package VennDiagram. It allows you to plot two-set or three-set venn diagrams based on counts. The R script used to generate the plot is also in the output.
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
44
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
45 Input: labels for sets and counts for each region in the diagram.
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
46
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
47 A: A-only
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
48
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
49 B: B-only
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
50
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
51 C: C-only
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
52
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
53 AB: in A and B but not C
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
54
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
55 BC: in B and C but not A
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
56
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
57 AC: in A and C but not B
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
58
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
59 ABC: in A, B, and C
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
60
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
61 -----
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
62
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
63 **Example**
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
64
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
65 Labels: X,Y
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
66
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
67 Counts: 30,10,20
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
68
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
69
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
70 .. image:: ./static/images/venn2.png
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
71
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
72
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
73 Labels: A,B,C
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
74
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
75 Counts: 10,20,30,40,50,60,70
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
76
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
77
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
78 .. image:: ./static/images/venn3.png
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
79
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
80
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
81 </help>
f0dc65e7f6c0 Uploaded
xuebing
parents:
diff changeset
82 </tool>