annotate population_structure.py @ 0:4d28d3295ac3 default tip

Uploaded
author rico
date Fri, 06 Apr 2012 13:46:42 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
1 #!/usr/bin/env python
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
2
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
3 import errno
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
4 import os
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
5 import shutil
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
6 import subprocess
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
7 import sys
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
8 from BeautifulSoup import BeautifulSoup
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
9 import gd_composite
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
10
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
11 ################################################################################
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
12
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
13 def run_admixture(ped_file, populations):
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
14 prog = 'admixture'
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
15
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
16 args = []
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
17 args.append(prog)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
18 args.append(input_ped_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
19 args.append(populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
20
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
21 #print "args:", ' '.join(args)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
22 ofh = open('/dev/null', 'w')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
23 p = subprocess.Popen(args, bufsize=-1, stdin=None, stdout=ofh, stderr=sys.stderr)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
24 rc = p.wait()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
25 ofh.close()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
26
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
27 def run_r(input_file, output_file, populations):
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
28 prog = 'R'
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
29
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
30 args = []
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
31 args.append(prog)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
32 args.append('--vanilla')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
33 args.append('--quiet')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
34 args.append('--args')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
35 args.append(input_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
36 args.append(output_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
37 args.append(populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
38
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
39 _realpath = os.path.realpath(__file__)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
40 _script_dir = os.path.dirname(_realpath)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
41 r_script_file = os.path.join(_script_dir, 'population_structure.r')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
42
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
43 ifh = open(r_script_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
44 ofh = open('/dev/null', 'w')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
45 p = subprocess.Popen(args, bufsize=-1, stdin=ifh, stdout=ofh, stderr=None)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
46 rc = p.wait()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
47 ifh.close()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
48 ofh.close()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
49
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
50 def mkdir_p(path):
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
51 try:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
52 os.makedirs(path)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
53 except OSError, e:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
54 if e.errno <> errno.EEXIST:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
55 raise
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
56
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
57 def get_populations(input):
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
58 pops = []
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
59 pop_names = {}
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
60
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
61 with open(input) as fh:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
62 soup = BeautifulSoup(fh)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
63 misc = soup.find('div', {'id': 'gd_misc'})
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
64
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
65 return 'Populations\n{0}'.format(misc('ul')[0])
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
66
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
67 ################################################################################
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
68
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
69 if len(sys.argv) != 6:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
70 print >> sys.stderr, "Usage"
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
71 sys.exit(1)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
72
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
73 input_html_file, input_ped_file, output_file, extra_files_path, populations = sys.argv[1:6]
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
74 populations_html = get_populations(input_html_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
75
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
76 run_admixture(input_ped_file, populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
77
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
78 ped_base = os.path.basename(input_ped_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
79 if ped_base.endswith('.ped'):
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
80 ped_base = ped_base[:-4]
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
81
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
82 p_file = '%s.%s.P' % (ped_base, populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
83 q_file = '%s.%s.Q' % (ped_base, populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
84
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
85 mkdir_p(extra_files_path)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
86 numeric_output_file = os.path.join(extra_files_path, 'numeric.txt')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
87 shutil.copy2(q_file, numeric_output_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
88 os.remove(p_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
89 os.remove(q_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
90
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
91 graphical_output_file = os.path.join(extra_files_path, 'graphical.pdf')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
92 run_r(numeric_output_file, graphical_output_file, populations)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
93
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
94 ################################################################################
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
95
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
96 info_page = gd_composite.InfoPage()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
97 info_page.set_title('Population structure Galaxy Composite Dataset')
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
98
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
99 display_file = gd_composite.DisplayFile()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
100 display_value = gd_composite.DisplayValue()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
101
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
102 out_pdf = gd_composite.Parameter(name='graphical.pdf', value='graphical.pdf', display_type=display_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
103 out_txt = gd_composite.Parameter(name='numeric.txt', value='numeric.txt', display_type=display_file)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
104
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
105 info_page.add_output_parameter(out_pdf)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
106 info_page.add_output_parameter(out_txt)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
107
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
108 in_pops = gd_composite.Parameter(description='Number of populations', value=populations, display_type=display_value)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
109
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
110 info_page.add_input_parameter(in_pops)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
111
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
112 misc_pops = gd_composite.Parameter(description=populations_html, display_type=display_value)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
113
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
114 info_page.add_misc(misc_pops)
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
115
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
116
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
117 with open (output_file, 'w') as ofh:
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
118 print >> ofh, info_page.render()
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
119
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
120
4d28d3295ac3 Uploaded
rico
parents:
diff changeset
121 sys.exit(0)