-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemp_read_2.py
79 lines (75 loc) · 3.36 KB
/
temp_read_2.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
def read_tod_files(indir, prefix, numpixels, numfiles=50,quiet=True):
# Read in the data
# jd = np.empty(0)
# az = np.empty(0)
# el = np.empty(0)
# data = np.empty((0,0,0))
jd = []
az = []
el = []
data = []
for i in range(0,numfiles):
print(indir+'/'+prefix+'-'+format(i, '04d')+'.tod2')
try:
inputfits = fits.open(indir+'/'+prefix+'-'+format(i, '04d')+'.tod2')
except:
break
# cols = inputfits[1].columns
# col_names = cols.names
ndata = len(inputfits[1].data.field(0)[0][:])
nsamples = ndata//4
if nsamples*4 != ndata:
print('Oddity in ' + prefix+'-'+format(i, '04d')+'.tod2' + ' - ndata = ' + str(ndata) + ' is not dividable by 4, changing it to ' + str(nsamples*4))
if i == 0:
jd = inputfits[1].data.field(0)[0][:nsamples*4].tolist()
az = inputfits[1].data.field(1)[0][:nsamples*4].tolist()
el = inputfits[1].data.field(2)[0][:nsamples*4].tolist()
else:
jd.append(inputfits[1].data.field(0)[0][:nsamples*4].tolist())
az.append(inputfits[1].data.field(1)[0][:nsamples*4].tolist())
el.append(inputfits[1].data.field(2)[0][:nsamples*4].tolist())
# jd = [*jd, *inputfits[1].data.field(0)[0][:nsamples*4]]
# az = [*az, *inputfits[1].data.field(1)[0][:nsamples*4]]
# el = [*el, *inputfits[1].data.field(2)[0][:nsamples*4]]
# jd = np.concatenate((jd, inputfits[1].data.field(0)[0][:nsamples*4]))
# az = np.concatenate((az,inputfits[1].data.field(1)[0][:nsamples*4]))
# el = np.concatenate((el,inputfits[1].data.field(2)[0][:nsamples*4]))
rawdata = inputfits[1].data.field(3)[0][:nsamples*4*4*31]
if np.shape(rawdata)[0] == ndata:
rawdata = rawdata.reshape(ndata*124,order='C')
rawdata = rawdata[:nsamples*4*4*31]
if i == 0:
data = rawdata.tolist()
else:
data.append(rawdata.tolist())
if not quiet:
print(' Start time: ' + str(np.min(inputfits[1].data.field(0)[0][:nsamples*4])))
print(' End time: ' + str(np.max(inputfits[1].data.field(0)[0][:nsamples*4])))
print(' Duration: ' + str((np.max(inputfits[1].data.field(0)[0][:nsamples*4])-np.min(inputfits[1].data.field(0)[0][:nsamples*4]))*24*60*60) + ' seconds')
print(' There are ' + str(ndata) + " datapoints")
print(' Az range: ' + str(np.min(inputfits[1].data.field(1)[0][:nsamples*4])) + ' to ' + str(np.max(inputfits[1].data.field(1)[0][:nsamples*4])))
print(' El range: ' + str(np.min(inputfits[1].data.field(2)[0][:nsamples*4])) + ' to ' + str(np.max(inputfits[1].data.field(2)[0][:nsamples*4])))
print(' Raw data array is ' + str(np.shape(rawdata)))
jd = np.asarray(jd)
az = np.asarray(az)
el = np.asarray(el)
data = np.asarray(data)
# Reshape the data
ndata = len(jd)//4
az = az.reshape(4,ndata,order='F')
el = el.reshape(4,ndata,order='F')
jd = jd.reshape(4,ndata,order='F')
print(prefix)
print(' Start time: ' + str(np.min(jd)))
print(' End time: ' + str(np.max(jd)))
print(' Duration: ' + str((np.max(jd)-np.min(jd))*24*60*60) + ' seconds')
print(' There are ' + str(ndata) + " datapoints")
print(' Az range: ' + str(np.min(az)) + ' to ' + str(np.max(az)))
print(' El range: ' + str(np.min(el)) + ' to ' + str(np.max(el)))
print(' JD shape: ' + str(np.shape(jd)))
print(' Az shape: ' + str(np.shape(az)))
print(' Data shape: ' + str(np.shape(data)))
print(' New data length: ' + str(len(data)/(numpixels*4*4)))
data = data.reshape(4, numpixels, 4, ndata, order='F')
print(' New data shape: ' + str(np.shape(data)))
return az, el, jd, data