From 7f3086c7bfcf8e0be531c6885276e3dcdf88f83f Mon Sep 17 00:00:00 2001 From: Aaron LI Date: Mon, 31 Jul 2017 19:47:18 +0800 Subject: clusters/main.py: Add method "_simulate_halos()" This method simulates the radio halo properties for each cluster with a recent major merger. Signed-off-by: Aaron LI --- fg21sim/extragalactic/clusters/main.py | 43 ++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) (limited to 'fg21sim/extragalactic/clusters/main.py') diff --git a/fg21sim/extragalactic/clusters/main.py b/fg21sim/extragalactic/clusters/main.py index a97b605..a280bb9 100644 --- a/fg21sim/extragalactic/clusters/main.py +++ b/fg21sim/extragalactic/clusters/main.py @@ -77,6 +77,7 @@ class GalaxyClusters: self.ratio_major = self.configs.getn(comp+"/ratio_major") self.tau_merger = self.configs.getn(comp+"/tau_merger") + self.frequencies = self.configs.frequencies self.filename_pattern = self.configs.getn("output/filename_pattern") self.use_float = self.configs.getn("output/use_float") self.checksum = self.configs.getn("output/checksum") @@ -222,8 +223,50 @@ class GalaxyClusters: logger.info("%d (%.1f%%) clusters have recent major mergers." % (num_major, 100*num_major/num)) + def _simulate_halos(self): """ + Simulate the radio halo properties for each cluster with + recent major merger event. + + Attributes + ---------- + halos : list[dict] + Simulated data for each cluster with recent major merger. """ + # Select out the clusters with recent major mergers + idx_rmm = ~self.catalog["rmm_z"].isnull() + num = idx_rmm.sum() + logger.info("Simulating halos for %d merging clusters ..." % num) + self.halos = [] + i = 0 + for row in self.catalog[idx_rmm].itertuples(): + i += 1 + if i % 50 == 0: + logger.info("[%d/%d] %.1f%% ..." % (i, num, 100*i/num)) + halo = RadioHalo(M_obs=row.mass, z_obs=row.z, + M_main=row.rmm_mass1, M_sub=row.rmm_mass2, + z_merger=row.rmm_z, configs=self.configs) + n_e = halo.calc_electron_spectrum() + emissivity = halo.calc_emissivity(frequencies=self.frequencies) + flux = halo.calc_flux(emissivity) + data = { + "z0": halo.z, + "M0": halo.mass, # [Msun] + "z_merger": halo.z_merger, + "M_main": halo.M_main, # [Msun] + "M_sub": halo.M_sub, # [Msun] + "time_crossing": halo.time_crossing, # [Gyr] + "gamma": halo.gamma, # Lorentz factors + "radius": halo.radius, # [kpc] + "angular_radius": halo.angular_radius, # [arcsec] + "B": halo.magnetic_field, # [uG] + "n_e": n_e, # [cm^-3] + "frequencies": self.frequencies, # [MHz] + "emissivity": emissivity, # [erg/s/cm^3/Hz] + "flux": flux, # [Jy] + } + self.halos.append(data) + logger.info("Simulated radio halos for merging cluster.") def preprocess(self): """ -- cgit v1.2.2