Fast Methods for Cosmological Simulations
FastSim serves as a tool for quick N-body simulations in modified gravity.
ehpk_bm.py
Go to the documentation of this file.
1 import numpy as np
2 import matplotlib.pyplot as plt
3 import py_cosmo_mad as csm
4 
5 TCMB=2.725
6 PLOT_STUFF=0
7 WRITE_STUFF=1
8 FS=16
9 LKMAX=7
10 
11 def do_all(z_arr,k_arr,cpar,prefix) :
12  pcs=csm.PcsPar()
13  pcs.background_set(cpar['om'],cpar['ol'],cpar['ob'],cpar['w0'],cpar['wa'],cpar['hh'],TCMB)
14  pcs.set_linear_pk('EH',-3,LKMAX,0.01,cpar['ns'],cpar['s8'])
15 
16  gf0=pcs.growth_factor(1)
17  a_arr=1./(z_arr+1)
18  gf_arr=np.array([pcs.growth_factor(a) for a in a_arr])
19  pk_arr=np.array([[pcs.Pk_linear_0(k)*(gf/gf0)**2 for k in k_arr] for gf in gf_arr])
20 
21  if PLOT_STUFF==1 :
22  for i in np.arange(len(pk_arr)) :
23  plt.plot(k_arr,pk_arr[i],label='$z=%.2lf$'%(z_arr[i]))
24  plt.xlabel('$k\\,[h\\,{\\rm Mpc}^{-1}]$',fontsize=FS)
25  plt.ylabel('$P(k)\\,[{\\rm Mpc}\\,h^{-1}]^3$',fontsize=FS)
26  plt.gca().set_xscale('log');
27  plt.gca().set_yscale('log');
28  plt.legend(loc='lower left')
29  plt.show()
30 
31  if WRITE_STUFF==1 :
32  header_pk="[0] k (Mpc/h)^-1"
33  for i in np.arange(len(z_arr)) :
34  header_pk+=", [%d]"%(i+2)+" P(k,z=%.1lf) (Mpc/h)^3"%(z_arr[i])
35  np.savetxt(prefix+"_pk_eh.txt",np.transpose(np.vstack((k_arr,pk_arr))),header=header_pk)
36 
37 z_arr=np.array([0.,1.,2.,3.,4.,5.])
38 lk_arr=0.1*np.arange(41)-3.
39 k_arr=10**lk_arr
40 
41 cpar_model1={'om': 0.3,'ol': 0.7,'ob':0.05,'hh': 0.7,'s8': 0.8,'ns': 0.96,'w0': -1.0, 'wa': 0.0}
42 
43 do_all(z_arr,k_arr,cpar_model1,"model1")
def do_all(z_arr, k_arr, cpar, prefix)
Definition: ehpk_bm.py:11