Source code for tailestim.estimators.moments

"""Moments estimator implementation for tail index estimation."""

from typing import Any, Dict, Tuple, Union

import numpy as np
from numpy.random import BitGenerator, Generator, RandomState, SeedSequence

from .base import BaseTailEstimator
from .result import TailEstimatorResult
from .tail_methods import moments_estimator as moments_estimate


[docs] class MomentsEstimator(BaseTailEstimator): """Moments estimator for tail index estimation. This class implements the Moments estimator with optional double-bootstrap for optimal threshold selection. Parameters ---------- bootstrap : bool, default=True Whether to use double-bootstrap for optimal threshold selection. t_bootstrap : float, default=0.5 Parameter controlling the size of the 2nd bootstrap. Defined from n2 = n*(t_bootstrap). r_bootstrap : int, default=500 Number of bootstrap resamplings for the 1st and 2nd bootstraps. eps_stop : float, default=0.99 Parameter controlling range of AMSE minimization. Defined as the fraction of order statistics to consider during the AMSE minimization step. verbose : bool, default=False Flag controlling bootstrap verbosity. diagn_plots : bool, default=False Flag to switch on/off generation of AMSE diagnostic plots. base_seed: None | SeedSequence | BitGenerator | Generator | RandomState, default=None Base random seed for reproducibility of bootstrap. """
[docs] def __init__( self, bootstrap: bool = True, t_bootstrap: float = 0.5, r_bootstrap: int = 500, eps_stop: float = 0.99, verbose: bool = False, diagn_plots: bool = False, base_seed: Union[ None, SeedSequence, BitGenerator, Generator, RandomState ] = None, **kwargs, ): super().__init__(bootstrap=bootstrap, base_seed=base_seed, **kwargs) self.t_bootstrap = t_bootstrap self.r_bootstrap = r_bootstrap self.eps_stop = eps_stop self.verbose = verbose self.diagn_plots = diagn_plots
def _estimate(self, ordered_data: np.ndarray) -> Tuple: """Estimate tail index using the Moments method. Parameters ---------- ordered_data : np.ndarray Data array in decreasing order. Returns ------- Tuple Contains estimation results from moments_estimator. """ return moments_estimate( ordered_data, bootstrap=self.bootstrap, t_bootstrap=self.t_bootstrap, r_bootstrap=self.r_bootstrap, verbose=self.verbose, diagn_plots=self.diagn_plots, eps_stop=self.eps_stop, base_seed=self.base_seed, )
[docs] def get_params(self) -> Dict[str, Any]: """Get the parameters of the estimator. Returns ------- dict Dictionary containing the parameters of the estimator. """ return { "base_seed": self.base_seed, "bootstrap": self.bootstrap, "t_bootstrap": self.t_bootstrap, "r_bootstrap": self.r_bootstrap, "eps_stop": self.eps_stop, "verbose": self.verbose, "diagn_plots": self.diagn_plots, **self.kwargs, }
[docs] def get_result(self) -> TailEstimatorResult: """Get the estimated parameters. Attributes ---------- estimator : BaseTailEstimator The estimator instance (e.g., HillEstimator, PickandsEstimator, etc.) used for estimation. xi_star_ : float Optimal tail index estimate (ξ). gamma_ : float Power law exponent (γ). k_arr_ : np.ndarray Array of order statistics. xi_arr_ : np.ndarray Array of tail index estimates. k_star_ : float Optimal order statistic (k*). bootstrap_results_ : dict Bootstrap results. Returns ------- TailEstimatorResult """ if self.results is None: raise ValueError("Model not fitted yet. Call fit() first.") ( k_arr, xi_arr, k_star, xi_star, x1_arr, n1_amse, k1, max_index1, x2_arr, n2_amse, k2, max_index2, ) = self.results res = { "k_arr_": k_arr, "xi_arr_": xi_arr, } if self.bootstrap and k_star is not None: gamma = float("inf") if xi_star <= 0 else 1 + 1.0 / xi_star res.update( { "estimator": self, "k_star_": k_star, "xi_star_": xi_star, "gamma_": gamma, "bootstrap_results_": { "first_bootstrap_": { "x_arr_": x1_arr, "amse_": n1_amse, "k_min_": k1, "max_index_": max_index1, }, "second_bootstrap_": { "x_arr_": x2_arr, "amse_": n2_amse, "k_min_": k2, "max_index_": max_index2, }, }, } ) return TailEstimatorResult(res)