scikit-learn 1.2 发布亮点#

我们很高兴宣布 scikit-learn 1.2 发布了!增加了许多错误修复和改进,以及一些新的关键功能。下面我们详细介绍本次发布的一些主要功能。有关所有更改的详尽列表,请参阅发布说明

安装最新版本(使用 pip)

pip install --upgrade scikit-learn

或使用 conda

conda install -c conda-forge scikit-learn

使用 set_output API 支持 Pandas 输出#

scikit-learn 的转换器现在通过 set_output API 支持 Pandas 输出。要了解更多关于 set_output API 的信息,请参见示例:引入 set_output API 和这个 视频:scikit-learn 转换器的 Pandas DataFrame 输出(一些示例)

import numpy as np

from sklearn.compose import ColumnTransformer
from sklearn.datasets import load_iris
from sklearn.preprocessing import KBinsDiscretizer, StandardScaler

X, y = load_iris(as_frame=True, return_X_y=True)
sepal_cols = ["sepal length (cm)", "sepal width (cm)"]
petal_cols = ["petal length (cm)", "petal width (cm)"]

preprocessor = ColumnTransformer(
    [
        ("scaler", StandardScaler(), sepal_cols),
        (
            "kbin",
            KBinsDiscretizer(encode="ordinal", quantile_method="averaged_inverted_cdf"),
            petal_cols,
        ),
    ],
    verbose_feature_names_out=False,
).set_output(transform="pandas")

X_out = preprocessor.fit_transform(X)
X_out.sample(n=5, random_state=0)
萼片长度 (cm) 萼片宽度 (cm) 花瓣长度 (cm) 花瓣宽度 (cm)
114 -0.052506 -0.592373 3.0 4.0
62 0.189830 -1.973554 2.0 1.0
33 -0.416010 2.630382 0.0 1.0
107 1.765012 -0.362176 4.0 3.0
7 -1.021849 0.788808 1.0 1.0


基于直方图的梯度提升树中的交互约束#

HistGradientBoostingRegressorHistGradientBoostingClassifier 现在支持通过 interaction_cst 参数设置交互约束。详细信息请参见用户指南。在下面的示例中,特征不允许相互作用。

from sklearn.datasets import load_diabetes
from sklearn.ensemble import HistGradientBoostingRegressor

X, y = load_diabetes(return_X_y=True, as_frame=True)

hist_no_interact = HistGradientBoostingRegressor(
    interaction_cst=[[i] for i in range(X.shape[1])], random_state=0
)
hist_no_interact.fit(X, y)
HistGradientBoostingRegressor(interaction_cst=[[0], [1], [2], [3], [4], [5],
                                               [6], [7], [8], [9]],
                              random_state=0)
在 Jupyter 环境中,请重新运行此单元格以显示 HTML 表示或信任笔记本。
在 GitHub 上,HTML 表示无法渲染,请尝试使用 nbviewer.org 加载此页面。


新增和增强的显示功能#

PredictionErrorDisplay 提供了一种定性分析回归模型的方法。

import matplotlib.pyplot as plt

from sklearn.metrics import PredictionErrorDisplay

fig, axs = plt.subplots(nrows=1, ncols=2, figsize=(12, 5))
_ = PredictionErrorDisplay.from_estimator(
    hist_no_interact, X, y, kind="actual_vs_predicted", ax=axs[0]
)
_ = PredictionErrorDisplay.from_estimator(
    hist_no_interact, X, y, kind="residual_vs_predicted", ax=axs[1]
)
plot release highlights 1 2 0

LearningCurveDisplay 现已可用,用于绘制 learning_curve 的结果。

from sklearn.model_selection import LearningCurveDisplay

_ = LearningCurveDisplay.from_estimator(
    hist_no_interact, X, y, cv=5, n_jobs=2, train_sizes=np.linspace(0.1, 1, 5)
)
plot release highlights 1 2 0

PartialDependenceDisplay 暴露了一个新参数 categorical_features,用于使用条形图和热力图显示类别特征的部分依赖关系。

from sklearn.datasets import fetch_openml

X, y = fetch_openml(
    "titanic", version=1, as_frame=True, return_X_y=True, parser="pandas"
)
X = X.select_dtypes(["number", "category"]).drop(columns=["body"])
from sklearn.pipeline import make_pipeline
from sklearn.preprocessing import OrdinalEncoder

categorical_features = ["pclass", "sex", "embarked"]
model = make_pipeline(
    ColumnTransformer(
        transformers=[("cat", OrdinalEncoder(), categorical_features)],
        remainder="passthrough",
    ),
    HistGradientBoostingRegressor(random_state=0),
).fit(X, y)
from sklearn.inspection import PartialDependenceDisplay

fig, ax = plt.subplots(figsize=(14, 4), constrained_layout=True)
_ = PartialDependenceDisplay.from_estimator(
    model,
    X,
    features=["age", "sex", ("pclass", "sex")],
    categorical_features=categorical_features,
    ax=ax,
)
plot release highlights 1 2 0

fetch_openml 中更快的解析器#

fetch_openml 现在支持一种新的 "pandas" 解析器,该解析器在内存和 CPU 效率方面更优。在 v1.4 中,默认值将更改为 parser="auto",这将自动对密集数据使用 "pandas" 解析器,对稀疏数据使用 "liac-arff"

X, y = fetch_openml(
    "titanic", version=1, as_frame=True, return_X_y=True, parser="pandas"
)
X.head()
pclass 姓名 性别 年龄 sibsp parch 船票 票价 客舱 登船港口 救生艇 遗体编号 家乡/目的地
0 1 艾伦小姐,伊丽莎白·沃尔顿 女性 29.0000 0 0 24160 211.3375 B5 S 2 NaN 密苏里州圣路易斯
1 1 艾利森少爷,哈德森·特雷弗 男性 0.9167 1 2 113781 151.5500 C22 C26 S 11 NaN 魁北克蒙特利尔 / 安大略切斯特维尔
2 1 艾利森小姐,海伦·洛雷恩 女性 2.0000 1 2 113781 151.5500 C22 C26 S NaN NaN 魁北克蒙特利尔 / 安大略切斯特维尔
3 1 艾利森先生,哈德森·约书亚·克莱顿 男性 30.0000 1 2 113781 151.5500 C22 C26 S NaN 135.0 魁北克蒙特利尔 / 安大略切斯特维尔
4 1 艾利森夫人,哈德森·J·C(贝西·瓦尔多·丹尼尔斯) 女性 25.0000 1 2 113781 151.5500 C22 C26 S NaN NaN 魁北克蒙特利尔 / 安大略切斯特维尔


LinearDiscriminantAnalysis 中对 Array API 的实验性支持#

LinearDiscriminantAnalysis 中增加了对 Array API 规范的实验性支持。该估计器现在可以在任何符合 Array API 规范的库上运行,例如 CuPy(一个 GPU 加速的数组库)。详细信息请参见用户指南

许多估计器的效率得到提升#

在 1.1 版本中,许多依赖于成对距离计算的估计器(主要是与聚类、流形学习和邻居搜索算法相关的估计器)对于 float64 密集输入的情况,效率得到了极大提升。效率的提升尤其体现在内存占用减少和在多核机器上更好的可伸缩性。在 1.2 版本中,这些估计器在 float32 和 float64 数据集上对密集和稀疏输入的所有组合(欧几里得距离和平方欧几里得距离度量的稀疏-密集和密集-稀疏组合除外)的效率得到了进一步提升。受影响估计器的详细列表可在更新日志中找到。

脚本总运行时间: (0 分 5.183 秒)

相关示例

scikit-learn 1.7 发布亮点

scikit-learn 1.7 发布亮点

scikit-learn 1.4 发布亮点

scikit-learn 1.4 发布亮点

引入 set_output API

引入 set_output API

scikit-learn 0.22 发布亮点

scikit-learn 0.22 发布亮点

画廊由 Sphinx-Gallery 生成