-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhz.py
113 lines (85 loc) · 3.86 KB
/
hz.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
import matplotlib.pylab as pylab
import matplotlib.pyplot as plt
import numpy as np
from src.lscdm import *
from src.lcdm import *
# ==================== PARAMETERS ====================
# --------------------- LCDM
h0_lcdm = h0_finder_LCDM()
Om0_lcdm = Om0_finder_LCDM()
z_ta = 2.0
a_ta = 1 / (1 + z_ta)
# ==================== HUBBLE FUNCTIONS ====================
def hz_LCDM(z):
H0_lcdm = h0_lcdm * 100
return H0_lcdm * np.sqrt(Om0_lcdm * (1+z)**3 + (1 - Om0_lcdm))
def hz_LsCDM(z, y_dag):
#y_dagger is given in terms of a_dagger
a_dag = y_dag * a_ta
z_dag = 1/a_dag - 1
h0_lscdm = h0_finder_LsCDM(z_dag)
Om0_lscdm = Om0_finder_LsCDM(z_dag)
H0_lscdm = h0_lscdm * 100
return H0_lscdm * np.sqrt(Om0_lscdm * (1+z)**3 + (1 - Om0_lscdm) * np.sign(z_dag - z))
# ==================== NUMERICAL ANALYSIS ====================
z_vals = np.arange(0, 4.505, 0.005)
Hz_vals_lcdm = np.array([hz_LCDM(z)/(1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_1 = np.array([hz_LsCDM(z, 0.60) / (1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_2 = np.array([hz_LsCDM(z, 0.70) / (1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_3 = np.array([hz_LsCDM(z, 0.80) / (1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_4 = np.array([hz_LsCDM(z, 1.01) / (1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_5 = np.array([hz_LsCDM(z, 1.05) / (1 + z) for z in z_vals])
Hz_vals_lscdm_y_dag_6 = np.array([hz_LsCDM(z, 1.08) / (1 + z) for z in z_vals])
# ==================== PLOT ====================
# LaTeX rendering text fonts
plt.rc('text', usetex=True)
plt.rc('font', family='serif')
# Adjusting the size of the figure
params = {'legend.fontsize': '27',
'axes.labelsize': '44',
'figure.figsize': (15, 10),
'xtick.labelsize': '44',
'ytick.labelsize': '44'}
pylab.rcParams.update(params)
fig, ax0 = plt.subplots()
ax0.plot(z_vals, Hz_vals_lcdm, color='black',
linestyle=(0, (5, 1)), lw=3.5, label=r'$\Lambda$CDM ($\Omega_{\rm m}=0.3101$)')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_1, color='#FFA500', ls='-',
lw=3.5, label=r'$y_{\dagger}=0.60~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) > 0)$')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_2, color='#Ff0000', ls='-',
lw=3.5, label=r'$y_{\dagger}=0.70~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) > 0)$')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_3, color='#800000', ls='-',
lw=3.5, label=r'$y_{\dagger}=0.80~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) > 0)$')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_4, color='#000080', ls='-',
lw=3.5, label=r'$y_{\dagger}=1.01~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) < 0)$')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_5, color='#0000ff', ls='-',
lw=3.5, label=r'$y_{\dagger}=1.05~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) < 0)$')
ax0.plot(z_vals, Hz_vals_lscdm_y_dag_6, color='#00ffff', ls='-',
lw=3.5, label=r'$y_{\dagger}=1.08~(\rho_{\Lambda_{\rm s}}(a_{\rm ta}) < 0)$')
ax0.axvline(x=2.0, color='green', ls='-', lw=3.5,
alpha=0.7, label=r'$z_{\rm ta}=2.0$')
# Setting labels
ax0.set_xlabel(r'$z$')
ax0.set_ylabel(r'$H(z) / (1+z)$')
# Setting limits
ax0.set_xlim(0, 4.5)
ax0.set_ylim(56, 92)
# Tick options
ax0.set_xticks([0, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5])
ax0.set_yticks([56, 60, 64, 68, 72, 76, 80, 84, 88, 92])
ax0.xaxis.set_ticks_position('both')
ax0.yaxis.set_ticks_position('both')
ax0.xaxis.set_tick_params(which='major', width=1.5, size=13.0, direction='in')
ax0.xaxis.set_tick_params(which='minor', width=1.0, size=6.50, direction='in')
ax0.yaxis.set_tick_params(which='major', width=1.5, size=13.0, direction='in')
ax0.yaxis.set_tick_params(which='minor', width=1.0, size=6.50, direction='in')
ax0.minorticks_on()
# Adding text
plt.text(1.5, 57.5, r'$y_{\dagger} > 1$', fontsize=36, color='black')
plt.text(2.1, 57.5, r'$y_{\dagger} < 1$', fontsize=36, color='black')
# Other settings
ax0.legend()
plt.tight_layout()
# Saving the figure
plt.savefig(r'log\hz.pdf', format='pdf', dpi=400)
plt.show()