Coverage for lst_auto_rta/merge_DL3_ACADA.py: 0%
95 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-26 14:48 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-26 14:48 +0000
1#!/usr/bin/env python
2# S. Caroff
4"""
5Script to merge DL3 and Analyse them
7Usage:
8$> python merge_DL3.py
9--input-filter "dl3_LST-1.Run04190.*.fits"
10--input-directory "./DL3/"
11--output-dir "./DL3/"
12--run_id 9864
13"""
15import argparse
16import glob
17import os
19# import matplotlib.colors as mcolors
20import warnings
21from pathlib import Path
23import astropy.units as u
24import matplotlib.pyplot as plt
25import numpy as np
26from astropy.io import fits
27from astropy.table import Column, QTable, Table, vstack
29# from SourceAnalyse import event
30from gammapy.data import DataStore, EventList
32warnings.filterwarnings("ignore")
33warnings.simplefilter("ignore")
34# import toml
35import glob
36import time
38# from PIL import Image
41def main():
42 parser = argparse.ArgumentParser(
43 description="Automatic Script for the DL3 check", formatter_class=argparse.ArgumentDefaultsHelpFormatter
44 )
45 parser.add_argument("-d", "--directory", default="/fefs/onsite/pipeline/rta/data/", help="Directory for data")
46 parser.add_argument("-da", "--date", default="20230705", help="Date of the run to check")
47 parser.add_argument("-r", "--run-id", default="13600", help="run id to check")
48 parser.add_argument("-add", "--add-string", default="reco/", help="add a string to the path")
49 parser.add_argument("-rf", "--run-fake", default="", help="local run id ")
50 args = parser.parse_args()
51 config = vars(args)
53 mypath = config["directory"] + config["date"] + "/" + config["run_id"] + "/" + config["add_string"] + "/dl3/"
54 mypath_rundir = config["directory"] + config["date"] + "/" + config["run_id"] + "/" + config["add_string"]
56 file_filter = "dl3_v06_*.fits" # "dl3_LST-1.Run04190.*.fits"
57 print(mypath + file_filter)
58 filelist = glob.glob(mypath + file_filter)
59 print(filelist)
61 hdu1 = fits.open(filelist[0])
62 for file in filelist[:]:
63 hdu2 = fits.open(file)
64 nev_hdu1 = len(hdu1["EVENTS"].data)
65 nev_hdu2 = len(hdu2["EVENTS"].data)
66 if (hdu1["EVENTS"].header["RA_PNT"] - hdu2["EVENTS"].header["RA_PNT"]) ** 2 < 2**2:
67 print(hdu1["EVENTS"].header["RA_PNT"], " ", hdu2["EVENTS"].header["RA_PNT"])
68 print(file)
69 hdu1["EVENTS"].header["RA_PNT"] = (
70 hdu1["EVENTS"].header["RA_PNT"] * nev_hdu1 + hdu2["EVENTS"].header["RA_PNT"] * nev_hdu2
71 ) / (nev_hdu1 + nev_hdu2)
72 hdu1["EVENTS"].header["DEC_PNT"] = (
73 hdu1["EVENTS"].header["DEC_PNT"] * nev_hdu1 + hdu2["EVENTS"].header["DEC_PNT"] * nev_hdu2
74 ) / (nev_hdu1 + nev_hdu2)
75 hdu1["EVENTS"].header["ALT_PNT"] = (
76 hdu1["EVENTS"].header["ALT_PNT"] * nev_hdu1 + hdu2["EVENTS"].header["ALT_PNT"] * nev_hdu2
77 ) / (nev_hdu1 + nev_hdu2)
78 hdu1["EVENTS"].header["AZ_PNT"] = (
79 hdu1["EVENTS"].header["AZ_PNT"] * nev_hdu1 + hdu2["EVENTS"].header["AZ_PNT"] * nev_hdu2
80 ) / (nev_hdu1 + nev_hdu2)
81 hdu1["EVENTS"].header["DEADC"] = (
82 hdu1["EVENTS"].header["DEADC"] * nev_hdu1 + hdu2["EVENTS"].header["DEADC"] * nev_hdu2
83 ) / (nev_hdu1 + nev_hdu2)
84 if not (hdu1["EVENTS"].header["OBS_ID"] == hdu2["EVENTS"].header["OBS_ID"]):
85 print("BEWARE ! You are merging DL3 event with different OBS_ID... You should not do that...")
86 # print(len(hdu1['EVENTS'].data))
87 hdu1["EVENTS"].data = np.append(hdu1["EVENTS"].data, hdu2["EVENTS"].data)
89 # print(len(hdu1['EVENTS'].data))
90 hdu1["EVENTS"].data = hdu1["EVENTS"].data[np.argsort(hdu1["EVENTS"].data["TIME"])]
92 hdu1["EVENTS"].data = hdu1["EVENTS"].data[
93 (hdu1["EVENTS"].data["TIME"] - hdu1["EVENTS"].data["TIME"][0]) < 8 * 3600
94 ]
95 # hdu1['EVENTS'].header['RA_PNT'] = np.mean(hdu1['EVENTS'].data['RA'])
96 # hdu1['EVENTS'].header['DEC_PNT'] = np.mean(hdu1['EVENTS'].data['DEC'])
97 # hdu1['EVENTS'].data['TIME'] = hdu1['EVENTS'].data['TIME']
98 # hdu1['EVENTS'].data['RA'] = hdu1['EVENTS'].data['RA']
99 # hdu1['EVENTS'].data['DEC'] = hdu1['EVENTS'].data['DEC']
100 # hdu1['EVENTS'].data['ENERGY'] = hdu1['EVENTS'].data['ENERGY']
101 # hdu1['EVENTS'].data[:][] = hdu1['EVENTS'].data[:][1]*u.s
102 hdu1["EVENTS"].header["OBS_ID"] = config["run_fake"]
103 hdu1["EVENTS"].header["N_TELS"] = 1
104 hdu1["EVENTS"].header["TELLIST"] = "LST-1"
105 hdu1["EVENTS"].header["TSTART"] = hdu1["EVENTS"].data["TIME"][0]
106 hdu1["EVENTS"].header["TSTOP"] = hdu1["EVENTS"].data["TIME"][-1]
107 hdu1["EVENTS"].header["ONTIME"] = hdu1["EVENTS"].data["TIME"][-1] - hdu1["EVENTS"].data["TIME"][0]
108 hdu1["EVENTS"].header["LIVETIME"] = hdu1["EVENTS"].header["ONTIME"] * hdu1["EVENTS"].header["DEADC"]
109 hdu1["EVENTS"].header["INSTRUME"] = "LST"
110 hdu1["EVENTS"].header["DATE-OBS"] = 0
111 hdu1["EVENTS"].header["TIME-OBS"] = 0
112 hdu1["EVENTS"].header["DATE-END"] = 0
113 hdu1["EVENTS"].header["TIME-END"] = 0
114 hdu1["EVENTS"].header["TELAPSE"] = 0
115 hdu1["POINTING"].header["ALT_PNT"] = hdu1["EVENTS"].header["ALT_PNT"]
116 hdu1["POINTING"].header["AZ_PNT"] = hdu1["EVENTS"].header["AZ_PNT"]
117 hdu1["POINTING"].header["TIME"] = hdu1["EVENTS"].header["TSTART"]
118 prefix = (5 - len(str(hdu1["EVENTS"].header["OBS_ID"]))) * "0"
119 # print(args.output_fits_dir+'dl3_LST-1.Run'+prefix+str(hdu1['EVENTS'].header['OBS_ID'])+'.fits')
120 hdu1["EVENTS"].columns["TIME"].unit = "s"
121 hdu1["EVENTS"].columns["ENERGY"].unit = "TeV"
122 hdu1["EVENTS"].columns["RA"].unit = "deg"
123 hdu1["EVENTS"].columns["DEC"].unit = "deg"
125 hdu1["GTI"].data[0][0] = hdu1["EVENTS"].data[0][1]
126 hdu1["GTI"].data[0][1] = hdu1["EVENTS"].data[-1][1]
128 if not os.path.exists(mypath_rundir + "plots/"):
129 os.mkdir(mypath_rundir + "plots/")
131 hdu1.writeto(
132 mypath_rundir + "plots/dl3_LST-1.Run" + prefix + str(hdu1["EVENTS"].header["OBS_ID"]) + ".fits", overwrite=True
133 )
134 print("create directory ")
135 print(mypath_rundir + "plots/")
136 # if not os.path.exists(mypath_rundir+'plots/'):
137 # os.mkdir(mypath_rundir+'plots/')
139 files_and_directories = os.listdir(config["directory"] + config["date"] + "/")
140 for item in files_and_directories:
141 print(
142 "cp -f "
143 + config["directory"]
144 + config["date"]
145 + "/"
146 + item
147 + "/"
148 + config["add_string"]
149 + "/plots/dl3_LST* "
150 + mypath_rundir
151 + "plots/."
152 )
153 os.system(
154 "cp -f "
155 + config["directory"]
156 + config["date"]
157 + "/"
158 + item
159 + "/"
160 + config["add_string"]
161 + "/plots/dl3_LST* "
162 + mypath_rundir
163 + "plots/."
164 )
166 filelist_runs = glob.glob(
167 config["directory"] + config["date"] + "/" + config["run_id"] + "/" + config["add_string"] + "/plots/dl3_LST*"
168 )
169 print("runlist is : ")
170 runlist_to_analyse = []
171 for i in range(len(filelist_runs)):
172 print(filelist_runs[i][-10:-5])
173 hdutemp = fits.open(filelist_runs[i])
174 if (hdutemp["EVENTS"].header["RA_PNT"] - hdu1["EVENTS"].header["RA_PNT"]) ** 2 < 9 and (
175 hdutemp["EVENTS"].header["DEC_PNT"] - hdu1["EVENTS"].header["DEC_PNT"]
176 ) ** 2 < 9:
177 runlist_to_analyse.append(int(filelist_runs[i][-10:-5]))
179 print(
180 "lstchain_create_dl3_index_files --file-pattern='dl3_LST*' --input-dl3-dir='"
181 + config["directory"]
182 + config["date"]
183 + "/"
184 + config["run_id"]
185 + "/"
186 + config["add_string"]
187 + "/plots/' --overwrite "
188 )
189 os.system(
190 "lstchain_create_dl3_index_files --file-pattern='dl3_LST*' --input-dl3-dir='"
191 + config["directory"]
192 + config["date"]
193 + "/"
194 + config["run_id"]
195 + "/"
196 + config["add_string"]
197 + "/plots/' --overwrite"
198 )
199 print(hdu1["EVENTS"].header["RA_PNT"])
200 print(" final runlist for analysis is : ")
201 print(runlist_to_analyse)
204if __name__ == "__main__":
205 main()