This repository has been archived by the owner on Aug 31, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtomo_reconstruct.py
executable file
·113 lines (96 loc) · 4.01 KB
/
tomo_reconstruct.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#!/usr/bin/env python3
import logging
import argparse
import pathlib
import sys
#import tracemalloc
from workflow.run_tomo import Tomo
#from memory_profiler import profile
#@profile
def __main__():
# Parse command line arguments
parser = argparse.ArgumentParser(
description='Perform a tomography reconstruction')
parser.add_argument('-i', '--input_file',
required=True,
type=pathlib.Path,
help='''Full or relative path to the input file (in Nexus format).''')
parser.add_argument('-c', '--center_file',
required=True,
type=pathlib.Path,
help='''Full or relative path to the center info file (in yaml format).''')
parser.add_argument('-o', '--output_file',
required=False,
type=pathlib.Path,
help='''Full or relative path to the output file (in Nexus format).''')
parser.add_argument('--galaxy_flag',
action='store_true',
help='''Use this flag to run the scripts as a galaxy tool.''')
parser.add_argument('-l', '--log',
# type=argparse.FileType('w'),
default=sys.stdout,
help='Logging stream or filename')
parser.add_argument('--log_level',
choices=logging._nameToLevel.keys(),
default='INFO',
help='''Specify a preferred logging level.''')
parser.add_argument('--x_bounds',
required=False,
nargs=2,
type=int,
help='''Boundaries of reconstructed images in x-direction.''')
parser.add_argument('--y_bounds',
required=False,
nargs=2,
type=int,
help='''Boundaries of reconstructed images in y-direction.''')
args = parser.parse_args()
# Set log configuration
# When logging to file, the stdout log level defaults to WARNING
logging_format = '%(asctime)s : %(levelname)s - %(module)s : %(funcName)s - %(message)s'
level = logging.getLevelName(args.log_level)
if args.log is sys.stdout:
logging.basicConfig(format=logging_format, level=level, force=True,
handlers=[logging.StreamHandler()])
else:
if isinstance(args.log, str):
logging.basicConfig(filename=f'{args.log}', filemode='w',
format=logging_format, level=level, force=True)
elif isinstance(args.log, io.TextIOWrapper):
logging.basicConfig(filemode='w', format=logging_format, level=level,
stream=args.log, force=True)
else:
raise(ValueError(f'Invalid argument --log: {args.log}'))
stream_handler = logging.StreamHandler()
logging.getLogger().addHandler(stream_handler)
stream_handler.setLevel(logging.WARNING)
stream_handler.setFormatter(logging.Formatter(logging_format))
# Starting memory monitoring
# tracemalloc.start()
# Log command line arguments
logging.info(f'input_file = {args.input_file}')
logging.info(f'center_file = {args.center_file}')
logging.info(f'output_file = {args.output_file}')
logging.info(f'galaxy_flag = {args.galaxy_flag}')
logging.debug(f'log = {args.log}')
logging.debug(f'is log stdout? {args.log is sys.stdout}')
logging.debug(f'log_level = {args.log_level}')
logging.info(f'x_bounds = {args.x_bounds}')
logging.info(f'y_bounds = {args.y_bounds}')
# Instantiate Tomo object
tomo = Tomo(galaxy_flag=args.galaxy_flag)
# Read input file
data = tomo.read(args.input_file)
# Read center data
center_data = tomo.read(args.center_file)
# Find the calibrated center axis info
data = tomo.reconstruct_data(data, center_data, x_bounds=args.x_bounds, y_bounds=args.y_bounds)
# Write output file
data = tomo.write(data, args.output_file)
# Displaying memory usage
# logging.info(f'Memory usage: {tracemalloc.get_traced_memory()}')
# stopping memory monitoring
# tracemalloc.stop()
logging.info('Completed tomography reconstruction')
if __name__ == "__main__":
__main__()