Source code for pymultifit.fitters.gaussian_f

"""Created on Jul 18 00:25:57 2024"""

import numpy as np

from .backend import BaseFitter
from .utilities_f import sanity_check
from .. import OneDArray, Params_
from ..distributions.utilities_d import gaussian_pdf_


[docs] class GaussianFitter(BaseFitter): """A class for fitting multiple Gaussian distributions to the given data.""" def __init__(self, x_values: OneDArray, y_values: OneDArray, max_iterations: int = 1000): x_values, y_values = sanity_check(x_values=x_values, y_values=y_values) super().__init__(x_values=x_values, y_values=y_values, max_iterations=max_iterations) self.n_par = 3 def fit_boundaries(self): lb = (0, -np.inf, 0) ub = (np.inf, np.inf, np.inf) return lb, ub @staticmethod def fitter(x, params: Params_): return gaussian_pdf_(x, *params)