55 lines
1.8 KiB
Python
55 lines
1.8 KiB
Python
import numexpr as ne
|
|
import numpy as np
|
|
import cosmotool as ct
|
|
import icgen as bic
|
|
import icgen.cosmogrowth as cg
|
|
import sys
|
|
import argparse
|
|
|
|
cosmo={'omega_M_0':0.3175, 'h':0.6711}
|
|
cosmo['omega_lambda_0']=1-cosmo['omega_M_0']
|
|
cosmo['omega_k_0'] = 0
|
|
cosmo['omega_B_0']=0.049
|
|
cosmo['SIGMA8']=0.8344
|
|
cosmo['ns']=0.9624
|
|
N0=256
|
|
|
|
doSimulation=True
|
|
|
|
astart=1.
|
|
|
|
parser=argparse.ArgumentParser(description="Generate CIC density from 2LPT")
|
|
parser.add_argument('--start', type=int, required=True)
|
|
parser.add_argument('--end', type=int, required=True)
|
|
parser.add_argument('--step', type=int, required=True)
|
|
parser.add_argument('--base', type=str, required=True)
|
|
parser.add_argument('--N', type=int, default=256)
|
|
parser.add_argument('--output', type=str, default="dcic_%d.npy")
|
|
parser.add_argument('--supersample', type=int, default=1)
|
|
parser.add_argument('--rsd', action='store_true')
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
for i in xrange(args.start, args.end, args.step):
|
|
print i
|
|
# pos,_,density,N,L,_ = bic.run_generation("/nethome/lavaux/remote/borg_2m++_128/initial_density_%d.dat" % i, 0.001, astart, cosmo, supersample=2, do_lpt2=True)
|
|
pos,vel,density,N,L,_,_ = bic.run_generation("%s/initial_density_%d.dat" % (args.base,i), 0.001, astart,
|
|
cosmo, supersample=args.supersample, do_lpt2=True, needvel=True)
|
|
|
|
if args.rsd:
|
|
inv_r2 = ne.evaluate('1/sqrt(x**2+y**2+z**2)',
|
|
local_dict={'x':pos[0], 'y':pos[1], 'z':pos[2]})
|
|
rsd = lambda p,v: ne.evaluate('x + (x*vx)*inv_r2 / H',
|
|
local_dict={'x':p, 'inv_r2':inv_r2,
|
|
'vx':v, 'H':100.0}, out=p, casting='unsafe')
|
|
|
|
rsd(pos[0], vel[0])
|
|
rsd(pos[1], vel[1])
|
|
rsd(pos[2], vel[2])
|
|
|
|
dcic = ct.cicParticles(pos, L, args.N)
|
|
dcic /= np.average(np.average(np.average(dcic, axis=0), axis=0), axis=0)
|
|
dcic -= 1
|
|
|
|
np.save(args.output % i, dcic)
|