-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathCell_CIBxtSZ.py
96 lines (85 loc) · 4.23 KB
/
Cell_CIBxtSZ.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
from headers_constants import *
class cl_cibxtsz(object):
def __init__(self, cell_cib, cell_tsz):
self.cib = cell_cib
self.tsz = cell_tsz
self.nfreq = self.cib.nfreq
self.cosmo = self.cib.cosmo
self.z = self.cib.z
self.mh = self.cib.mh
self.ell = self.cib.ell
def E_z(self):
return np.sqrt(self.cosmo.Om0*(1+self.z)**3 + self.cosmo.Ode0) # dim z
def dVc_dz(self): # dim z
return c_light*self.cosmo.comoving_distance(self.z).value**2/(self.cosmo.H0.value*self.E_z())
def dj2cibprime(self):
djcen, djsub = self.cib.djc_dlogMh(), self.cib.djsub_dlogMh()
cosm = (1+self.z)*self.cosmo.comoving_distance(self.z).value**2
djcen_prime = djcen/(self.tsz.hmf*cosm)
djsub_prime = djsub/(self.tsz.hmf*cosm)
return djcen_prime, djsub_prime
def onehalo(self):
if self.cib.dv.exp['name'] == 'Planck':
"""
Kcmb_MJy are factors for Planck frequency channels to convert
units from Kcmb to MJy
"""
Kcmb_MJy = np.array([244.1, 371.74, 483.69, 287.45, 58.04, 2.27])
else:
print ("factors to convert units from Kcmb to MJy for %s experiment are not provided." +
"So the final units here will be Kcmb*Jy/sr" % (self.cib.dv.exp['name']))
Kcmb_MJy = np.ones(len(self.nu))
cl_1h = np.zeros((self.nfreq, self.nfreq, len(self.ell)))
u_nfw = self.cib.unfw # dim m,ell,z
geo = self.dVc_dz()
dj_c, dj_sub = self.dj2cibprime()
f_v = self.tsz.f_nu()*1e6*Kcmb_MJy
y_ell = self.tsz.y_ell_tab()
dlog10m = np.log10(self.mh[1] / self.mh[0])
for i in range(len(self.ell)):
for f in range(self.nfreq):
a = y_ell[i, :]*((dj_c+dj_sub*u_nfw[:, i, :])*self.cib.cc[:, None, None]*f_v[f] +
(dj_c[f, :]+dj_sub[f, :] *
u_nfw[:, i, :])*self.cib.cc[f]*f_v[:, None, None]) * \
self.tsz.hmf
# intgn_mh = intg.simps(a, dx=dlog10m, axis=1, even='avg')
intgn_mh = intg.simps(a, x=np.log10(self.mh), axis=1, even='avg')
b = geo*intgn_mh
intgn_z = intg.simps(b, x=self.z, axis=-1, even='avg')
cl_1h[f, :, i] = intgn_z # *T_cmb
return cl_1h # final units: Jy^2/sr if Kcmb_jy factor is multiplied
# otherwise the units are Kcmb*Jy/sr
def twohalo(self):
if self.cib.dv.exp['name'] == 'Planck':
"""
Kcmb_MJy are factors for Planck frequency channels to convert
units from Kcmb to MJy
"""
Kcmb_MJy = np.array([244.1, 371.74, 483.69, 287.45, 58.04, 2.27])
else:
print ("factors to convert units from Kcmb to MJy for %s experiment are not provided." +
"So the final units here will be Kcmb*Jy/sr" % (self.cib.dv.exp['name']))
Kcmb_MJy = np.ones(len(self.nu))
cl_2h = np.zeros((self.nfreq, self.nfreq, len(self.ell)))
u_nfw = self.cib.unfw # dim m,ell,z
geo = self.dVc_dz()*self.cib.Pk_int
dj_c, dj_sub = self.dj2cibprime()
f_v = self.tsz.f_nu()*1e6*Kcmb_MJy
y_ell = self.tsz.y_ell_tab()
bhmf = self.tsz.biasmz*self.tsz.hmf
dlog10m = np.log10(self.mh[1] / self.mh[0])
for i in range(len(self.ell)):
res1 = y_ell[i, :]*bhmf
# intgn_mh1 = intg.simps(a1, dx=dlog10m, axis=0, even='avg')
intgn_mh1 = intg.simps(res1, x=np.log10(self.mh), axis=0, even='avg')
for f in range(self.nfreq):
res2 = ((dj_c+dj_sub*u_nfw[:, i, :])*f_v[f] +
(dj_c[f, :]+dj_sub[f, :]*u_nfw[:, i, :]) *
f_v[:, None, None])*bhmf
# intgn_mh2 = intg.simps(a2, dx=dlog10m, axis=1, even='avg')
intgn_mh2 = intg.simps(res2, x=np.log10(self.mh), axis=1, even='avg')
b = geo[i, :]*intgn_mh1*intgn_mh2
intgn_z = intg.simps(b, x=self.z, axis=-1, even='avg')
cl_2h[f, :, i] = intgn_z # *T_cmb
return cl_2h # final units: Jy^2/sr if Kcmb_jy factor is multiplied
# otherwise the units are Kcmb*Jy/sr