!git checkout master
!git branch
import os
import sys
sys.path.append("/home/jovyan/work/shared/nanograv_timing_2017/util/")
from nanograv_utils import *
sys.path.append("/home/jovyan/work/shared/")
from pypulse.tim import Tim
%matplotlib inline
# Load the notebook utilities
nanoutils = NANOGravUtils()
tempoutils = TempoUtils()
pintutils = PINTUtils()
enterpriseutils = EnterpriseUtils()
FLAGS = "-G" # Use "-G" for Generalized least squares fit
NITER = 50000 #10000 # How many iterations to run PAL2 for
EXCISEPARFILE = "J1923+2515.excise.par"
EXCISETIMFILE = "J1923+2515.excise.tim"
PARFILE = "J1923+2515.working.par"
TIMFILE = "J1923+2515.working.tim"
# Copy initial par/tim files into working files
call("cp J1923+2515.dmx.par %s"%EXCISEPARFILE)
call("cp J1923+2515.dmx.tim %s"%EXCISETIMFILE)
tempoutils.tempo(EXCISEPARFILE,EXCISETIMFILE,c=True)
tempoutils.plot_resids()
# TOA excision from outlier analysis
outlierfilenames = np.loadtxt("outlier/J1923+2515.dmx-outliers.txt",unpack=True,usecols=(0,),dtype=np.str,ndmin=1)
outlierchans = np.loadtxt("outlier/J1923+2515.dmx-outliers.txt",unpack=True,usecols=(6,),dtype=np.int,ndmin=1)
outliersubints = np.loadtxt("outlier/J1923+2515.dmx-outliers.txt",unpack=True,usecols=(8,),dtype=np.int,ndmin=1)
outlierpouts = np.loadtxt("outlier/J1923+2515.dmx-outliers.txt",unpack=True,usecols=(12,),dtype=np.float,ndmin=1)
tim = Tim(EXCISETIMFILE)
for toa in tim.toas:
filename,chan,subint = toa.getFilename(),int(toa.get('chan')),int(toa.get('subint'))
for i,outlierfilename in enumerate(outlierfilenames):
if outlierfilename == filename and outlierchans[i] == chan and outliersubints[i] == subint and outlierpouts[i] >= 0.10:
toa.comment(cut="outlier10")
break
tim.save(EXCISETIMFILE)
nanoutils.plot_multipage_pdf("outlier/J1923+2515.dmx-residuals.pdf")#,height=400)
# Ensure correct DMX binning, create PARFILE and TIMFILE
! ../../util/./dmx_fixer.py J1923+2515.excise.par J1923+2515.excise.tim excise
# Center the EPOCHs
! $TEMPO/util/center_epoch/center_epoch.py J1923+2515.excise.par J1923+2515.excise.tim J1923+2515.excise.par
# Noise parameter addition from outlier analysis
with open("outlier/J1923+2515.dmx-noise.txt",'r') as FILE:
outlierlines = FILE.readlines()
with open(EXCISEPARFILE,'r') as FILE:
lines = FILE.readlines()
output = ""
for line in lines:
if "EFAC" in line or "EQUAD" in line or "ECORR" in line or "RNAMP" in line or "RNIDX" in line: #remove these parameters
continue
output += line
rnoutput = ""
for line in outlierlines: #add these parameters
if "efac" in line:
output += line.replace("efac-","T2EFAC -f ")
elif "equad" in line:
value = 10**(float(line.split()[-1].strip()))
string = line.replace("equad-","T2EQUAD -f ")
output += "%s %0.5f\n"%(" ".join(string.split()[:-1]),value)
elif "jitter" in line:
value = 10**(float(line.split()[-1]))
string = line.replace("jitter-","ECORR -f ")
output += "%s %0.5f\n"%(" ".join(string.split()[:-1]),value)
elif "RN-Amplitude" in line:
value = float(line.split()[1])
RNAMP = tempoutils.convert_to_RNAMP(value)
RNAMP = str("%0.4e"%RNAMP).replace('e','D')
rnoutput += "RNAMP %s\n"%RNAMP
elif "RN-spectral-index" in line:
gamma = float(line.split()[1])
rnoutput += "RNIDX %0.4f\n"%(-gamma)
if not (gamma < 1.0):
output += rnoutput
with open(EXCISEPARFILE,'w') as FILE:
FILE.write(output)
# Additional call to cull and plot
tempoutils.cull("-r55u",EXCISETIMFILE,EXCISETIMFILE+".cull")
call("mv %s.cull %s"%(EXCISETIMFILE,EXCISETIMFILE))
tempoutils.tempo(EXCISEPARFILE,EXCISETIMFILE,plot=True)
# Copy excise files to working files
call("cp %s %s"%(EXCISEPARFILE,PARFILE))
call("cp %s %s"%(EXCISETIMFILE,TIMFILE))
! ../../util/./finalize_timing.py -G J1923+2515.working.par J1923+2515.working.tim
nanoutils.plot_multipage_pdf("J1923+2515.summary.pdf")
NOISEDIR = "noisemodel/"
CHAINSDIR = "noisemodel/chains/J1923+2515/"
call("mkdir %s"%NOISEDIR)
call("mkdir noise_output")
#call("mkdir %s"%CHAINSDIR)
call("cp %s %s%s"%(TIMFILE,NOISEDIR,TIMFILE))
call("cp %s %s%s"%(PARFILE,NOISEDIR,PARFILE))
with open("%s%s"%(NOISEDIR,PARFILE),'r') as FILE:
lines = FILE.readlines()
output = ""
for line in lines:
write = True
for param in ["T2EFAC","T2EQUAD","ECORR","RNAMP","RNIDX"]:
if param in line:
write = False
continue
if write:
output += line
with open("%s%s"%(NOISEDIR,PARFILE),'w') as FILE:
FILE.write(output)
enterpriseutils.setup_model(NOISEDIR+PARFILE,NOISEDIR+TIMFILE)
enterpriseutils.setup_sampler(CHAINSDIR)
enterpriseutils.run_sampler(N=NITER)
enterpriseutils.process_noise('%s/chain_1.txt'%CHAINSDIR,"noise_output/t1_noise.txt") #need to add in T2 noise!
enterpriseutils.plot_corner('%s/chain_1.txt'%CHAINSDIR)
# No need to comment out low-spectral-index red noise as this is taken care of in EnterpriseUtils.process_noise() now
with open("noise_output/t1_noise.txt",'r') as FILE:
noiselines = FILE.readlines()
with open("%s%s"%(NOISEDIR,PARFILE),'r') as FILE: #read in the noisemodel version
lines = FILE.readlines()
output = ""
for line in lines:
if "JUMP" in line:
for noiseline in noiselines:
output += noiseline
output += line
with open("%s"%PARFILE,'w') as FILE: #write out to the main version
FILE.write(output)
tempoutils.tempo(PARFILE,TIMFILE,G=True,c=True)
call("mv J1923+2515.par %s"%PARFILE)
! ../../util/./finalize_timing.py -G J1923+2515.working.par J1923+2515.working.tim
nanoutils.plot_multipage_pdf("J1923+2515.summary.pdf")
!git add J1923+2515.working.par J1923+2515.working.tim process.ipynb
!git commit -m "J1923+2515 run" J1923+2515.working.par J1923+2515.working.tim process.ipynb
!git pull
!git push