Source code for lenstronomy.SimulationAPI.sim_api
from lenstronomy.SimulationAPI.data_api import DataAPI
from lenstronomy.SimulationAPI.model_api import ModelAPI
from lenstronomy.ImSim.image_model import ImageModel
import copy
import numpy as np
__all__ = ["SimAPI"]
[docs]
class SimAPI(DataAPI, ModelAPI):
"""This class manages the model parameters in regard of the data specified in
SingleBand.
In particular, this API translates models specified in units of astronomical
magnitudes into the amplitude parameters used in the LightModel module of
lenstronomy. Optionally, this class can also handle inputs with cosmology dependent
lensing quantities and translates them to the optical quantities being used in the
lenstronomy LensModel module. All other model choices are equivalent to the ones
provided by LightModel, LensModel, PointSource modules
"""
[docs]
def __init__(self, numpix, kwargs_single_band, kwargs_model):
"""
:param numpix: number of pixels per axis
:param kwargs_single_band: keyword arguments specifying the class instance of DataAPI
:param kwargs_model: keyword arguments specifying the class instance of ModelAPI
"""
DataAPI.__init__(self, numpix, **kwargs_single_band)
ModelAPI.__init__(self, **kwargs_model)
[docs]
def image_model_class(self, kwargs_numerics=None):
"""
:param kwargs_numerics: keyword arguments list of Numerics module
:return: instance of the ImageModel class with all the specified configurations
"""
return ImageModel(
self.data_class,
self.psf_class,
self.lens_model_class,
self.source_model_class,
self.lens_light_model_class,
self.point_source_model_class,
kwargs_numerics=kwargs_numerics,
)
[docs]
def magnitude2amplitude(
self, kwargs_lens_light_mag=None, kwargs_source_mag=None, kwargs_ps_mag=None
):
"""'magnitude' definition are in APPARENT magnitudes as observed on the sky, not
intrinsic!
:param kwargs_lens_light_mag: keyword argument list as for LightModel module
except that 'amp' parameters are 'magnitude' parameters.
:param kwargs_source_mag: keyword argument list as for LightModel module except
that 'amp' parameters are 'magnitude' parameters.
:param kwargs_ps_mag: keyword argument list as for PointSource module except
that 'amp' parameters are 'magnitude' parameters.
:return: value of the lenstronomy 'amp' parameter such that the total flux of
the profile type results in this magnitude for all the light models. These
keyword arguments conform with the lenstronomy LightModel syntax.
"""
kwargs_lens_light = copy.deepcopy(kwargs_lens_light_mag)
if kwargs_lens_light_mag is not None:
for i, kwargs_mag in enumerate(kwargs_lens_light_mag):
kwargs_new = kwargs_lens_light[i]
del kwargs_new["magnitude"]
cps_norm = self.lens_light_model_class.total_flux(
kwargs_list=kwargs_lens_light, norm=True, k=i
)[0]
magnitude = kwargs_mag["magnitude"]
cps = self.magnitude2cps(magnitude)
amp = cps / cps_norm
kwargs_new["amp"] = amp
kwargs_source = copy.deepcopy(kwargs_source_mag)
if kwargs_source_mag is not None:
for i, kwargs_mag in enumerate(kwargs_source_mag):
kwargs_new = kwargs_source[i]
del kwargs_new["magnitude"]
cps_norm = self.source_model_class.total_flux(
kwargs_list=kwargs_source, norm=True, k=i
)[0]
magnitude = kwargs_mag["magnitude"]
cps = self.magnitude2cps(magnitude)
amp = cps / cps_norm
kwargs_new["amp"] = amp
kwargs_ps = copy.deepcopy(kwargs_ps_mag)
if kwargs_ps_mag is not None:
amp_list = []
for i, kwargs_mag in enumerate(kwargs_ps_mag):
kwargs_new = kwargs_ps[i]
del kwargs_new["magnitude"]
cps_norm = 1
magnitude = np.array(kwargs_mag["magnitude"])
cps = self.magnitude2cps(magnitude)
amp = cps / cps_norm
amp_list.append(amp)
kwargs_ps = self.point_source_model_class.set_amplitudes(
amp_list, kwargs_ps
)
return kwargs_lens_light, kwargs_source, kwargs_ps