Coverage for src/galsbi/ucat/plugins/sample_galaxies_morph.py: 97%
38 statements
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-10 11:12 +0000
« prev ^ index » next coverage.py v7.6.10, created at 2025-01-10 11:12 +0000
1# Copyright (C) 2018 ETH Zurich, Institute for Particle Physics and Astrophysics
3"""
4Created 2021
5author: Tomasz Kacprzak
6"""
8import numpy as np
9import PyCosmo
10from cosmic_toolbox import logger
11from ivy.plugin.base_plugin import BasePlugin
12from galsbi.ucat.galaxy_population_models.galaxy_light_profile import (
13 sample_sersic_for_galaxy_type,
14)
15from galsbi.ucat.galaxy_population_models.galaxy_shape import (
16 sample_ellipticities_for_galaxy_type,
17)
18from galsbi.ucat.galaxy_population_models.galaxy_size import sample_r50_for_galaxy_type
20LOGGER = logger.get_logger(__file__)
21SEED_OFFSET_LUMFUN = 123491
24class Plugin(BasePlugin):
25 """
26 Generate a random catalog of galaxies with magnitudes in multiple bands.
27 """
29 def __call__(self):
30 par = self.ctx.parameters
32 # cosmology
33 cosmo = PyCosmo.build()
34 cosmo.set(h=par.h, omega_m=par.omega_m)
36 # Initialize galaxy catalog
37 assert hasattr(
38 self.ctx, "galaxies"
39 ), "galaxy catalog not initialized, perhaps run sample_galaxies_photo first"
40 assert hasattr(
41 self.ctx, "pixels"
42 ), "pixels not initialized, perhaps run sample_galaxies_photo first"
44 # add new columns
45 morph_columns = ["sersic_n", "int_r50", "int_e1", "int_e2"]
46 self.ctx.galaxies.columns += morph_columns
47 n_gal_total = len(self.ctx.galaxies.z)
48 for c in morph_columns:
49 setattr(
50 self.ctx.galaxies, c, np.zeros(n_gal_total, dtype=par.catalog_precision)
51 )
53 # loop over luminosity functions
54 for j, g in enumerate(par.galaxy_types):
55 for i in range(len(self.ctx.pixels)):
56 # get info about the sample
57 select_type = self.ctx.galaxies.galaxy_type == j
58 n_gal_ = np.count_nonzero(select_type)
60 if n_gal_ == 0:
61 continue
63 # sersic index
64 np.random.seed(
65 par.seed + self.ctx.pixels[i] + par.gal_sersic_seed_offset
66 )
67 sersic_n = sample_sersic_for_galaxy_type(
68 n_gal=n_gal_,
69 galaxy_type=g,
70 app_mag=self.ctx.galaxies.int_magnitude_dict[par.reference_band][
71 select_type
72 ],
73 par=par,
74 z=self.ctx.galaxies.z[select_type],
75 )
77 # intrinsic size
78 int_r50 = sample_r50_for_galaxy_type(
79 z=self.ctx.galaxies.z[select_type],
80 abs_mag=self.ctx.galaxies.abs_magnitude_dict[par.reference_band][
81 select_type
82 ],
83 cosmo=cosmo,
84 par=par,
85 galaxy_type=g,
86 )
88 # intrinsic ellipticity
89 np.random.seed(
90 par.seed + self.ctx.pixels[i] + par.gal_ellipticities_seed_offset
91 )
92 (
93 int_e1,
94 int_e2,
95 ) = sample_ellipticities_for_galaxy_type(
96 n_gal=n_gal_, galaxy_type=g, par=par
97 )
99 # append lists
100 self.ctx.galaxies.int_r50[select_type] = int_r50
101 self.ctx.galaxies.sersic_n[select_type] = sersic_n
102 self.ctx.galaxies.int_e1[select_type] = int_e1
103 self.ctx.galaxies.int_e2[select_type] = int_e2
105 def __str__(self):
106 return "sample gal morph "