Source code for zfit.models.special

"""
Special PDFs are provided in this module. One example is a normal function `Function` that allows to
simply define a non-normalizable function.
"""

#  Copyright (c) 2019 zfit

import functools
from types import MethodType

import tensorflow as tf



from ..core.basemodel import SimpleModelSubclassMixin
from ..core.basepdf import BasePDF
from .functor import BaseFunctor
from ..util import ztyping

from ..core.basepdf import BasePDF
from ..core.limits import no_norm_range
from ..util.exception import NormRangeNotImplementedError


[docs]class SimplePDF(BasePDF): def __init__(self, obs, func, name="SimplePDF", **params): super().__init__(name=name, params=params, obs=obs) self._unnormalized_prob_func = self._check_input_x_function(func) def _unnormalized_pdf(self, x): return self._unnormalized_prob_func(self, x)
[docs] def copy(self, **override_parameters) -> 'BasePDF': override_parameters.update(func=self._unnormalized_prob_func) return super().copy(**override_parameters)
[docs]class SimpleFunctorPDF(BaseFunctor, SimplePDF): def __init__(self, obs, pdfs, func, name="SimpleFunctorPDF", **params): super().__init__(obs=obs, pdfs=pdfs, func=func, name=name, **params)
[docs]def raise_error_if_norm_range(func): func = no_norm_range(func) @functools.wraps(func) def wrapped(*args, **kwargs): try: return func(*args, **kwargs) except NormRangeNotImplementedError: # TODO: silently remove norm_range? Or loudly fail? raise tf.errors.InvalidArgumentError("Norm_range given to Function: cannot be normalized.") return wrapped
[docs]class ZPDF(SimpleModelSubclassMixin, BasePDF): def __init__(self, obs: ztyping.ObsTypeInput, name: str = "ZPDF", **params): super().__init__(obs=obs, name=name, **params) def __init_subclass__(cls, **kwargs): super().__init_subclass__(**kwargs) cls._check_simple_model_subclass()