# Copyright (c) 2016 Zhixian MA <zxma_sjtu@qq.com> # MIT license """ Basic parameters to be used in point sources simulation. References ---------- [1] Angular diameter distance, https://en.wikipedia.org/wiki/Angular_diameter_distance [2] FlatLambdaCDM, {http://docs.astropy.org/en/stable/api/astropy.cosmology. FlatLambdaCDM.html#astropy.cosmology.FlatLambdaCDM} """ from astropy.cosmology import FlatLambdaCDM class PixelParams(): """ A class to transform cosmology distance to angles or pixels. Parameters ------------ H0: float The hubble constant at z = 0, whose unit is km/s/Mpc Om0: float The total matter density. ang_res: float Angular resolution, i.e. degree per pixel. (May be useless) ang_total: list Total angles of the simulated sky region,whose unit is degree (\deg) z : float Redshift scale: float The real object scale. Example ------------ >>> PixelParams = PixelParams(img_size=(1024,1024),ang_total=(5,5)) """ # Hubble constant at z = 0 H0 = 71.0 # Omega0, total matter density Om0 = 0.27 # Redshift z = 0.0 # Cosmology calculator cosmo = 0.0 # angular diameter distance, [Mpc] dA = 0.0 # angular resolution ang_res = 0.0 def __init__(self, z=0.0): self.z = z self.cosmo = FlatLambdaCDM(H0=self.H0, Om0=self.Om0) # angular diameter distance, [Mpc] self.dA = self.cosmo.angular_diameter_distance(self.z).value def get_angle(self, scale=1.0): """ Input real object scale, and output the respect observed angle, and pixels. """ ang = scale / self.dA # [rac] return ang def get_scale(self, ang=1.0): """ Input real observed scale, and output the respect real object scale, and pixels. """ scale = ang * self.dA # [Mpc] return scale