-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathphotbinner.py
110 lines (105 loc) · 5.23 KB
/
photbinner.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
from __future__ import print_function
import numpy as np
import matplotlib.pyplot as plt
'''
Meredith Rawls, 2015
Takes a file created by photplotter.py and bins it appropriately.
'''
# SPECIFY THESE ITEMS CORRECTLY
#period = 33.65685; BJD0 = 54960.8989; target = '03955867'
#period = 235.29852; BJD0 = 55190.5400; target = '09970396'
#period = 20.6864; BJD0 = 54966.891; target = '09291629'
period = 197.9182; BJD0 = 55162.6140; target = '05786154'
#period = 19.38446; BJD0 = 54970.2139; target = '08702921'
#period = 120.3903; BJD0 = 54957.682; target = '10001167'
dir = '../../1m_observations/KIC'+target+'/'
infile = 'BVRI_diffmag_LC2.txt'
outfile = 'BVRI_diffmag_binned_LC2.txt'
time_threshold = 0.01 # time in days by which to bin observations
filtlist = ['B', 'V', 'R', 'I']
phaseoffset = False # option to offset phases by 0.5 IN PLOT ONLY
# SPECIFY THESE ITEMS CORRECTLY
def phasecalc(time, period, zeropoint):
'''
Calculates orbital phase of a single observation given period and zeropoint
'''
fracP = (time - zeropoint) / period
phase = fracP % 1
return phase
times, phases, filters, mags, merrs, compmags, cerrs, diffmags, derrs = \
np.loadtxt(dir+infile, comments='#', unpack=True, dtype={ \
'names': ('times', 'phases', 'filters', 'mags', 'merrs', 'compmags', 'cerrs', \
'diffmags', 'derrs'), 'formats': (np.float64, np.float64, '|S2', np.float64, \
np.float64, np.float64, np.float64, np.float64, np.float64)})
allfilt = []; alltime = []; allphase = []; alldiff = []; allderr = []
for filt in filtlist:
# initialize chunk lists
chunk = 0
timechunk = [[]]; phasechunk = [[]]
magchunk = [[]]; merrchunk = [[]]
compmagchunk = [[]]; cerrchunk = [[]]
diffmagchunk = [[]]; derrchunk = [[]]
# load observations for one filter
for idx, (time, phase, filter, mag, merr, compmag, cerr, diffmag, derr) in enumerate( \
zip(times, phases, filters, mags, merrs, compmags, cerrs, diffmags, derrs)):
if filter == filt:
# calculate time elapsed since previous image
if idx > 0:
dt = (time - times[idx-1])
else:
dt = 0
# start a new chunk if dt > some threshold
if dt >= time_threshold:
chunk += 1
timechunk.append([]); phasechunk.append([])
magchunk.append([]); merrchunk.append([])
compmagchunk.append([]); cerrchunk.append([])
diffmagchunk.append([]); derrchunk.append([])
# save observations by chunk
timechunk[chunk].append(time); phasechunk[chunk].append(phase)
magchunk[chunk].append(mag); merrchunk[chunk].append(merr)
compmagchunk[chunk].append(compmag); cerrchunk[chunk].append(cerr)
diffmagchunk[chunk].append(diffmag); derrchunk[chunk].append(derr)
nchunks = len(timechunk)
newtime = []; newphase = []
newmag = []; newmerr = []
newcomp = []; newcerr = []
newdiff = []; newderr = []
for cdx, time in enumerate(timechunk):
# cdx is chunk index
# calculate rms for magnitude data points, one per chunk
newtime.append( (timechunk[cdx][0] + timechunk[cdx][-1]) / 2. ) # FAILS IF DATA NOT TIME SORTED
newphase.append( phasecalc((timechunk[cdx][0] + timechunk[cdx][-1]) / 2., period, BJD0) )
newmag.append( np.sqrt(np.nanmean(np.power(magchunk[cdx],2))) ) # RMS mag for one chunk
newmerr.append( np.sqrt(np.nanmean(np.power(merrchunk[cdx],2))) )
newcomp.append( np.sqrt(np.nanmean(np.power(compmagchunk[cdx],2))) ) # RMS compmag for one chunk
newcerr.append( np.sqrt(np.nanmean(np.power(cerrchunk[cdx],2))) )
newdiff.append( np.sqrt(np.nanmean(np.power(diffmagchunk[cdx],2))) ) # RMS diffmag for one chunk
newderr.append( np.sqrt(np.nanmean(np.power(derrchunk[cdx],2))) )
allfilt.append(filt)
alltime.append(newtime[cdx])
allphase.append(newphase[cdx])
alldiff.append(newdiff[cdx])
allderr.append(newderr[cdx])
# plt.errorbar(newphase, newdiff, yerr=newderr, ls='None', marker='o')
# plt.show()
# Write results to file and make a plot
with open(dir+outfile, 'w') as out:
print('# filter, UTCtime, phase, differential mag, error', file=out)
for filter, time, phase, diff, derr in zip(allfilt, alltime, allphase, alldiff, allderr):
print(filter, time, phase, diff, derr, file=out)
if phaseoffset == True: # offset phases so primary eclipse appears at 0.5 instead of 0 (1)
if phase < 0.5: phase = phase+0.5
else: phase = phase-0.5
#allphase = [p+0.5 if p < 0.5 else p-0.5 for p in allphase]
if filter == 'B':
plt.errorbar(phase, diff, yerr=derr, ls='None', marker='o', color='b', label='B')
elif filter == 'V':
plt.errorbar(phase, diff, yerr=derr, ls='None', marker='o', color='g', label='V')
elif filter == 'R':
plt.errorbar(phase, diff, yerr=derr, ls='None', marker='o', color='r', label='R')
elif filter == 'I':
plt.errorbar(phase, diff, yerr=derr, ls='None', marker='o', color='k', label='I')
plt.xlabel('Orbital Phase')
plt.ylabel('BACKWARDS MAGNITUDE IS BACKWARDS')
plt.show()