From 8221ece7a7d18dc0f76f3c0bbf25371eedd1e33f Mon Sep 17 00:00:00 2001
From: Aaron LI <aly@aaronly.me>
Date: Sun, 13 Aug 2017 21:09:46 +0800
Subject: clusters/main.py: Implement "simulate_frequency()" and "simulate()"

Signed-off-by: Aaron LI <aly@aaronly.me>
---
 fg21sim/extragalactic/clusters/main.py | 46 ++++++++++++++++++++++++++++++++++
 1 file changed, 46 insertions(+)

(limited to 'fg21sim')

diff --git a/fg21sim/extragalactic/clusters/main.py b/fg21sim/extragalactic/clusters/main.py
index 94a3288..610e60b 100644
--- a/fg21sim/extragalactic/clusters/main.py
+++ b/fg21sim/extragalactic/clusters/main.py
@@ -29,6 +29,7 @@ from .halo import RadioHalo
 from ...share import CONFIGS, COSMO
 from ...utils.io import dataframe_to_csv, pickle_dump
 from ...utils.ds import dictlist_to_dataframe
+from ...utils.convert import JyPerPix_to_K
 from ...sky import get_sky
 from . import helper
 
@@ -364,6 +365,51 @@ class GalaxyClusters:
 
         self._preprocessed = True
 
+    def simulate_frequency(self, freqidx):
+        """
+        Simulate the superimposed radio halos image at frequency (by
+        frequency index) based on the above simulated halo templates.
+
+        Parameters
+        ----------
+        freqidx : int
+            The index of the frequency in the ``self.frequencies`` where
+            to simulate the radio halos image.
+
+        Returns
+        -------
+        sky : `~fg21sim.sky.SkyPatch`
+            The simulated sky image of radio halos as a new sky instance.
+        """
+        freq = self.frequencies[freqidx]
+        logger.info("Simulating radio halo map at %.2f [MHz] ..." % freq)
+        sky = self.sky.copy()
+        sky.frequency = freq
+        # Conversion factor for [Jy/pixel] to [K]
+        JyPP2K = JyPerPix_to_K(freq, sky.pixelsize)
+
+        for hdict in self.halos:
+            center = (hdict["lon"], hdict["lat"])
+            template = hdict["template"]  # normalized to have mean of 1
+            Npix = template.size
+            flux = hdict["flux[%d]" % freqidx]  # [Jy]
+            Tmean = (flux/Npix) * JyPP2K  # [K]
+            Timg = Tmean * template  # [K]
+            sky.add(Timg, center=center)
+
+        return sky
+
+    def simulate(self):
+        """
+        Simulate the sky images of radio halos at each frequency.
+        """
+        logger.info("Simulating {name} ...".format(name=self.name))
+        for idx, freq in enumerate(self.frequencies):
+            sky = self.simulate_frequency(freqidx=idx)
+            outfile = self._outfilepath(frequency=freq)
+            sky.write(outfile)
+        logger.info("Done simulate {name}!".format(name=self.name))
+
     def postprocess(self):
         """
         Do some necessary post-simulation operations.
-- 
cgit v1.2.2