-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathredshifts.py
121 lines (109 loc) · 2.89 KB
/
redshifts.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
114
115
116
117
118
119
120
121
from csv import reader, writer
from shutil import move
import fruitbat
import math
# Load data
# Initiate empty parameter lists
l = []
b = []
dm = []
frbs = []
# Read FRBSTATS CSV catalogue
with open('catalogue.csv', 'r') as read_obj:
csv_reader = reader(read_obj)
header = next(csv_reader)
# Skip header
if header != None:
for row in csv_reader:
l.append(row[6])
b.append(row[7])
dm.append(row[9])
frbs.append(row[0])
# Pre-process data (pick out incompatible rows)
idx_mask = set()
for idx, val in enumerate(l):
try:
l[idx] = float(val)
except ValueError:
idx_mask.add(idx)
for idx, val in enumerate(b):
try:
b[idx] = float(val)
except ValueError:
idx_mask.add(idx)
for idx, val in enumerate(dm):
try:
dm[idx] = float(val)
except ValueError:
idx_mask.add(idx)
# Dump rows with missing data
for idx in sorted(idx_mask, reverse=True):
del l[idx]
del b[idx]
del dm[idx]
del frbs[idx]
# Delete last row (redshift) from csv
with open('catalogue.csv', 'r') as read_obj:
with open('catalogue_tmp.csv', 'w') as write_obj:
csv_writer = writer(write_obj)
for row in reader(read_obj):
csv_writer.writerow(row[:-1])
# Rename and replace (prepare) CSV catalogue
move('catalogue_tmp.csv', 'catalogue.csv')
redshifts = []
idx = 0
for dm_value in dm:
print('-----------')
# Create a Frb Object with DM and Galactic Coordinates
frb = fruitbat.Frb(dm_value, gl=str(l[idx]), gb=str(b[idx]))
# Calculate the DM contribution from the Milky Way
frb.calc_dm_galaxy()
#print(frb)
#print(dm_value)
#print(str(l[idx]), str(b[idx]))
#print(redshift)
try:
# Calculate the Redshift of the FRB
redshift = float(frb.calc_redshift())
# Round to 4 decimal places
redshift = round(redshift, 4)
float(str(redshift))
print(str(frbs[idx]) +':'+ str(redshift))
if math.isnan(redshift):
print('is nan entered. Redshift is:')
print(str(frbs[idx]) +':'+ str(redshift))
redshifts.append('-')
else:
redshifts.append(str(redshift))
except Exception as e:
print(e)
redshifts.append('-')
idx += 1
#print(redshifts)
"""
# Open the input_file in read mode and output_file in write mode
with open('catalogue.csv', 'r') as read_obj, open('catalogue_tmp.csv', 'w', newline='') as write_obj:
# Create a reader object from the input file object
csv_reader = reader(read_obj)
header = next(csv_reader)
header.append("redshifts")
#print(header,type(header))
# Create a writer object from the output file object
csv_writer = writer(write_obj)
for row in csv_reader:
row.append(header)
csv_writer.writerow(row)
break
# Skip header
if header != None:
# Read each row of the input csv file as list
idx = 0
for row in csv_reader:
# Append the default text in the row / list
row.append(redshifts[idx])
# Add the updated row / list to the output file
csv_writer.writerow(row)
idx += 1
# Rename and replace (finalize) CSV catalogue
move('catalogue_tmp.csv', 'catalogue.csv')
"""