Source code for simbad.command_line.simbad_lattice

#!/usr/bin/env python

__author__ = "Felix Simkovic & Adam Simpkin"
__date__ = "06 Mar 2017"
__version__ = "0.1"

import argparse
import os
import sys

from pyjob.misc import StopWatch

import simbad.command_line
import simbad.exit
import simbad.util.pyrvapi_results

logger = None

[docs]def lattice_argparse(): """Create the argparse options""" prep = argparse.ArgumentParser(add_help=False) prep.add_argument('-sg', dest="space_group", type=str, default=None, help='The space group to use') prep.add_argument('-uc', dest="unit_cell", type=str, default=None, help="The unit cell, format 'a,b,c,alpha,beta,gamma'") args, _ = prep.parse_known_args() p = argparse.ArgumentParser( parents=[prep], formatter_class=argparse.ArgumentDefaultsHelpFormatter) simbad.command_line._argparse_core_options(p) simbad.command_line._argparse_job_submission_options(p) simbad.command_line._argparse_lattice_options(p) simbad.command_line._argparse_mtz_options(p) simbad.command_line._argparse_mr_options(p) if args.space_group and args.unit_cell: # Add to the namespace as we're looking for it later p.add_argument('-mtz', dest="mtz", default=None, help=argparse.SUPPRESS) else: p.add_argument('mtz', help="The path to the input mtz file") return p
[docs]def main(): """Main function to run SIMBAD's lattice search""" args = lattice_argparse().parse_args() args.work_dir = simbad.command_line.get_work_dir( args.run_dir, work_dir=args.work_dir, ccp4_jobid=args.ccp4_jobid, ccp4i2_xml=args.ccp4i2_xml ) log_file = os.path.join(args.work_dir, 'simbad.log') debug_log_file = os.path.join(args.work_dir, 'debug.log') log_class = simbad.command_line.LogController() log_class.add_console(level=args.debug_lvl) log_class.add_logfile(log_file, level="info", format="%(message)s") log_class.add_logfile(debug_log_file, level="notset", format="%(asctime)s\t%(name)s [%(lineno)d]\t%(levelname)s\t%(message)s") global logger logger = log_class.get_logger() gui = simbad.util.pyrvapi_results.SimbadOutput( args.rvapi_document, args.webserver_uri, args.display_gui, log_file, args.work_dir, ccp4i2_xml=args.ccp4i2_xml, tab_prefix=args.tab_prefix ) simbad.command_line.print_header() logger.info("Running in directory: %s\n", args.work_dir) stopwatch = StopWatch() stopwatch.start() solution_found = simbad.command_line._simbad_lattice_search(args) if args.space_group and args.unit_cell: display_summary = False elif solution_found: logger.info( "Lucky you! SIMBAD worked its charm and found a lattice match for you.") display_summary = True else: logger.info("No results found - lattice search was unsuccessful") display_summary = True if args.output_pdb and args.output_mtz: run_dir = os.path.join(args.work_dir, 'latt') csv = os.path.join(run_dir, 'lattice_mr.csv') if os.path.exists(csv): result = simbad.util.result_by_score_from_csv(csv, 'final_r_free', ascending=True) simbad.util.output_files(run_dir, result, args.output_pdb, args.output_mtz) stopwatch.stop() logger.info("All processing completed in %d days, %d hours, %d minutes, and %d seconds", *stopwatch.time_pretty) gui.display_results(display_summary, args.results_to_display) if args.rvapi_document: gui.save_document() log_class.close()
if __name__ == "__main__": import logging logging.basicConfig(level=logging.NOTSET) try: main() except Exception: simbad.exit.exit_error(*sys.exc_info())