LassoLarsCV#
- класс sklearn.linear_model.LassoLarsCV(*, fit_intercept=True, verbose=False, max_iter=500, precompute='auto', cv=None, max_n_alphas=1000, n_jobs=None, eps=np.float64(2.220446049250313e-16), copy_X=True, положительный=False)[источник]#
Лассо с кросс-валидацией, использующий алгоритм LARS.
См. запись в глоссарии для оценщик перекрестной проверки.
Целевая функция оптимизации для Lasso:
(1 / (2 * n_samples)) * ||y - Xw||^2_2 + alpha * ||w||_1
Подробнее в Руководство пользователя.
- Параметры:
- fit_interceptbool, по умолчанию=True
Вычислять ли свободный член для этой модели. Если установлено false, свободный член не будет использоваться в вычислениях (т.е. ожидается, что данные центрированы).
- verbosebool или int, по умолчанию=False
Устанавливает уровень подробности вывода.
- max_iterint, по умолчанию=500
Максимальное количество итераций для выполнения.
- precomputebool или ‘auto’, по умолчанию=’auto’
Использовать ли предварительно вычисленную матрицу Грама для ускорения вычислений. Если установлено в
'auto'позвольте нам решить. Матрица Грама не может быть передана в качестве аргумента, поскольку мы будем использовать только подмножества X.- cvint, генератор кросс-валидации или итерируемый объект, по умолчанию=None
Определяет стратегию разделения для перекрестной проверки. Возможные значения для cv:
None, чтобы использовать стандартную 5-кратную перекрестную проверку,
целое число, чтобы указать количество фолдов.
Итерируемый объект, возвращающий (обучающие, тестовые) разбиения в виде массивов индексов.
Для целочисленных/None входов,
KFoldиспользуется.Обратитесь Руководство пользователя для различных стратегий перекрестной проверки, которые можно использовать здесь.
Изменено в версии 0.22:
cvзначение по умолчанию, если None изменено с 3-кратного на 5-кратное.- max_n_alphasint, по умолчанию=1000
Максимальное количество точек на пути, используемом для вычисления остатков при кросс-валидации.
- n_jobsint или None, по умолчанию=None
Количество процессоров для использования во время перекрестной проверки.
Noneозначает 1, если только не вjoblib.parallel_backendконтекст.-1означает использование всех процессоров. См. Глоссарий для получения дополнительной информации.- epsfloat, по умолчанию=np.finfo(float).eps
Регуляризация с машинной точностью в вычислении диагональных факторов Холецкого. Увеличьте это для очень плохо обусловленных систем. В отличие от
tolпараметр в некоторых итеративных алгоритмах на основе оптимизации, этот параметр не контролирует допуск оптимизации.- copy_Xbool, по умолчанию=True
Если True, X будет скопирован; иначе, он может быть перезаписан.
- положительныйbool, по умолчанию=False
Ограничить коэффициенты быть >= 0. Учтите, что вы можете захотеть удалить fit_intercept, который по умолчанию установлен в True. При положительном ограничении коэффициенты модели не сходятся к решению обычного метода наименьших квадратов для малых значений alpha. Только коэффициенты до наименьшего значения alpha (
alphas_[alphas_ > 0.].min()когда fit_path=True), достигаемые пошаговым алгоритмом Lars-Lasso, обычно соответствуют решению оценщика Lasso с координатным спуском. Следовательно, использование LassoLarsCV имеет смысл только для задач, где ожидается и/или достигается разреженное решение.
- Атрибуты:
- coef_массивоподобный формы (n_features,)
вектор параметров (w в формуле)
- intercept_float
независимый член в функции принятия решений.
- coef_path_array-like формы (n_features, n_alphas)
изменяющиеся значения коэффициентов вдоль пути
- alpha_float
оцененный параметр регуляризации alpha
- alphas_array-like формы (n_alphas,)
различные значения alpha вдоль пути
- cv_alphas_array-like формы (n_cv_alphas,)
все значения alpha вдоль пути для различных фолдов
- mse_path_array-like формы (n_folds, n_cv_alphas)
среднеквадратичная ошибка на оставленных данных для каждого сгида вдоль пути (значения alpha, заданные
cv_alphas)- n_iter_array-like или int
количество итераций, выполненных Lars с оптимальным alpha.
- active_список целых чисел
Индексы активных переменных в конце пути.
- n_features_in_int
Количество признаков, замеченных во время fit.
Добавлено в версии 0.24.
- feature_names_in_ndarray формы (
n_features_in_,) Имена признаков, наблюдаемых во время fit. Определено только когда
Xимеет имена признаков, которые все являются строками.Добавлено в версии 1.0.
Смотрите также
lars_pathВычислить путь регрессии наименьших углов или Lasso с использованием алгоритма LARS.
lasso_pathВычислить путь Lasso с координатным спуском.
LassoЛинейная модель, обученная с априорным распределением L1 в качестве регуляризатора (также известная как Lasso).
LassoCVЛассо линейная модель с итеративной подгонкой вдоль пути регуляризации.
LassoLarsМодель Lasso, обученная с использованием метода наименьших углов, также известного как Lars.
LassoLarsICМодель Lasso, обученная с помощью Lars с использованием BIC или AIC для выбора модели.
sklearn.decomposition.sparse_encodeРазреженное кодирование.
Примечания
Объект решает ту же проблему, что и
LassoCVобъект. Однако, в отличие отLassoCV, он находит соответствующие значения альфа самостоятельно. В целом, благодаря этому свойству, он будет более стабильным. Однако он более чувствителен к сильно мультиколлинеарным наборам данных.Он более эффективен, чем
LassoCVесли выбрано лишь небольшое количество признаков по сравнению с общим числом, например, если выборок очень мало по сравнению с количеством признаков.В
fit, как только лучший параметрalphaнаходится с помощью кросс-валидации, модель снова обучается на всем тренировочном наборе.Примеры
>>> from sklearn.linear_model import LassoLarsCV >>> from sklearn.datasets import make_regression >>> X, y = make_regression(noise=4.0, random_state=0) >>> reg = LassoLarsCV(cv=5).fit(X, y) >>> reg.score(X, y) 0.9993 >>> reg.alpha_ np.float64(0.3972) >>> reg.predict(X[:1,]) array([-78.4831])
- fit(X, y, **params)[источник]#
Обучите модель, используя X, y в качестве обучающих данных.
- Параметры:
- Xarray-like формы (n_samples, n_features)
Обучающие данные.
- yarray-like формы (n_samples,)
Целевые значения.
- **paramsdict, по умолчанию=None
Параметры, передаваемые разделителю CV.
Добавлено в версии 1.4: Доступно только если
enable_metadata_routing=True, который можно установить с помощьюsklearn.set_config(enable_metadata_routing=True). См. Руководство по маршрутизации метаданных для более подробной информации.
- Возвращает:
- selfobject
Возвращает экземпляр self.
- 6332()[источник]#
Получить маршрутизацию метаданных этого объекта.
Пожалуйста, проверьте Руководство пользователя о том, как работает механизм маршрутизации.
Добавлено в версии 1.4.
- Возвращает:
- маршрутизацияMetadataRouter
A
MetadataRouterИнкапсуляция информации о маршрутизации.
- get_params(глубокий=True)[источник]#
Получить параметры для этого оценщика.
- Параметры:
- глубокийbool, по умолчанию=True
Если True, вернет параметры для этого оценщика и вложенных подобъектов, которые являются оценщиками.
- Возвращает:
- paramsdict
Имена параметров, сопоставленные с их значениями.
- predict(X)[источник]#
Прогнозирование с использованием линейной модели.
- Параметры:
- Xмассивоподобный или разреженная матрица, форма (n_samples, n_features)
Образцы.
- Возвращает:
- Cмассив, формы (n_samples,)
Возвращает предсказанные значения.
- score(X, y, sample_weight=None)[источник]#
Возвращает коэффициент детерминации на тестовых данных.
Коэффициент детерминации, \(R^2\), определяется как \((1 - \frac{u}{v})\), где \(u\) является остаточной суммой квадратов
((y_true - y_pred)** 2).sum()и \(v\) является общей суммой квадратов((y_true - y_true.mean()) ** 2).sum()Лучший возможный результат - 1.0, и он может быть отрицательным (потому что модель может быть сколь угодно хуже). Постоянная модель, которая всегда предсказывает ожидаемое значениеy, игнорируя входные признаки, получит \(R^2\) оценка 0.0.- Параметры:
- Xarray-like формы (n_samples, n_features)
Тестовые выборки. Для некоторых оценщиков это может быть предварительно вычисленная матрица ядра или список общих объектов вместо этого с формой
(n_samples, n_samples_fitted), гдеn_samples_fitted— это количество образцов, использованных при обучении оценщика.- yarray-like формы (n_samples,) или (n_samples, n_outputs)
Истинные значения для
X.- sample_weightarray-like формы (n_samples,), по умолчанию=None
Веса выборок.
- Возвращает:
- scorefloat
\(R^2\) of
self.predict(X)относительноy.
Примечания
The \(R^2\) оценка, используемая при вызове
scoreна регрессоре используетmultioutput='uniform_average'с версии 0.23 для сохранения согласованности со значением по умолчаниюr2_score. Это влияет наscoreметод всех многомерных регрессоров (кромеMultiOutputRegressor).
- set_fit_request(*, Xy: bool | None | str = '$UNCHANGED$') LassoLarsCV[источник]#
Настроить, следует ли запрашивать передачу метаданных в
fitметод.Обратите внимание, что этот метод актуален только тогда, когда этот оценщик используется как под-оценщик внутри мета-оценщик и маршрутизация метаданных включена с помощью
enable_metadata_routing=True(см.sklearn.set_config). Пожалуйста, проверьте Руководство пользователя о том, как работает механизм маршрутизации.Варианты для каждого параметра:
True: запрашиваются метаданные и передаютсяfitесли предоставлено. Запрос игнорируется, если метаданные не предоставлены.False: метаданные не запрашиваются, и мета-оценщик не передаст их вfit.None: метаданные не запрашиваются, и мета-оценщик выдаст ошибку, если пользователь предоставит их.str: метаданные должны передаваться мета-оценщику с этим заданным псевдонимом вместо исходного имени.
По умолчанию (
sklearn.utils.metadata_routing.UNCHANGED) сохраняет существующий запрос. Это позволяет изменять запрос для некоторых параметров, но не для других.Добавлено в версии 1.3.
- Параметры:
- Xystr, True, False или None, по умолчанию=sklearn.utils.metadata_routing.UNCHANGED
Маршрутизация метаданных для
Xyпараметр вfit.
- Возвращает:
- selfobject
Обновленный объект.
- set_params(**params)[источник]#
Установить параметры этого оценщика.
Метод работает как на простых оценщиках, так и на вложенных объектах (таких как
Pipeline). Последние имеют параметры видачтобы можно было обновить каждый компонент вложенного объекта.__ - Параметры:
- **paramsdict
Параметры оценщика.
- Возвращает:
- selfэкземпляр estimator
Экземпляр оценщика.
- set_score_request(*, sample_weight: bool | None | str = '$UNCHANGED$') LassoLarsCV[источник]#
Настроить, следует ли запрашивать передачу метаданных в
scoreметод.Обратите внимание, что этот метод актуален только тогда, когда этот оценщик используется как под-оценщик внутри мета-оценщик и маршрутизация метаданных включена с помощью
enable_metadata_routing=True(см.sklearn.set_config). Пожалуйста, проверьте Руководство пользователя о том, как работает механизм маршрутизации.Варианты для каждого параметра:
True: запрашиваются метаданные и передаютсяscoreесли предоставлено. Запрос игнорируется, если метаданные не предоставлены.False: метаданные не запрашиваются, и мета-оценщик не передаст их вscore.None: метаданные не запрашиваются, и мета-оценщик выдаст ошибку, если пользователь предоставит их.str: метаданные должны передаваться мета-оценщику с этим заданным псевдонимом вместо исходного имени.
По умолчанию (
sklearn.utils.metadata_routing.UNCHANGED) сохраняет существующий запрос. Это позволяет изменять запрос для некоторых параметров, но не для других.Добавлено в версии 1.3.
- Параметры:
- sample_weightstr, True, False или None, по умолчанию=sklearn.utils.metadata_routing.UNCHANGED
Маршрутизация метаданных для
sample_weightпараметр вscore.
- Возвращает:
- selfobject
Обновленный объект.
Примеры галереи#
Выбор модели Lasso: AIC-BIC / перекрёстная проверка