Mercurial > repos > xuebing > sharplabtool
comparison tools/hyphy/hyphy_branch_lengths_wrapper.py @ 0:9071e359b9a3
Uploaded
author | xuebing |
---|---|
date | Fri, 09 Mar 2012 19:37:19 -0500 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:9071e359b9a3 |
---|---|
1 #Dan Blankenberg | |
2 #takes commandline tree def and input multiple fasta alignment file and runs the branch length ananlysis | |
3 import os, sys | |
4 from galaxy import eggs | |
5 from galaxy.tools.util import hyphy_util | |
6 | |
7 #Retrieve hyphy path, this will need to be the same across the cluster | |
8 tool_data = sys.argv.pop() | |
9 HYPHY_PATH = os.path.join( tool_data, "HYPHY" ) | |
10 HYPHY_EXECUTABLE = os.path.join( HYPHY_PATH, "HYPHY" ) | |
11 | |
12 #Read command line arguments | |
13 input_filename = os.path.abspath(sys.argv[1].strip()) | |
14 output_filename = os.path.abspath(sys.argv[2].strip()) | |
15 tree_contents = sys.argv[3].strip() | |
16 nuc_model = sys.argv[4].strip() | |
17 base_freq = sys.argv[5].strip() | |
18 model_options = sys.argv[6].strip() | |
19 | |
20 #Set up Temporary files for hyphy run | |
21 #set up tree file | |
22 tree_filename = hyphy_util.get_filled_temp_filename(tree_contents) | |
23 | |
24 #Guess if this is a single or multiple FASTA input file | |
25 found_blank = False | |
26 is_multiple = False | |
27 for line in open(input_filename): | |
28 line = line.strip() | |
29 if line == "": found_blank = True | |
30 elif line.startswith(">") and found_blank: | |
31 is_multiple = True | |
32 break | |
33 else: found_blank = False | |
34 | |
35 #set up BranchLengths file | |
36 BranchLengths_filename = hyphy_util.get_filled_temp_filename(hyphy_util.BranchLengths) | |
37 if is_multiple: | |
38 os.unlink(BranchLengths_filename) | |
39 BranchLengths_filename = hyphy_util.get_filled_temp_filename(hyphy_util.BranchLengthsMF) | |
40 print "Multiple Alignment Analyses" | |
41 else: print "Single Alignment Analyses" | |
42 | |
43 #setup Config file | |
44 config_filename = hyphy_util.get_branch_lengths_config_filename(input_filename, nuc_model, model_options, base_freq, tree_filename, output_filename, BranchLengths_filename) | |
45 | |
46 #Run Hyphy | |
47 hyphy_cmd = "%s BASEPATH=%s USEPATH=/dev/null %s" % (HYPHY_EXECUTABLE, HYPHY_PATH, config_filename) | |
48 hyphy = os.popen(hyphy_cmd, 'r') | |
49 #print hyphy.read() | |
50 hyphy.close() | |
51 | |
52 #remove temporary files | |
53 os.unlink(BranchLengths_filename) | |
54 os.unlink(tree_filename) | |
55 os.unlink(config_filename) |