Source code for jetset.gammapy_plugin
__author__ = "Andrea Tramacere"
import os
try:
from gammapy.modeling.models import (
SpectralModel,
)
from gammapy.modeling.parameter import Parameter,Parameters
from gammapy.estimators import FluxPoints
from gammapy.datasets import FluxPointsDataset
from gammapy.modeling import Fit
gammapy_installed = True
except:
on_rtd = os.environ.get('READTHEDOCS', None) == 'True'
if on_rtd is True:
pass
else:
raise ImportError('to use gammapy plugin you need to install gammapy: https://docs.gammapy.org/0.19/getting-started/install.html')
import astropy.units as u
import numpy as np
[docs]
def GammapyJetsetModelFactory(jetmodel,clone=True):
if clone is True:
_jetset_model = jetmodel.clone()
else:
_jetset_model= jetmodel
class GammapyJetsetModel(SpectralModel):
""" """
for ID,p in enumerate(_jetset_model.parameters.par_array):
#print(p.name)
exec("%s=Parameter(p.name,p.val, frozen=p.frozen)"%p.name)
if _jetset_model.parameters.par_array[ID].units is not None:
try:
exec("%s.unit = '%s'"%(p.name,_jetset_model.parameters.par_array[ID].units))
except:
exec("%s.unit = '' "%(p.name))
else:
exec("%s.unit = '' "%(p.name))
if _jetset_model.parameters.par_array[ID].val_min is not None:
exec("%s.min = %s"%(p.name,_jetset_model.parameters.par_array[ID].val_min))
if _jetset_model.parameters.par_array[ID].val_max is not None:
exec("%s.max = %s"%(p.name,_jetset_model.parameters.par_array[ID].val_max))
def evaluate(self,energy=None,**kwargs):
if energy is None:
el1=np.log10( self._jetset_model.nu_min)
el2=np.log10( self._jetset_model.nu_max)
energy=(np.logspace(el1,el2,self._jetset_model.nu_size)*u.Hz).to('eV',equivalencies=u.spectral())
nu = energy.to("Hz", equivalencies=u.spectral())
for p in self.parameters:
if p.name not in kwargs.keys():
self._jetset_model.set_par(p.name ,val=p.value)
for k,v in kwargs.items():
self._jetset_model.set_par(k,val=v.value)
self._jetset_model.eval(nu=nu.value)
_spec= self._jetset_model.spectral_components.Sum.SED.nuFnu.to('eV cm-2 s-1')/(energy.to('eV')**2)
return _spec.to("1 / (cm2 eV s)")
@property
def jetset_model(self):
return self._jetset_model
gammapy_obj=GammapyJetsetModel()
setattr(gammapy_obj,'_jetset_model',_jetset_model)
setattr(gammapy_obj,'tag',_jetset_model.name)
return gammapy_obj