-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathsample.py
214 lines (152 loc) · 7.63 KB
/
sample.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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
import numpy as np
from emcee import EnsembleSampler
from emcee.backends import HDFBackend
from schwimmbad import MPIPool
from Cosmology import *
import sys
#KMA 15 Nov 19: updated parameters in correspondence with current jupyter nb
#KMA 11 Jan 20: added option to use numerical or analytical formulae for z_d and r_d
#########################################################################
#Parameters for BAO and CMB
z_d = 1089
h = .6727
cLight=3E5
omega_baryon_preset = 0.02235/h**2
omega_gamma_preset = 2.469E-5/h**2
#Cosmological parameters
Omega_m_preset = 0.3166
#Omega_r_preset = 2.469E-5/h**2 # this is the photon density
Omega_c_preset = 0.6834
#Whether to use the numerical approximation for the comoving sound horizon, see arXiv:1411.1074:
rd_num = False
#Whether to use the numerical approximation for the redshift of last scattering and end of drag epoch,
#cf arXiv:astro-ph/9510117, or use z_d = z_star = 1089:
z_num = True
#########################################################################
#SN data
dataSN = np.loadtxt('data/jla_lcparams.txt', usecols=(2,4,6,8,10))
errSN = np.loadtxt('data/jla_lcparams.txt', usecols=(5,7,9))[np.argsort(dataSN.T[0])]
dataSN = dataSN[np.argsort(dataSN.T[0])]
#best fit values found in JLA analysis arXiv:1401.4064
a = 0.14
b = 3.14
MB = -19.04
delta_Mhost = -.06
SNdata = Supernova_data(dataSN, errSN, np.array([a,b,MB, 0]))
#Quasar data
dataQ = np.loadtxt('data/quasar_data_RL.txt', usecols=(0,1,2,3,4))
errQ = np.loadtxt('data/quasar_data_RL.txt', usecols=5)[np.argsort(dataQ.T[0])]
dataQ = dataQ[np.argsort(dataQ.T[0])]
#best fit values found in Risaliti & Lusso, Nature Astronomy, 2018
beta_prime, s = 7.4, 1.5
Qdata = Quasar_data(dataQ, errQ, np.array([beta_prime, s]))
# ## RC data
gamma00, kappa0 = 0.0093, 95
RCdata = RC_data([gamma00, kappa0])
# #BAO data
# # load all data points except for WiggleZ
# dataBAO = np.loadtxt('data/BOSS.txt', usecols=(1,3))
# # add WiggleZ
# dataBAO = np.append(dataBAO, np.loadtxt('data/WiggleZ.txt', usecols=(1,3)), axis=0)
# # the error for BAO is a cov mat, due to the addition of the WiggleZ data.
# errBAO = np.pad(np.diag(np.loadtxt('data/BOSS.txt', usecols=4)), [(0, 3), (0, 3)], mode='constant', constant_values=0)
# # now add the WiggleZ cov mat. Note that this is the sqrt, as all the other errors are given in this format, too.
# errBAO += np.pad(np.sqrt(np.loadtxt('data/WiggleZ_cov.txt', usecols=(3,4,5))), [(len(errBAO)-3, 0), (len(errBAO)-3, 0)], mode='constant', constant_values=0)
# typeBAO = np.genfromtxt('data/BOSS.txt',dtype=str, usecols=2)
# typeBAO = np.append(typeBAO, np.genfromtxt('data/WiggleZ.txt',dtype=str, usecols=2), axis=0)
# BAOdata = BAO_data(dataBAO, errBAO, np.array([omega_baryon_preset, omega_gamma_preset]), typeBAO)
#load BOSS data points
dataBAO = np.loadtxt('data/BOSS.txt', usecols=(1,3))
#load BOSS errors & measurement quantity
errBAO = np.diag(np.loadtxt('data/BOSS.txt', usecols=4))
typeBAO = np.genfromtxt('data/BOSS.txt',dtype=str, usecols=2)
#BOSS DR12 covariance matrix from 1607.03155
sigmaDR12 = np.diag(np.diag(errBAO)[np.where(np.loadtxt('data/BOSS.txt', usecols=0, dtype=str) == 'BOSS_DR12')])
corrDR12 = np.tril(np.loadtxt('data/BOSS_DR12_cov.txt', usecols=(1,2,3,4,5,6))*1E-4)
corrDR12 += corrDR12.T
corrDR12 -= np.eye(len(corrDR12))
CovDR12 = np.dot(sigmaDR12, np.dot(corrDR12, sigmaDR12))
#eBOSS Quasar covariance matrix from 1801.03043
sigmaeBOSS = np.diag(np.diag(errBAO)[np.where(np.loadtxt('data/BOSS.txt', usecols=0, dtype=str) == 'eBOSS_QSO')])
correBOSS = np.triu(np.loadtxt('data/eBOSS_QSO_cov.txt', usecols=(1,2,3,4,5,6,7,8))*1E-4)
correBOSS += correBOSS.T
correBOSS -= np.eye(len(correBOSS[0]))
CoveBOSS = np.dot(sigmaeBOSS, np.dot(correBOSS, sigmaeBOSS))
#assemble the full covariance matrix
load_cov = np.diag([1 if i else 0 for i in np.loadtxt('data/BOSS.txt',usecols=5)==1])
CovBAO = (errBAO - np.dot(load_cov,errBAO))**2
#CovBAO = (errBAO)**2
CovBAO += np.pad(CovDR12,[(2,len(errBAO)-2-len(CovDR12)),(2,len(errBAO)-2-len(CovDR12))], mode='constant', constant_values=0)
CovBAO += np.pad(CoveBOSS,[(2 + len(CovDR12) + 1,len(errBAO)- 3 - len(CovDR12) - len(CoveBOSS)),(2 + len(CovDR12) + 1,len(errBAO)- 3 - len(CovDR12) - len(CoveBOSS))], mode='constant', constant_values=0)
#Finally, add the correlations given in 1904.03430
add_cov = np.array([i if i<0 else 0 for i in np.loadtxt('data/BOSS.txt',usecols=5)])
Cov = np.pad(np.diag(add_cov[1:]), [(1,0),(0,1)], mode='constant', constant_values=0) + np.pad(np.diag(add_cov[1:]), [(0,1), (1,0)], mode='constant', constant_values=0)
for ind in np.array([np.where(add_cov<0)[0]-1., np.where(add_cov<0)[0]], dtype=int).T:
Cov[ind] = Cov[ind] * np.diag(errBAO)[ind[0]] * np.diag(errBAO)[ind[1]]
CovBAO += Cov
BAOdata = BAO_data(dataBAO, CovBAO, typeBAO)
model = sys.argv[-1]
#CMB Planck 2018 data
CMBdata = CMB_data(model, 'Planck18')
if not model in ['LCDM', 'kLCDM', 'wLCDM', 'conformal', 'bigravity', 'kbigravity']:
raise(NameError('Specify a cosmological model as the last argument.'))
ranges_min = np.array([0, 0, 60., -5, -10, -30, -.5, 0, 0]) #Omegam, Omegab, H0, alpha, beta, MB, delda_M, beta_prime, s
ranges_max = np.array([1, 0.1, 80., 5, 10, -10, .5, 10, 3]) #Omegam, Omegab, H0, alpha, beta, MB, delda_M, beta_prime, s
if model == 'kLCDM' or model == 'wLCDM': #insert Omegac prior
ranges_min = np.insert(ranges_min, 1, 0)
ranges_max = np.insert(ranges_max, 1, 1.5)
if model == 'wLCDM': #insert w prior
ranges_min = np.insert(ranges_min, -6, -2.5)
ranges_max = np.insert(ranges_max, -6, -1/3.)
elif model == 'conformal': #replace Omegam, Omegac -> gamma0, kappa priors
#ranges_min[2] = np.insert(ranges_min, 1, 0) #gamma0 range identical to Omegam
#ranges_max[2] = 2500
#ranges_max[0] = 10
ranges_min = np.insert(ranges_min, 1, 0) #gamma0 range identical to Omegam
ranges_max = np.insert(ranges_max, 1, 100) #gamma0 range identical to Omegam
elif model == 'bigravity': #add Bigravity model priors
ranges_min = np.append([ -1,-100,-100], ranges_min)
ranges_max = np.append([100, 100, 100], ranges_max)
elif model == 'kbigravity': #add Bigravity model priors and Omagc
ranges_min = np.insert(ranges_min, 1, 0)
ranges_max = np.insert(ranges_max, 1, 1.5)
ranges_min = np.append([ -1,-100,-100], ranges_min)
ranges_max = np.append([100, 100, 100], ranges_max)
data_sets = []
if 'SN' in sys.argv:
data_sets.append(SNdata)
if 'Quasars' in sys.argv:
data_sets.append(Qdata)
if 'BAO' in sys.argv:
data_sets.append(BAOdata)
if 'CMB' in sys.argv:
data_sets.append(CMBdata)
if 'RC' in sys.argv:
data_sets.append(RCdata)
def Likelihood(theta):
l = likelihood(theta, data_sets, ranges_min, ranges_max, model = model, rd_num = rd_num, z_num = z_num)
return l.logprobability_gauss_prior()
ndim, nwalkers, nsteps = len(ranges_min), 512, 1000
pool= MPIPool()
if not pool.is_master():
pool.wait()
sys.exit(0)
name = model + '_'
for data_sample in sys.argv[1:-1]:
name += data_sample + '_'
h5chain = HDFBackend('chains/' + name + str(nwalkers) + 'x' + str(nsteps) + '.h5')
try:
pos0 = h5chain.get_chain()[-1] #continue existing chains...
nsteps -= len(h5chain.get_chain()) #...for missing steps only
if nsteps <= 0:
raise ValueError("Chain is already complete.")
sampler = EnsembleSampler(nwalkers, ndim, Likelihood, pool=pool, backend=h5chain)
sampler.run_mcmc(pos0, nsteps)
pool.close()
except AttributeError:
pos0 = np.random.uniform(ranges_min, ranges_max,(nwalkers,len(ranges_max)))
sampler = EnsembleSampler(nwalkers, ndim, Likelihood, pool=pool, backend=h5chain)
sampler.run_mcmc(pos0, nsteps)
pool.close()
except ValueError:
pool.close()