annotate signature.py @ 0:d613dbee3ce4

Imported from capsule None
author drosofff
date Mon, 03 Nov 2014 10:29:28 -0500
parents
children 2b30861d95f4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
1 #!/usr/bin/python
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
2 # script for computing overlap signatures from a bowtie output
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
3 # Christophe Antoniewski <drosofff@gmail.com>
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
4 # Usage signature.py <1:input> <2:format of input> <3:minsize query> <4:maxsize query> <5:minsize target> <6:maxsize target>
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
5 # <7:minscope> <8:maxscope> <9:output> <10:bowtie index> <11:procedure option> <12: graph (global or lattice)>
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
6 # <13: R code>
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
7 # version 2.0.0
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
8
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
9 import sys, subprocess, argparse
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
10 from smRtools import *
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
11 from collections import defaultdict # test whether it is required
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
12
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
13 def Parser():
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
14 the_parser = argparse.ArgumentParser()
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
15 the_parser.add_argument('--input', action="store", type=str, help="input alignment file")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
16 the_parser.add_argument('--inputFormat', action="store", type=str, choices=["tabular", "bam", "sam"], help="format of alignment file (tabular/bam/sam)")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
17 the_parser.add_argument('--minquery', type=int, help="Minimum readsize of query reads (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
18 the_parser.add_argument('--maxquery', type=int, help="Maximum readsize of query reads (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
19 the_parser.add_argument('--mintarget', type=int, help="Minimum readsize of target reads (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
20 the_parser.add_argument('--maxtarget', type=int, help="Maximum readsize of target reads (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
21 the_parser.add_argument('--minscope', type=int, help="Minimum overlap analyzed (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
22 the_parser.add_argument('--maxscope', type=int, help="Maximum overlap analyzed (nt) - must be an integer")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
23 the_parser.add_argument('--outputOverlapDataframe', action="store", type=str, help="Overlap dataframe")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
24 the_parser.add_argument('--referenceGenome', action='store', help="path to the bowtie-indexed or fasta reference")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
25 the_parser.add_argument('--extract_index', action='store_true', help="specify if the reference is an indexed Bowtie reference")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
26 the_parser.add_argument('--graph', action='store', choices=["global", "lattice"], help="small RNA signature is computed either globally or by item (global-lattice)")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
27 the_parser.add_argument('--rcode', type=str, help="R code to be passed to the python script")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
28 args = the_parser.parse_args()
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
29 return args
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
30
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
31 args = Parser()
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
32
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
33 if args.extract_index:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
34 GenomeFormat = "bowtieIndex"
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
35 else:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
36 GenomeFormat = "fastaSource"
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
37
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
38 if args.inputFormat == "tabular":
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
39 Genome = HandleSmRNAwindows (args.input, args.inputFormat, args.referenceGenome, GenomeFormat)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
40 elif args.inputFormat == "sam":
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
41 Genome = HandleSmRNAwindows (args.input, args.inputFormat, args.referenceGenome, GenomeFormat)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
42 else:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
43 Genome = HandleSmRNAwindows (args.input, args.inputFormat, args.referenceGenome, GenomeFormat)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
44
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
45 # replace objDic by Genome.instanceDict or... objDic = Genome.instanceDict
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
46 objDic = Genome.instanceDict
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
47
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
48 args.maxscope += 1
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
49
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
50 general_frequency_table = dict ([(i,0) for i in range(args.minscope, args.maxscope)])
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
51 general_percent_table = dict ([(i,0) for i in range(args.minscope, args.maxscope)])
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
52 OUT = open (args.outputOverlapDataframe, "w")
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
53
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
54 if args.graph == "global":
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
55 ###### for normalized summing of local_percent_table(s)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
56 readcount_dic = {}
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
57 Total_read_in_objDic = 0
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
58 for item in objDic:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
59 readcount_dic[item] = objDic[item].readcount(args.minquery, args.maxquery)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
60 Total_read_in_objDic += readcount_dic[item]
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
61 ######
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
62 for x in (objDic):
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
63 local_frequency_table = objDic[x].signature( args.minquery, args.maxquery, args.mintarget, args.maxtarget, range(args.minscope, args.maxscope) )
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
64 local_percent_table = objDic[x].hannon_signature( args.minquery, args.maxquery, args.mintarget, args.maxtarget, range(args.minscope, args.maxscope) )
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
65 try:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
66 for overlap in local_frequency_table.keys():
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
67 general_frequency_table[overlap] = general_frequency_table.get(overlap, 0) + local_frequency_table[overlap]
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
68 except:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
69 pass
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
70 try:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
71 for overlap in local_percent_table.keys():
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
72 general_percent_table[overlap] = general_percent_table.get(overlap, 0) + (1./Total_read_in_objDic*readcount_dic[x]*local_percent_table[overlap])
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
73 except:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
74 pass
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
75 print >> OUT, "overlap\tnum of pairs\tprobability"
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
76 for classe in sorted(general_frequency_table):
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
77 print >> OUT, "%i\t%i\t%f" % (classe, general_frequency_table[classe], general_percent_table[classe])
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
78
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
79 else:
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
80 print >> OUT, "overlap\tnum of pairs\tprobability\titem"
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
81 for x in (objDic):
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
82 local_frequency_table = objDic[x].signature( args.minquery, args.maxquery, args.mintarget, args.maxtarget, range(args.minscope, args.maxscope) )
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
83 local_percent_table = objDic[x].hannon_signature( args.minquery, args.maxquery, args.mintarget, args.maxtarget, range(args.minscope, args.maxscope) )
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
84 for classe in range(args.minscope, args.maxscope):
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
85 print >> OUT, "%i\t%i\t%f\t%s" % (classe, local_frequency_table[classe], local_percent_table[classe], x)
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
86
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
87 OUT.close()
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
88
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
89 ## Run the R script that is defined in the xml using the Rscript binary provided with R.
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
90 R_command="Rscript "+ args.rcode
d613dbee3ce4 Imported from capsule None
drosofff
parents:
diff changeset
91 process = subprocess.Popen(R_command.split())