Python Scikit-learn简介(二)

devtools/2024/11/27 0:25:54/

数据处理

数据划分

机器学习的数据,可以划分为训练集、验证集和测试集,也可以划分为训练集和测试集。
在这里插入图片描述

python">from sklearn.model_selection import train_test_split# 示例数据
X = [[1, 2], [3, 4], [5, 6], [7, 8]]
y = [0, 1, 0, 1]# 划分数据集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25, random_state=42)print("Training data:", X_train, y_train)
print("Testing data:", X_test, y_test)
数据清洗

数据清洗是数据预处理的第一步,涉及处理缺失值、重复数据、异常值等。

python">import pandas as pd# 创建一个包含缺失值和重复数据的DataFrame
data = pd.DataFrame({'A': [1, 2, np.nan, 4],'B': [5, 5, 7, 8],'C': [9, 10, 11, 12]
})# 删除重复行
data = data.drop_duplicates()# 填充缺失值
data = data.fillna(data.mean())print(data)
特征提取与转换

特征提取是将原始数据转换为更适合机器学习模型的特征表示。Scikit-learn提供了多种特征提取工具,如DictVectorizer用于处理字典数据,CountVectorizer用于文本数据的词频统计。

python">from sklearn.feature_extraction.text import CountVectorizer# 示例文本数据
text_data = ["hello world", "hello everyone", "world of programming"]# 初始化CountVectorizer
vectorizer = CountVectorizer()# 转换文本数据为词频矩阵
X = vectorizer.fit_transform(text_data)print(X.toarray())
标准化与归一化

标准化和归一化是调整特征尺度的重要步骤,有助于提高某些算法的性能。

python">from sklearn.preprocessing import StandardScaler, MinMaxScaler# 示例数据
data = [[1, 2], [2, 3], [3, 4]]# 标准化
scaler = StandardScaler()
standardized_data = scaler.fit_transform(data)# 归一化
min_max_scaler = MinMaxScaler()
normalized_data = min_max_scaler.fit_transform(data)print("Standardized data:", standardized_data)
print("Normalized data:", normalized_data)
缺失值处理

处理缺失值是数据预处理中的常见任务。Scikit-learn提供了SimpleImputer来填充缺失值。

python">from sklearn.impute import SimpleImputer# 示例数据
data = [[1, 2], [np.nan, 3], [7, 6]]# 初始化SimpleImputer,使用均值填充
imputer = SimpleImputer(strategy='mean')# 填充缺失值
imputed_data = imputer.fit_transform(data)print(imputed_data)
特征选择

在这里插入图片描述

监督学习算法

在这里插入图片描述
在这里插入图片描述

  • 线性模型
    • 线性模型是监督学习中最基础的模型之一,它假设特征之间的关系可以用一条直线(对于二元分类)或超平面(对于多类分类)来表示。线性模型主要包括线性回归(用于连续目标变量)和逻辑回归(用于分类目标变量)
  • 支持向量机
    • 支持向量机(Support Vector Machine, SVM)是一种强大的监督学习算法,适用于分类和回归分析。在分类问题中,SVM旨在找到一个超平面,该超平面能够最大化不同类别之间的边际。
    • Scikit-learn提供了多种SVM实现,包括线性SVM和核SVM。线性SVM适用于线性可分数据,而核SVM通过使用核技巧,可以处理非线性可分数据。
  • 决策树
    • 决策树通过一系列的判断规则对数据进行分类,而随机森林是决策树的集成学习方法,通过构建多个决策树并进行投票来提高预测的准确性。
  • 随机森林
    • 随机森林是决策树的集成学习方法,通过构建多个决策树并进行投票来提高预测的准确性。
  • 集成学习方法
    • 监督学习中的梯度提升机(Gradient Boosting)是一种强大的集成学习算法,它通过迭代地训练决策树来最小化损失函数,从而提高模型的预测性能。Scikit-learn提供了一个名为GradientBoostingClassifier的类,用于实现梯度提升机。

无监督学习算法

在这里插入图片描述

  • 聚类分析
    • 聚类分析是将数据集中的样本分成多个组或簇的过程,使得同一簇内的样本相似度高,不同簇间的样本相似度低。K-Means是最常用的聚类算法之一。
  • 主成分分析(PCA)
    • 主成分分析(PCA)是一种用于降维的技术,它通过线性变换将数据投影到新的坐标系中,使得投影后的数据具有最大的方差。
  • 奇异值分解(SVD)
    • 奇异值分解(SVD)是一种矩阵分解技术,常用于降维和数据压缩。
  • 关联规则学习
    • 关联规则学习用于发现数据集中变量之间的有趣关系,如购物篮分析中的“啤酒与尿布”现象。Apriori算法是常用的关联规则学习算法之一。

http://www.ppmy.cn/devtools/137257.html

相关文章

全面解析多种mfc140u.dll丢失的解决方法,五种方法详细解决

当你满心期待地打开某个常用软件,却突然弹出一个错误框,提示“mfc140u.dll丢失”,那一刻,你的好心情可能瞬间消失。这种情况在很多电脑用户的使用过程中都可能出现。无论是游戏玩家还是办公族,面对这个问题都可能不知所…

Android opencv使用Core.hconcat 进行图像拼接

Android 集成OpenCV-CSDN博客 import org.opencv.android.Utils; import org.opencv.core.Core; import org.opencv.core.CvType; import org.opencv.core.Mat; import org.opencv.imgcodecs.Imgcodecs; import android.graphics.Bitmap; import android.graphics.BitmapFactor…

【论文解析】HAQ: Hardware-Aware Automated Quantization With Mixed Precision

作者及发刊详情 inproceedings{haq, author {Wang, Kuan and Liu, Zhijian and Lin, Yujun and Lin, Ji and Han, Song}, title {HAQ: Hardware-Aware Automated Quantization With Mixed Precision}, booktitle {IEEE Conference on Computer Vision and Pattern Recognit…

基于FPGA的2FSK调制-串口收发-带tb仿真文件-实际上板验证成功

基于FPGA的2FSK调制 前言一、2FSK储备知识二、代码分析1.模块分析2.波形分析 总结 前言 设计实现连续相位 2FSK 调制器,2FSK 的两个频率为:fI15KHz,f23KHz,波特率为 1500 bps,比特0映射为f 载波,比特1映射为 载波。 1&#xff09…

大学课程项目中的记忆深刻 Bug —— 一次意外的数组越界

开头 在编程的世界里,每一行代码都像是一个小小的宇宙,承载着开发者的心血与智慧。然而,即便是最精心编写的代码,也难免会遇到那些突如其来的 bug,它们就像是潜伏在暗处的小怪兽,时不时跳出来捣乱。 在我…

云服务器部署WebSocket项目

WebSocket是一种在单个TCP连接上进行全双工通信的协议,其设计的目的是在Web浏览器和Web服务器之间进行实时通信(实时Web) WebSocket协议的优点包括: 1. 更高效的网络利用率:与HTTP相比,WebSocket的握手只…

Web开发:ABP框架7——前端请求头的读取

一、前端请求头的读取 1.注入 高层代码使用注入,IHttpContextAccessor 是 ASP.NET Core 中的一个接口,用于在服务层中获取与当前 HTTP 请求相关的信息,比如请求的头部、Cookie、用户身份等。 private readonly IHttpContextAccessor _http…

性能监控利器:Ubuntu 22.04 上的 Zabbix 安装与配置指南

简介 今天我们来聊聊如何在 Ubuntu 22.04 上安装和配置 Zabbix。我们会用到 PostgreSQL 作为数据库后端,Nginx 作为 Web 服务器,并用 Let’s Encrypt SSL 证书来保驾护航。 什么是 Zabbix? Zabbix 是一个开源的网络监控和管理解决方案&…