Mercurial > repos > yufei-luo > s_mart
view commons/launcher/launchPhyML.py @ 31:0ab839023fe4
Uploaded
author | m-zytnicki |
---|---|
date | Tue, 30 Apr 2013 14:33:21 -0400 |
parents | 94ab73e8a190 |
children |
line wrap: on
line source
#!/usr/bin/env python import os import sys import getopt from pyRepet.launcher.programLauncher import programLauncher from commons.tools.ChangeSequenceHeaders import ChangeSequenceHeaders def help(): print print "usage: ",sys.argv[0],"[ options ]" print "options:" print " -h: this help" print " -i: name of the input file (aligned fasta)" print " -c: clean" print " -v: verbose (default=0)" print def main(): inFileName = "" clean = False verbose = 0 try: opts,args=getopt.getopt(sys.argv[1:],"hi:cv:") except getopt.GetoptError, err: print str(err) help(); sys.exit(1) for o,a in opts: if o == "-h": help(); sys.exit(0) elif o == "-i": inFileName = a elif o == "-c": clean = True elif o == "-v": verbose = int(a) if inFileName == "": print "ERROR: missing compulsory options" help(); sys.exit(1) if verbose > 0: print "START %s" % (sys.argv[0].split("/")[-1]) sys.stdout.flush() csh = ChangeSequenceHeaders() csh.setInputFile( inFileName ) csh.setFormat( "fasta" ) csh.setStep( 1 ) csh.setPrefix( "seq" ) csh.setLinkFile( inFileName+".shortHlink" ) csh.setOutputFile( inFileName+".shortH" ) csh.run() pL = programLauncher( inFileName+".shortH" ) pL.launchSreformat( outFormat="phylip", outFileName=inFileName+".shortH.phylip", verbose=verbose ) pL.reset( inFileName+".shortH.phylip" ) pL.launchPhyML( verbose=verbose ) csh.setInputFile( inFileName+".shortH.phylip_phyml_tree.txt" ) csh.setFormat( "newick" ) csh.setStep( 2 ) csh.setLinkFile( inFileName+".shortHlink" ) csh.setOutputFile( inFileName+"_phyml.newick" ) csh.run() if clean: for f in [ inFileName+".shortH", inFileName+".shortHlink", inFileName+".shortH.phylip", inFileName+".shortH.phylip_phyml_lk.txt", inFileName+".shortH.phylip_phyml_tree.txt" ]: os.remove( f ) os.system( "mv %s.shortH.phylip_phyml_stat.txt %s_phyml.txt" % ( inFileName, inFileName ) ) if verbose > 0: print "END %s" % (sys.argv[0].split("/")[-1]) sys.stdout.flush() return 0 if __name__ == "__main__": main()