python编程:如何使用python代码绘制出哪些常见的机器学习图像?
off999 2025-08-03 07:30 106 浏览 0 评论
专栏推荐
绘图的变量
单变量
查看单变量最方便的无疑是displot()函数,默认绘制一个直方图,并你核密度估计(KDE)
sns.set(color_codes=True)
np.random.seed(sum(ord,"distributions"))
x=np.random.gamma(6,size=200)z这个是伽马函数,表示生成200个,以列表形式返回
sns.displot(x,kde=False,fit=stats.gamma)
Scipy的stats模块包含了多种概率分布的随机变量,gamma是连续分布的相关函数
双变量
双变量使用散点图,描述特征和特征之间的关系
mean,cov=[0,1],[(1,5),(5,1)]均值和协方差
data=np.random.multivariate_normal(mean,cov,200)
df=pd.DataFrame(data,colums=["x","y"])
sns.jointplot(x="x",y="y",data=df)
这样df中第一个维度是x,第二个维度是y
jointplot函数创建一个多面板数字,显示两个变量之间的双变量关系,及每个变量的单变量分布
上面的joinplot函数中还可以增加以下参数,kind="hex"这样的图叫做hex图,这回将数据多的地方加深,适用于数据较大的数据集,kind=“kde”是表示使用等高线显示核密度
上面是双变量,这样可以两个结合在一起,如果是多变量呢?
假如是四个变量,其实也可以两个结合在一起,可以使用pairplot函数
sns.set(color_codes=True)
iris=sns.load_dataset("iris")数据集的四个特征
sns.pairplot(iris)pairplot会将四个特征进行两两结合
第四个:线性关系可视化,回归绘图分析
sns.set(color_code=True)
np.random.seed(sum(map(ord,"regression")))
tips=sns.load_dataset("tips")
sns.regplot(x="total_bill",y="tip",data=tips)
plt.show()
这个程序会画出total_bill和tip之间的线性回归模型,就是最符合他们之间关系的那一条线
许多数据集包含多个定量和变量分析的目的是将这些变量相互关联起来,使用整个统计模型来估计两个噪声组之间的简单关系是很有帮助的,reglot()和lmplot()
两者的区别:
在regplot()函数中通过只传入x和y绘出:sns.regplot(x=tips["total_bill"], y=tips["tip"]);而相应的sns.lmplot(x=tips["total_bill"], y=tips["tip"])这种写法就会报错,因为数据集data是lmplot()的必传参数。
另一个主要区别是regplot()以各种格式接受x和y变量,包括numpy数组、Pandas的Series列或DataFrame对象的变量引用;不一样的是,lmplot()将数据集作为一个必需的参数,而x和y变量必须指定为字符串。这种数据格式称为“长格式”或“整洁”数据。
这里其实还有很多的内容,但是这里就不具体展开了
第五个:分类关系的可视化
散点图和回归模型适合连续的数据,但是当数据是离散的时候就没有意义了,这个时候不要使用回归模型来,那么处理分类数据的问题,非常实用的方法是将Seaborn的分类图分为三类
第一个包括函数swarmplot()和stripplot()
第二个包括函数boxplot()和violinplot()
第三个包括函数barplot()和pointplt()
显示分类变量级别中某些定量变量的值的一种简单方法使用stripplot(),它会将分散图概括为其中一个变量是分类的:
sns.stripplot(x="day", y="total_bill", data=tips);
效果为:
因为day是离散的所以可以看出所有的数据都在这一条线上,这样很多数据都重叠了,这样的数据是意义不大的额,为了解决这个问题,可以有以下几种方式:
方式一:抖动
sns.stripplot(x="day", y="total_bill", data=tips, jitter=True);
方式二swarmplot
sns.swarmplot(x="day", y="total_bill", data=tips);
上面的分类散点图固然简单实用,但在某些特定的的情况下,他们可以提供的值的分布信息会变得及其有限。 有几种方式可以方便的解决这个问题,在类别之间进行简单比较并汇总信息,我们快速讨论并比较一些适合这类数据观测的函数。
画盒图
sns.boxplot(x="day", y="total_bill", hue="time", data=tips);
提琴图violinplot(),它结合了箱体图和核心密度估计过程:
sns.violinplot(x="total_bill", y="day", hue="time", data=tips);
这种方法使用核密度估计来更好地描述值的分布,当色调参数只有两个级别时,也可以传入参数split至violinplot(),这样可以更有效地利用空间:
sns.violinplot(x="day", y="total_bill", hue="sex", data=tips, split=True);
你会发现盒图和小提琴的优势就是每个类别中数据集中的地方会变胖,如果,不是显示每个类别中的分布,你可能希望显示值的集中趋势,可以用下面的图
条形图
在Seaborn中barplot()函数在完整数据集上运行,并显示任意估计,默认情况下使用均值
sns.barplot(x="sex", y="survived", hue="class", data=titanic);
效果为:
条形图的特殊情况是当想要显示每个类别中的观察次数,而不是计算第二个变量的统计量。这类似于分类而不是定量变量的直方图。在Seaborn中,使用countplot()函数很容易绘制,函数将默认使用count参数作为x/y中未传的一组维度
sns.countplot(x="deck", data=titanic, palette="Greens_d");
点图
pointplot()函数提供了可视化相同信息的另一种风格。该函数还对另一轴的高度估计值进行编码,而不是显示一个完整的柱型,它只绘制点估计和置信区间。另外,点图连接相同hue类别的点。这使得很容易看出主要关系如何随着第二个变量的变化而变化,斜率的差异会很明显:
sns.pointplot(x="sex", y="survived", hue="class", data=titanic);
至此我们就将第五个:分类关系的可视化的主要几个画图方法总结完了,总的来说使用不难,就是在什么情况下使用哪个才是关键,在Seaborn中绘制分类图可以使用上面的几种方式,还有一种方式比较强大,那就是更高级别的函数factorplot(),将这些函数与FacetGrid()相结合,通过这个图形的更大的结构来增加展示其他类别的能力。
seaborn.factorplot(x=None, y=None, hue=None, data=None, row=None, col=None, col_wrap=None, estimator=<function mean>, ci=95, n_boot=1000, units=None, order=None, hue_order=None, row_order=None, col_order=None, kind='point', size=4, aspect=1, orient=None, color=None, palette=None, legend=True, legend_out=True, sharex=True, sharey=True, margin_titles=False, facet_kws=None, **kwargs)
x,y,hue 数据集变量 变量名
date 数据集 数据集名
row,col 更多分类变量进行平铺显示 变量名
col_wrap 每行的最高平铺数 整数
estimator 在每个分类中进行矢量到标量的映射 矢量
ci 置信区间 浮点数或
Nonen_boot 计算置信区间时使用的引导迭代次数 整数
units 采样单元的标识符,用于执行多级引导和重复测量设计 数据变量或向量数据
order, hue_order 对应排序列表 字符串列表
row_order, col_order 对应排序列表 字符串列表
kind : 可选:point 默认, bar 柱形图, count 频次, box 箱体, violin 提琴, strip 散点,swarm 分散点(具体图形参考文章前部的分类介绍)
size 每个面的高度(英寸) 标量
aspect 纵横比 标量
orient 方向 "v"/"h"
color 颜色
matplotlib颜色
palette 调色板
seaborn颜色色板或字典
legend hue的信息面板
True/Falselegend_out 是否扩展图形,并将信息框绘制在中心右边
True/Falseshare{x,y} 共享轴线
True/Falsefacet_kws FacetGrid的其他参数 字典
默认情况下,factorplot()产生一个pairplot():
pairplot是一个折现图,但是类似点图
sns.factorplot(x="day", y="total_bill", hue="smoker", data=tips);
我们可以使用kind参数来指定要画什么图:
kind=“bar”
kind=“swarm”
kind=“box”
除了可以指定要来画什么图之外还有一个强大的功能就是对数据展开更多其他分类变量:,比如参数col="time"
基于FacetGrid的工作原理,要更改图形的大小和形状,需要指定适用于每个方面的size和aspect参数:
sns.factorplot(x="time", y="total_bill", hue="smoker",col="day", data=tips, kind="box", size=4, aspect=.5);
用FacetGrid子集数据
当您想要在数据集的子集内可视化变量的分布或多个变量之间的关系时,FacetGrid类很有用。 FacetGrid可以绘制最多三个维度:row,col和hue。前两者与所得轴数有明显的对应关系;将hue变量视为沿着深度轴的第三维,其中不同的级别用不同的颜色绘制。
通过使用数据框初始化FacetGrid对象和将形成网格的行,列或色调维度的变量的名称来使用该类。 这些变量应该是分类的或离散的,然后变量的每个级别的数据将用于沿该轴的小平面。
tips = sns.load_dataset("tips")加载这个tips的数据
g = sns.FacetGrid(tips, col="time")对数据展示time
到目前为止的效果是这样的 ,还没有绘制任何东西
可视化数据的主要方法是使用FacetGrid.map()方法,提供一个绘图功能和数据框中变量的名称来绘制
g.map(plt.hist, "tip");这个就表示在上面的两个图中绘制tip,然后图为直方图,效果为:
至此就画完了,但是这个只是在time基础上绘制tip,tip并没有和其它的变量产生关系,所以直方图是最好的,但是多个变量的时候,应该是散点图才是最好的额,
g = sns.FacetGrid(tips, col="sex", hue="smoker")
g.map(plt.scatter, "total_bill", "tip", alpha=.7)
g.add_legend();
这个程序中col和hue都指定了,核心的散点图的关系还是tip和total_bill之间的额关系
效果就是上面的模样,有几个选项可以控制可以传递给类构造函数的网格的外观。
g = sns.FacetGrid(tips, row="smoker", col="time", margin_titles=True)
g.map(sns.regplot, "size", "total_bill", color=".3", fit_reg=False, x_jitter=.1);
用PairGrid绘制成对的关系
该类的基本用法与FacetGrid非常相似。首先初始化网格,然后将绘图函数传递给map方法,并在每个子图上调用它。
iris = sns.load_dataset("iris")
g = sns.PairGrid(iris)
g.map(plt.scatter);
g = sns.PairGrid(iris)是iris中的变量两两结合
g.map(plt.scatter);然后画出散点图
相关推荐
- 安全教育登录入口平台(安全教育登录入口平台官网)
-
122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...
- 大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)
-
大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...
-
- 哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
-
要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...
-
2026-02-04 09:03 off999
- 电信宽带测速官网入口(电信宽带测速官网入口app)
-
这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...
- 植物大战僵尸95版手机下载(植物大战僵尸95 版下载)
-
1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...
- 免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)
-
1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...
- 2025世界杯赛程表(2025世界杯在哪个国家)
-
2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...
- 下载搜狐视频电视剧(搜狐电视剧下载安装)
-
搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...
- 永久免费听歌网站(丫丫音乐网)
-
可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...
- 音乐格式转换mp3软件(音乐格式转换器免费版)
-
有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...
- 电子书txt下载(免费的最全的小说阅读器)
-
1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...
- 最好免费观看高清电影(播放免费的最好看的电影)
-
在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...
- 孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)
-
要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
win7系统还原步骤图解(win7还原电脑系统的步骤)
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
16949认证费用是多少(16949审核员太难考了)
-
linux软件(linux软件图标)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
windows7旗舰版多少钱(win7旗舰版要多少钱)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
