sklearn.pipeline的用法介绍

sklearn.pipeline可以将多个数据预处理步骤和机器学习模型组合,成一个整体,从而简化了机器学习的流程。 sklearn.pipeline类可以将多个算法模型串联起来,比如将特征提取、归一化、分类组织在一起形成一个典型的机器学习问题工作流,主要带来两点好处:

  • 1.直接调用 fit 和 predict 方法来对pipeine中的所有算法模型进行训练和预测。
  • 2.可以结合gid search对参数进行选择,具体而言,Pipeline 实现了对全部步骤的流式化封装和管理,可以很方便地使参数集在新数据集(比如测试集)上被重复使用。

下面是一个简单的例子,展示了如何使用 Pipelne 对训练集和测试集进行如下操作: 先用 Siandardscaler对数据集每一列做标准化处理(是transfomer),再用PCA将原始的30维度特征压缩到2维度, 最后再用模型,LogisticRegression(是Estimator)。

调用Pipeline时,输入中元组构成的列表,每个元组第一个值为变量名,元组第二个元素是sklearn中的transfomer或Esimator,注意中间每一步是transformer,即它们必须包含fittransfomr方法,或者ft_tansform,最后一步是个Estimator,即最后一步模型要有fit方法,可以没有transform方法.

python 复制代码
from sklearn.preprocessing import Standardscalerfrom sklearn.decomposition import PCA
from sklearn.linear model import LogisticRegression
from sklearn.pipeline import Pipeline

pipe_lr= Pipeline([
	('sc',standardscaler()),
	('pca',PCA(n_components=2)),
	('clf',LogisticRegression(random state=1))
	])
pipe_lr.fit(x_train, y_train)
print('Test accuracy:%.3f'% pipe_lr.score(x test, y_test))
相关推荐
henry1010108 分钟前
Ansible自动化运维全攻略(AI生成)
linux·运维·python·ansible·devops
逻辑君10 分钟前
根与星辰【第2章】
人工智能·程序人生
施法老农13 分钟前
openclaw和opencode组合使用
人工智能
2501_9269783316 分钟前
提高认知的位置---存在、认知、程序的逻辑位置
人工智能·经验分享
AI袋鼠帝17 分钟前
豆包2.0来了!中国版Trae免费用~
人工智能·ai编程·豆包marscode
沪漂阿龙25 分钟前
LLM底层机制深度解析:从Transformer到推理优化的完整技术地图
人工智能·深度学习·transformer
weixin_4404016937 分钟前
Python数据分析(空值、重复值检测删除与设置)
开发语言·python·数据分析
无忧智库39 分钟前
某低空经济示范区“十五五”通感一体化低空智联网与飞行服务保障体系建设方案深度解析(WORD)
人工智能
袁气满满~_~43 分钟前
深度学习笔记五
人工智能·深度学习