Source code for gemseo.mlearning.linear_model_fitting.ridge_cv_settings
# Copyright 2021 IRT Saint Exupéry, https://www.irt-saintexupery.com
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License version 3 as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
"""Settings for the scikit-learn ridge algorithm with built-in cross-validation."""
from __future__ import annotations
from collections.abc import Callable # noqa: TC003
from typing import ClassVar
from pydantic import Field
from pydantic import NonNegativeFloat
from strenum import StrEnum
from gemseo.mlearning.linear_model_fitting.base_linear_model_fitter_settings import (
BaseLinearModelFitter_Settings,
)
[docs]
class GCVMode(StrEnum):
"""Flag indicating the strategy for Leave-One-Out Cross-Validation."""
AUTO = "auto"
SVD = "svd"
EIGEN = "eigen"
[docs]
class RidgeCV_Settings(BaseLinearModelFitter_Settings): # noqa: N801
"""Settings for the scikit-learn ridge algorithm with build-in cross validation."""
_TARGET_CLASS_NAME: ClassVar[str] = "RidgeCV"
alphas: tuple[NonNegativeFloat, ...] = Field(
default=(0.001, 0.01, 0.1, 1.0, 10.0),
description=r"""Values of :math:`\alpha` to try.
The constant :math:`\alpha` multiplies the L2 term,
controlling regularization strength.""",
)
gcv_mode: GCVMode = Field(
default=GCVMode.AUTO,
description="""The flag indicating which strategy to use
when performing Leave-One-Out Cross-Validation.""",
)
alpha_per_target: bool = Field(
default=False,
description="""The flag indicating whether to optimize the :math:`alpha` value
(picked from the ``alphas`` parameter list) for each target separately
(for multi-output settings: multiple prediction targets).""",
)
scoring: str | Callable | None = Field(
default=None,
description="""The scoring method to use for cross-validation.
If ``None``,
use the mean squared error when ``cv`` is ``None``
and the coefficient of determination :math:`R^2` otherwise
""",
)
cv: int | None = Field(
default=None,
description="""The number of folds.
If ``None``, use the efficient Leave-One-Out cross-validation.""",
)