Python数据科学:Scikit-Learn机器学习

4.1Scikit-Learn机器学习

Scikit-Learn使用的数据表示:二维网格数据表

实例1:通过Seaborn导入数据

def skLearn():'''scikit Learn基本介绍:return:'''import seaborn as sns#导入Iris数据集#注:一般网络访问不了iris = sns.load_dataset('iris')iris.head()

实例2:通过本地导入数据

def skLearn1():'''本地导入csv数据:return:'''df_iris = pd.read_csv('./data/Iris.csv')print(df_iris.head())

鸢尾花数据集说明:

sepal_length:萼片长度

sepal_width:萼片宽度

petal_length:花瓣长度

petal_width:花瓣宽度

species:鸢尾花类型,Iris-setosa(山鸢尾),Iris-versicolor(变色鸢尾),Iris-virginica(维吉尼亚鸢尾)

df_iris.head()

样本:鸢尾花数据集矩阵,矩阵的行n_samples;

特征:某些数据参数的列称为特征,特征列数n_features,鸢尾花数据集需要去掉species列;

特征矩阵:数据集的特征列矩阵,一般用X表示。维度为[n_samples,n_features]。

目标数组:一个标签或目标数组,一般为一维数组,一般用y表示。长度为n_samples。

实例3:构建特征矩阵,目标数组

def skLearn1():'''本地导入csv数据:return:'''df_iris = pd.read_csv('./data/Iris.csv')print(df_iris.head())#获取数据集行列print(df_iris.shape)#构建特征矩阵X_iris = df_iris.drop('species',axis=1)#构建目标数组y_iris = df_iris['species']#使用seaborn绘制图片sns.set()sns.pairplot(df_iris,hue='species',height=1.5)plt.show()

通过sns.pairplot绘制不同特征值相关性图。

对角线上是单一特征值之间,不同鸢尾花种类在该特征值上数据的重叠程度。

Scikit-Learn的评估器API:

  1. 通过Scikit-Learn中导入合适的评估器类,选择模型类;
  2. 选择合适数值对模型类实例化;
  3. 整理数据,获取特征矩阵,目标数组;
  4. 调用模型fit()方法,对数据进行拟合
  5. 对新的数据应用模型:有监督学习模型中使用predict()方法,无监督学习使用transform()或predict()方法。

实例4:构建机器学习有监督学习模型,对鸢尾花进行识别

def skLearn2():'''有监督学习,鸢尾花分类:return:'''#读取数据df_iris = pd.read_csv('./data/Iris.csv')#构建特征矩阵X_iris = df_iris.drop('species',axis=1)#构建目标数组y_iris = df_iris['species']#划分训练集,测试集from sklearn.model_selection import train_test_splitXtrain,Xtest,ytrain,ytest = train_test_split(X_iris,y_iris,random_state=1)#选择模型#高斯朴素贝叶斯from sklearn.naive_bayes import GaussianNBmodel = GaussianNB()#训练模型model.fit(Xtrain,ytrain)#使用模型对数据进行预测y_model = model.predict(Xtest)#如何验证y_model数据准确性?#和实际的数据进行比较,确定模型预测准确率from sklearn.metrics import accuracy_score#ytest:实际数据#y_model:模型预测数据print(accuracy_score(ytest,y_model))

实例5:无监督学习,鸢尾花数据降维

鸢尾花数据集有四个特征维度,对数据进行降维,保留数据的本质特征,用低维度矩阵表示高维数据。

def skLearn3():'''无监督学习,鸢尾花数据降维:return:'''#读取数据df_iris = pd.read_csv('./data/Iris.csv')#构建特征矩阵X_iris = df_iris.drop('species',axis=1)#构建目标数组y_iris = df_iris['species']#选择模型#主成分分析PCA,快速线性降维from sklearn.decomposition import PCA#设置超参数model = PCA(n_components=2)#拟合数据model.fit(X_iris)#将数据转换为二维数据X_2d = model.transform(X_iris)#将数据插入原数据df_iris['PCA1'] = X_2d[:,0]df_iris['PCA2'] = X_2d[:,1]print(df_iris)#sns绘制二维数据投影图sns.lmplot("PCA1","PCA2",hue='species',data=df_iris,fit_reg=False)plt.show()

实例6:无监督学习,对鸢尾花数据进行聚类分析

def skLearn4():'''无监督学习,在降维后数据基础上,聚类分析高斯混合模型:return:'''#读取数据df_iris = pd.read_csv('./data/Iris.csv')#构建特征矩阵X_iris = df_iris.drop('species',axis=1)#构建目标数组y_iris = df_iris['species']#选择模型#主成分分析PCA,快速线性降维from sklearn.decomposition import PCA#设置超参数model_pca = PCA(n_components=2)#拟合数据model_pca.fit(X_iris)#将数据转换为二维数据X_2d = model_pca.transform(X_iris)#将数据插入原数据df_iris['PCA1'] = X_2d[:,0]df_iris['PCA2'] = X_2d[:,1]#选择模型#高斯混合模型GMMfrom sklearn.mixture import GaussianMixture#设置超参数model = GaussianMixture(n_components=3,covariance_type='full')#拟合数据model.fit(X_iris)#预测数据y_model = model.predict(X_iris)#将预测数据放入原数据df_iris['y_gmm'] = y_model#绘制图片sns.lmplot("PCA1","PCA2",data=df_iris,hue='species',col='y_gmm',fit_reg=False)plt.show()

实例7:手写数字识别

步骤1:获取手写数字集,查看数据

def skLearn5():'''手写数字探索:return:'''#加载手写数字集from sklearn.datasets import load_digitsdigits = load_digits()#(1798,8,8)#一共1798个样本,8x8的像素print(digits.images.shape)#绘制手写数据图fig,axes = plt.subplots(10,10,figsize=(8,8))for i,ax in enumerate(axes.flat):#显示图片手写数字ax.imshow(digits.images[i],cmap='binary',interpolation='nearest')#显示目标数字ax.text(0.05,0.05,str(digits.target[i]),transform=ax.transAxes,color='blue')

步骤2:将数据进行降维处理,查看降维后数据。可以发现还是有许多数字之间是重叠的。

#8x8矩阵相当于64个特征值#获取特征矩阵X_digits = digits.data#获取目标列y_digits = digits.target#64维的特征值进行降维处理,流形学习算法from sklearn.manifold import Isomap#降到二维iso = Isomap(n_components=2)#拟合数据iso.fit(X_digits)#获取转换后的数据X_trans = iso.transform(X_digits)#显示二维数据plt.scatter(X_trans[:,0],X_trans[:,1],c=y_digits,edgecolor='none',alpha=0.6,cmap=plt.cm.get_cmap('rainbow',10))plt.colorbar(label='digit label',ticks=range(10))

步骤3:使用高斯朴素贝叶斯模型训练识别模型。使用混淆矩阵判断模型识别效果

#训练模型,数字识别#划分训练集,测试集from sklearn.model_selection import train_test_splitXtrain,Xtest,ytrain,ytest = train_test_split(X_trans,y_digits,random_state=0)#使用模型from sklearn.naive_bayes import GaussianNBmodel = GaussianNB()#训练数据model.fit(Xtrain,ytrain)#预测测试数据y_model = model.predict(Xtest)#获取识别准确率from sklearn.metrics import accuracy_score#识别率有70*print(accuracy_score(ytest,y_model))#如何知道模型识别的不足?#使用混淆矩阵from sklearn.metrics import confusion_matrixmat = confusion_matrix(ytest,y_model)print(mat)#绘制热力图sns.heatmap(mat,square=True,annot=True,cbar=False)plt.xlabel('predict value')plt.ylabel('true value')

从图像可以看出,识别数字2时,许多识别成了7或者1;识别5时,也识别错误成其他数字

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/682465.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

助眠神器小程序源码|白噪音|小睡眠|微信小程序前后端开源

安装要求和说明后端程序运行环境:NginxPHP7.4MySQL5.6 PHP程序扩展安装:sg11 网站运行目录设置为:public 伪静态规则选择:thinkphp 数据库修改文件路径:/config/database.php需要配置后端的小程序配置文件,…

[word] word分割线在哪里设置 #其他#经验分享

word分割线在哪里设置 在工作中有些技巧,可以快速提高工作效率,解决大部分工作,今天给大家分享word分割线在哪里设置的小技能,希望可以帮助到你。 1、快速输入分割线 输入三个【_】按下回车就是一条长直线,同样分别…

webgis后端安卓系统部署攻略,超详细Termux攻略

目录 前言 一、将后端项目编译ARM64 二、安卓手机安装termux 1.更换为国内源 2.安装ssh远程访问 3.安装文件远程访问 三、安装postgis数据库 1.安装数据库 2.数据库配置 3.数据导入 四、后端项目部署 五、自启动设置 总结 前言 因为之前一直做的H5APP开发&#xf…

webpack面试解析

参考: 上一篇webpack相关的系列:webpack深入学习,搭建和优化react项目 爪哇教育字节面试官解析webpack-路白 1、Webpack中的module是什么? 通常来讲,一个 module 模块就是指一个文件中导出的内容,webpack…

Amber-Leedcode-Java - 代码随想录打卡第38 - 39天-动态规划汇总

本质上感觉是一个相加的问题,状态的转换,由前一种状态推至下一种状态509. 斐波那契数 较为简单 746. 使用最小花费爬楼梯 62. 不同路径 一开始写的时候被吓到了,但是发现听完一半之后再写还是比较容易的 对于我而言主要是找到逻辑&#xf…

Vue3+Ant-Design-Vue:报错Cannot read properties of null (reading ‘isCE‘)

问题描述 在使用Ant-Design-Vue内置的Table表格组件,实现expand展开行功能时,报错:Uncaught TypeError: Cannot read properties of null (reading ‘isCE‘) 。 报错信息图示: 在GitHub上找到如下描述, 解决方案 网上…

【漏洞复现】和为顺IP-COM WiFi未授权下载漏洞

Nx01 产品简介 深圳市和为顺网络技术有限公司是一家聚焦于商用级网络通信设备的研发与应用,为全球中小型企业提供高速、安全、易维护的网络设备产品和解决方案的公司。 Nx02 漏洞描述 深圳市和为顺网络技术有限公司IP-COM WiFi方案解决专家存在任意文件下载漏洞&am…

springsecurity6使用

spring security 中的类 : AuthenticationManager : 实现类:ProviderManager 管理很多的 provider ,,, 经常使用的,DaoAuthenticationProvider , 这个要设置一个 UserDetailService , 查找数据库&#xff…

分享88个CSS3特效,总有一款适合您

分享88个CSS3特效,总有一款适合您 88个CSS3特效下载链接:https://pan.baidu.com/s/1pDAyFESnO8HSnCZj4-DOzQ?pwd8888 提取码:8888 Python采集代码下载链接:采集代码.zip - 蓝奏云 学习知识费力气,收集整理更不…

第13章 网络 Page724 asio定时器

程序代码: 11行,声明一个ios对象 13行,使用ios对象作为参数声明一个定时器,此时,定时器和ios完成了关联,后面定时器如果有任务的话,就可以将任务交给ios 16行,为定时器设置一个定…

【日常聊聊】新年新征程:迎接学习的挑战

🍎个人博客:个人主页 🏆个人专栏:日常聊聊 ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 结语 我的其他博客 前言 随着新的一年的到来,程序员们站在了全新的起点。这是一个充满机遇和挑战的时刻&#xff0…

【JavaEE】_HTTP请求与响应

目录 1. HTTP协议 1.1 HTTP简介 1.2 Fiddler 2. HTTP请求 2.1 首行 2.2 请求头(header) 2.3 空行 2.4 正文(body) 3. HTTP响应 3.1 首行 3.2 响应头(header) 3.3 空行 3.4 正文(bo…

51单片机编程基础(C语言):LED点阵屏

点阵屏介绍 类似于数码管,要用到肉眼视觉效应。扫描,才能把每一个LED都能选中,从而显示我们想要的图形,否则, 只能一次点亮一个LED, LED使用 51单片机点阵屏电路图: 实际连接顺序如下图&#…

爱快使用VPN

文章目录 一、VPN服务器1. 各种VPN比较2. PPTP服务端配置3. 创建登录账号4. 创建端口映射5. 设置动态域名 二、Windows客户端1. 连接配置2. 不能连接 Internet 配置 一、VPN服务器 1. 各种VPN比较 PPTPIPSECOpenVPN简介微软推出的VPN协议,占用资源少更高级的VPN协…

php基础学习之分支结构和循环结构(不细讲,来对比一下和两大常用高级编程语言(C++/Java)的细微区别以便记忆)

分支结构 常见分支结构 编程语言常见分支结构有: if语句if-else语句if-elseif-else语句switch语句 其中,除了if-elseif-else语句外,另外3中分支语句在php中和C/Java是一模一样的! 而if-elseif-else的唯一不同点就在,【…

Linux查看日志的几种方法总结

摘要 Linux系统中查看日志的命令确实多种多样,每个命令都有其特定的用途和优势。常用的命令有:tail、cat、tac、head、echo,grep、less、awk、sed。 下面我会详细解释这些命令在查看日志时的用法和特点: tail命令: ta…

机器学习:ROC曲线笔记

ROC曲线(Receiver Operating Characteristic Curve)是一种用于评估二分类模型性能的图形化工具,主要用于展示在不同阈值(Threshold)下模型的真阳性率(True Positive Rate,TPR)和假阳…

寒假作业:2024/2/14

作业1&#xff1a;编程实现二维数组的杨辉三角 代码&#xff1a; #include <stdio.h> #include <string.h> #include <stdlib.h> int main(int argc, const char *argv[]) {int n;printf("please enter n:");scanf("%d",&n);int a…

Redis核心技术与实战【学习笔记】 - 31.番外篇:Redis客户端如何与服务器端交换命令和数据

简述 Redis 使用 RESP 协议&#xff08;Redis Serialzation Protocol&#xff09;协议定义了客户端和服务器端交互的命令、数据的编码格式。在 Redis 2.0 版本中&#xff0c;RESP 协议正式称为客户端和服务器端的标准通信协议。从 Redis 2.0 到 Redis 5.0 &#xff0c;RESP 协…

leetcode:55.跳跃游戏

1.解题思路&#xff1a;贪心算法看最大覆盖范围 2.模拟过程&#xff1a; 1.若数组长度等于1&#xff0c;直接返回True 2.循环遍历覆盖范围&#xff0c;选取最大的覆盖范围&#xff1b;若覆盖范围覆盖到了最后一个元素&#xff0c;直接返回true. 3.代码&#xff1a;(贪心无套…