Mercurial > repos > rv43 > tomo
annotate tomo_reduce.py @ 69:fba792d5f83b draft
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
| author | rv43 | 
|---|---|
| date | Fri, 10 Mar 2023 16:02:04 +0000 | 
| parents | |
| children | 97c4e2cbbad9 | 
| rev | line source | 
|---|---|
| 69 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 1 #!/usr/bin/env python3 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 2 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 3 import logging | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 4 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 5 import argparse | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 6 import pathlib | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 7 import sys | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 8 #import tracemalloc | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 9 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 10 from workflow.run_tomo import Tomo | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 11 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 12 #from memory_profiler import profile | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 13 #@profile | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 14 def __main__(): | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 15 # Parse command line arguments | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 16 parser = argparse.ArgumentParser( | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 17 description='Reduce tomography data') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 18 parser.add_argument('-i', '--input_file', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 19 required=True, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 20 type=pathlib.Path, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 21 help='''Full or relative path to the input file (in yaml format).''') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 22 parser.add_argument('-o', '--output_file', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 23 required=False, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 24 type=pathlib.Path, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 25 help='''Full or relative path to the output file (in Nexus format).''') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 26 parser.add_argument('--galaxy_flag', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 27 action='store_true', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 28 help='''Use this flag to run the scripts as a galaxy tool.''') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 29 parser.add_argument('--img_x_bounds', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 30 required=False, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 31 nargs=2, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 32 type=int, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 33 help='Vertical data reduction image range') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 34 parser.add_argument('-l', '--log', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 35 # type=argparse.FileType('w'), | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 36 default=sys.stdout, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 37 help='Logging stream or filename') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 38 parser.add_argument('--log_level', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 39 choices=logging._nameToLevel.keys(), | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 40 default='INFO', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 41 help='''Specify a preferred logging level.''') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 42 args = parser.parse_args() | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 43 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 44 # Set log configuration | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 45 # When logging to file, the stdout log level defaults to WARNING | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 46 logging_format = '%(asctime)s : %(levelname)s - %(module)s : %(funcName)s - %(message)s' | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 47 level = logging.getLevelName(args.log_level) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 48 if args.log is sys.stdout: | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 49 logging.basicConfig(format=logging_format, level=level, force=True, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 50 handlers=[logging.StreamHandler()]) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 51 else: | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 52 if isinstance(args.log, str): | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 53 logging.basicConfig(filename=f'{args.log}', filemode='w', | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 54 format=logging_format, level=level, force=True) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 55 elif isinstance(args.log, io.TextIOWrapper): | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 56 logging.basicConfig(filemode='w', format=logging_format, level=level, | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 57 stream=args.log, force=True) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 58 else: | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 59 raise(ValueError(f'Invalid argument --log: {args.log}')) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 60 stream_handler = logging.StreamHandler() | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 61 logging.getLogger().addHandler(stream_handler) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 62 stream_handler.setLevel(logging.WARNING) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 63 stream_handler.setFormatter(logging.Formatter(logging_format)) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 64 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 65 # Start memory monitoring | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 66 # tracemalloc.start() | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 67 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 68 # Log command line arguments | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 69 logging.info(f'input_file = {args.input_file}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 70 logging.info(f'output_file = {args.output_file}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 71 logging.info(f'galaxy_flag = {args.galaxy_flag}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 72 logging.info(f'img_x_bounds = {args.img_x_bounds}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 73 logging.debug(f'log = {args.log}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 74 logging.debug(f'is log stdout? {args.log is sys.stdout}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 75 logging.debug(f'log_level = {args.log_level}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 76 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 77 # Instantiate Tomo object | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 78 tomo = Tomo(galaxy_flag=args.galaxy_flag) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 79 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 80 # Read input file | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 81 data = tomo.read(args.input_file) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 82 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 83 # Generate reduced tomography images | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 84 data = tomo.gen_reduced_data(data, img_x_bounds=args.img_x_bounds) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 85 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 86 # Write output file | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 87 data = tomo.write(data, args.output_file) | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 88 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 89 # Displaying memory usage | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 90 # logging.info(f'Memory usage: {tracemalloc.get_traced_memory()}') | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 91 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 92 # Stop memory monitoring | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 93 # tracemalloc.stop() | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 94 | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 95 if __name__ == "__main__": | 
| 
fba792d5f83b
planemo upload for repository https://github.com/rolfverberg/galaxytools commit ab9f412c362a4ab986d00e21d5185cfcf82485c1
 rv43 parents: diff
changeset | 96 __main__() | 
