-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuvotbadpix.py
60 lines (43 loc) · 2.17 KB
/
uvotbadpix.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
#uvotbadpix.py: Script to create quality maps.
#Created on 09-12-2015, updated (to Python 3.6) on 26-10-2018.
#Updated on 10-01-2019 (based on feedback Bob).
#Marjorie Decleir
#Import the necessary packages.
import os
import subprocess
import configloader
#Load the configuration file.
config = configloader.load_config()
#Specify the galaxy and the path to the working directory.
galaxy = config['galaxy']
path = config['path'] + galaxy + "/working_dir/"
#Print user information.
print("Creating quality maps...")
#Initialize the counter and count the total number of sky images. Initialize the error flag.
i = 0
num = sum(1 for filename in sorted(os.listdir(path)) if filename.endswith("sk.img") and "uat" in filename)
error = False
#For all files in the working directory:
for filename in sorted(os.listdir(path)):
#If the file is not a sky image (created with the uat attitude file), skip this file and continue with the next file.
if not filename.endswith("sk.img") or not "uat" in filename: continue
#Specify the input file, the output file and the terminal output file.
infile = filename
outfile = "quality_" + filename.replace("sk","badpix")
terminal_output_file = path + "output_uvotbadpix_" + filename.replace('.img','.txt')
#Open the terminal output file and run uvotbadpix with the specified parameters:
with open(terminal_output_file,"w") as terminal:
subprocess.call("uvotbadpix infile=" + infile + " badpixlist=CALDB outfile=" + outfile, cwd=path, shell=True, stdout=terminal)
#Check if the badpixel file was succesfully created.
file = open(terminal_output_file,"r")
text = file.read()
#If the word "error" is encountered or if the words "created output image" are not encountered, print an error message.
if "error" in text or not "created output image" in text:
print("An error has occured for image " + filename)
error = True
#Print user information.
i += 1
print("Quality map created for all (other) frames of " + filename + " (" + str(i) + "/" + str(num) + ")")
#Print user information.
if error == False:
print("Quality maps were successfully created for all sky images.")