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
|
import sys
import copy
import time
import argparse
from Alignment.OfflineValidation.TkAlMap import TkAlMap
def parser():
parser = argparse.ArgumentParser(description = "Parse AllInOne config to TkAlMap. Only ment for condor jobs.", formatter_class=argparse.RawTextHelpFormatter)
parser.add_argument("config", metavar='config', type=str, action="store", help="Global AllInOneTool config (json/yaml format)")
return parser.parse_args()
def main():
print('*---------------------------------------*')
print('| GCP TkAlMap |')
print('*---------------------------------------*')
# Get arguments
args = parser()
# Get configuration
with open(args.config, 'r') as configFile:
if args.config.split('.')[-1] == 'json':
config = json.load(configFile)
elif args.config.split('.')[-1] == 'yaml':
config = yaml.load(configFile, Loader=yaml.Loader)
else:
raise Exception('Unknown config extension "{}". Please use json/yaml format!'.format(args.config.split('.')[-1]))
# Init variables
var_list = ['dr', 'dx', 'dy', 'dz', 'rdphi', 'dphi', 'dalpha', 'dbeta', 'dgamma', 'du', 'dv', 'dw', 'da', 'db', 'dg']
var_ranges = {}
for var in var_list:
var_ranges[var] = [None, None]
# Digest
al_ref = config['alignments']['ref']['title']
al_comp = config['alignments']['comp']['title']
in_file = config['input']
out_dir = config['output']
phase = 1
auto_tk = True
if 'detector_phase' in config['validation']['GCP']:
phase = int(config['validation']['GCP']['detector_phase'])
auto_tk = False
palette = 2
if 'map_palette' in config['validation']['GCP']: palette = int(config['validation']['GCP']['map_palette'])
save_png = False
if 'save_png' in config['validation']['GCP']: save_png = config['validation']['GCP']['save_png']
save_pdf = True
if 'save_pdf' in config['validation']['GCP']: save_pdf = config['validation']['GCP']['save_pdf']
print('Current setup:')
print(' - reference alingment : '+al_ref)
print(' - compared alingment : '+al_comp)
print(' - tracker version : phase '+str(phase))
print(' - auto detect tracker version : '+str(auto_tk))
print(' - color palette : '+str(palette))
print(' - input root file : '+in_file)
print(' - output directory : '+out_dir)
print(' - saving as png : '+str(save_png))
print(' - saving as pdf : '+str(save_pdf))
print('')
print('Active plots:')
print(' - plot 4 sigma capped values : '+str(do_4scap))
print(' - plot default range capped values : '+str(do_drange))
print(' - plot un-capped values : '+str(do_frange))
print(' - plot full detector : '+str(do_full))
print(' - plot pixel detector : '+str(do_pixel))
print(' - plot strips detector : '+str(do_strips))
print('')
print('Changed default ranges:')
for var in var_ranges:
if var_ranges[var][0] is None and var_ranges[var][1] is None: continue
prt_srt = ' - '+var+'\t: [ '
if var_ranges[var][0] is None: prt_srt += 'default'
else: prt_srt += str(var_ranges[var][0])
prt_srt += '\t, '
if var_ranges[var][1] is None: prt_srt += 'default'
else: prt_srt += str(var_ranges[var][1])
prt_srt += '\t]'
print(prt_srt)
print('Loading maps')
TkMap_full = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=False, GEO_file=geometry_file, tracker='full', palette=palette, check_tracker=auto_tk)
TkMap_pixel = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=False, GEO_file=geometry_file, tracker='pixel', palette=palette, check_tracker=auto_tk)
TkMap_strips = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=False, GEO_file=geometry_file, tracker='strips', palette=palette, check_tracker=auto_tk)
TkMap_cap_full = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=True, GEO_file=geometry_file, tracker='full', palette=palette, check_tracker=auto_tk)
TkMap_cap_pixel = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=True, GEO_file=geometry_file, tracker='pixel', palette=palette, check_tracker=auto_tk)
TkMap_cap_strips = TkAlMap('test', title, in_file, use_default_range=False, two_sigma_cap=True, GEO_file=geometry_file, tracker='strips', palette=palette, check_tracker=auto_tk)
TkMap_drange_full = TkAlMap('test', title, in_file, use_default_range=True, two_sigma_cap=False, GEO_file=geometry_file, tracker='full', palette=palette, check_tracker=auto_tk)
TkMap_drange_pixel = TkAlMap('test', title, in_file, use_default_range=True, two_sigma_cap=False, GEO_file=geometry_file, tracker='pixel', palette=palette, check_tracker=auto_tk)
TkMap_drange_strips = TkAlMap('test', title, in_file, use_default_range=True, two_sigma_cap=False, GEO_file=geometry_file, tracker='strips', palette=palette, check_tracker=auto_tk)
|