【R语言】描述性数据分析与数据可视化

我们处理的变量可以分为两类,一类是连续型变量,另一类叫做分类型变量,其中对于连续型变量,如果服从正态分布就用平均值填充NA,不服从正态分布就用中位数填充NA,对于分类型变量,不管是有序的(比如一年级,二年级)还是无序的(比如男性,女性)都是用众数来填补NA。

分类型变量的描述性数据分析

对于分类型变量,我们只需要关心每一类变量有多少个以及他的众数,使用的函数为table(变量),table函数的基本语法为

table(..., useNA = "always", exclude = NULL)

  • ...:一个或多个向量,表示要创建频率表的分类变量。可以是因子(factor)、逻辑(logical)或整数(integer)类型。
  • useNA:指定如何处理NA值。默认always,表示总是将NA作为一个类别包括在内。如果设置为no,则不包括NA值。
  • exclude:指定要排除的类别。

包含了分类变量中每种类别的名字和其对应的频数。

假如有一个名为mydata的数据框如图所示

运行代码table(mydata$性别)就可以得到男女各有多少人了,table函数的返回结果为分类变量中每种类别的名字和对应的频数

要找查分类变量中的众数,可以借助which.max函数,运行代码

which.max(table(mydata$性别)),结果如图

which.max用于返回变量中最大值出现位置的下标,而max函数用于返回最大值。基本语法为which.max(..., arr.ind = FALSE, useNames = TRUE)

  • ...:一个或多个数值型向量,从中找出最大值的索引。
  • arr.ind:逻辑值,指定是否返回数组索引。默认为FALSE。
  • useNames:逻辑值,指定是否使用变量名作为返回值的一部分。默认TRUE。可以看到上面的例子中确实返回了变量名。

连续型变量的描述性数据分析

R语言描述统计操作的函数有:summary函数,describe函数等

summary函数

这个函数用于对连续型变量做一个整体的概述,比如数据框mydata如图所示

运行代码summary(mydata)结果如图

对于连续型变量summary给出了这个变量的最大最小值,中位数平均数等等信息,对于分类型变量则给出了各种类型有多少个。因此调用summary函数即可让我们对一组数据具有一个整体的了解。但是使用summary得到的结果很难转换成数据框或者矩阵这样的表格,因此再进行描述性统计分析的时候推荐使用describe函数。

describe函数

这个函数来自于R包: psych

describe这个函数对于分类型变量的描述可能会有一点点问题,因为我们发现直接给该函数传参为mydata结果如图

年龄居然有平均值58.21,因此这个函数并不适合用来处理分类型变量,那么我们再单独把那些连续型变量的列提取出来,运行代码

describe(mydata[,c(2,4:14)])

结果如图

使用变量ret把describe函数的运行结果存起来并且查看发现ret长这样

俨然是一个表格,可以方便的导出。当然我们发现describe函数默认并没有给出上下四分位点,但这并不是说该函数不能给出上下四分位点,只需要添加参数quant=c(.25,.75)即可完成任务,运行代码

ret

最终ret的结果如图

正态性检验的方法

样本量小于2000,使用函数shapiro.test(),p>0.05则服从正态分布

样本量大于2000,使用函数ks.test(x,"pnorm"),p>0.05则服从正态分布。其中第二个参数pnorm表示进行正态性检验

数据可视化

R语言中提供了丰富的绘图函数,这些函数要求的参数各不相同,但有一些通用的参数,这些参数可以控制图形的各种属性,如颜色、线条样式、字体大小等。以下是一些常用的通用图形参数:

  1. col:设置颜色。可以是颜色名称(如"red")、十六进制颜色代码(如"#FF0000")或RGB值。
  2. pch:设置点的类型。可以是数字(1-25),代表不同的点形状,或者是一个字符向量。
  3. lty:设置线条类型。可以是"solid"(实线)、"dashed"(虚线)、"dotted"(点线)等。
  4. lwd:设置线条宽度。数值越大,线条越粗。
  5. cex:设置字符大小扩展,影响文本、点和线条的大小。
  6. cex.axis:设置坐标轴标签的字符大小。
  7. cex.lab:设置图例标签的字符大小。
  8. cex.main:设置主标题的字符大小。
  9. font:设置字体。不同的数字代表不同的字体。
  10. family:设置字体族,可以是字体名称。
  11. bg:设置背景颜色,常用于设置点或多边形的填充色。
  12. xlab:设置x轴的标签。
  13. ylab:设置y轴的标签。
  14. main:设置图形的主标题。
  15. sub:设置图形的副标题。
  16. xlim:设置x轴的显示范围。
  17. ylim:设置y轴的显示范围。
  18. xaxs、yaxs:控制坐标轴的比例(如"i"表示等比例,"r"表示根据图形区域自动调整)。
  19. xaxt、yaxt:控制坐标轴的显示(如"n"表示不显示坐标轴)。
  20. log:对x或y轴进行对数变换。
  21. asp:设置y轴与x轴的比率。
  22. bty:设置图形边界框的类型。
  23. fg:设置前景色,常用于设置边框颜色。
  24. tck:设置坐标轴刻度的长度。
  25. tcl:设置坐标轴刻度标签的距离。

直方图

绘制直方图使用的函数是hist

运行代码hist(mydata$年龄)即可得到这样一幅图

这个直方图的横坐标代表着一个个区间,纵坐标代表频数,比如40到45这个区间内又20个样本,45到50这个区间内又大约50个样本。显然这是一个频数直方图。而众所周知我们想要添加概率密度曲线只能添加在频率直方图中,实际上hist函数也可以用来绘制频率直方图,只需要在刚才代码中添加一个参数freq=FALSE即可。

运行代码hist(mydata$年龄,freq = FALSE),结果如图

添加概率密度曲线使用的函数是curve,运行代码

curve(dnorm(x,mean=mean(mydata$年龄),sd=sd(mydata$年龄)),add = T)

其中在curve内部调用了dnorm函数,这个函数用于计算正态分布的概率密度函数,其内部的参数x表示正态分布的取值点,这个参数是固定的,就是用x表示,然后mean和sd指定了该分布的均值和方差,因此dnorm函数的调用结果是一个表达式,细说就是均值为mean(mydata$年龄),方差为sd(mydata$年龄)的概率密度函数表达式,curve函数需要的参数就是这样的一个表达式,他会根据这个表达式来绘制这个表达式的图像,参数add=T表示绘制的图形将会添加在当前画板中,而不是另外开一块画板。

结果如图

我们还发现了一个问题就是,这个纵坐标好像有点不够用,画的图都已经超出去了,这个问题可以通过hist函数中的参数ylim来控制。比如运行代码

hist(mydata$年龄,freq = FALSE,ylim=c(0,0.06)),此时的图像就变成了这样

再运行代码

curve(dnorm(x,mean=mean(mydata$年龄),sd=sd(mydata$年龄)),add = T)把概率密度曲线添加进去

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯单片机省赛——第八届“基于单片机的电子钟程序设计与调试”程序部分

往期回顾 第三届蓝桥杯单片机省赛 第四届蓝桥杯单片机省赛 第五届蓝桥杯单片机省赛 第六届蓝桥杯单片机省赛 第七届蓝桥杯单片机省赛 文章目录 往期回顾一、前期准备二、代码详情1.基础代码蜂鸣器/继电器/led/定时器之类的代码 2.按键详解按键写法讲解 3.驱动的处理驱动写法讲…

Linux学习笔记:进程间的通信.共享内存shm

共享内存shm 什么是共享内存shm共享内存的特点关键函数ftokshmgetshmatshmdtshmctl 代码示例 什么是共享内存shm 进程间通信的前提:必须让不同的进程看到同一份资源,并且这个资源是OS提供的 而共享内存(Share memory)就是在内核共享内存区找一块物理内存空间,并允许多个进程共…

远距离、高品质、低延迟、高保真——SA316无线音频模块带您探索新的音频体验

SA316系列产品分为发射端模块SA316S-TX,SA316F30和接收端模块SA316-RX,该系列方案采用了无线高品质的语音传输芯片来设计,它可以支持外部 PCM / IIS 双模数字音频接口,同时模块为客户提供了标准化的串行接口,使用者可通过串口指令…

使用QT完成如图的游戏登录界面 使用信号和槽完成密文明文密码转换,重置账号和密码,登录校验 详细代码在主页下载

头文件: #ifndef LOGINWIDGET_H #define LOGINWIDGET_H #include <QLineEdit> #include <QPushButton> #include <QWidget> class LoginWidget : public QWidget {Q_OBJECT public: LoginWidget(QWidget *parent = 0); ~LoginWidget(); public slots: …

全新神经网络架构KAN一夜爆火!200参数顶30万,MIT华人一作 | 最新快讯

白交衡宇发自凹非寺 量子位公众号 QbitAI 一种全新的神经网络架构 KAN&#xff0c;诞生了&#xff01; 与传统的 MLP 架构截然不同&#xff0c;且能用更少的参数在数学、物理问题上取得更高精度。 比如&#xff0c;200 个参数的 KANs&#xff0c;就能复现 DeepMind 用 30 万参数…

SpringCloud整合Gateway结合Nacos

目录 一、引入依赖 二、开启两个测试项目 2.1 order service ​编辑 2.2 user service 三、gateway项目 3.1 新建一个bootstrap.yml文件 3.2 将我们的的网关配置写道nacos里的配置里 3.3 测试&#xff1a;看能够根据网关路由到两个测试的项目 四、 优化 4.1 将项目打包…

低空经济+飞行汽车:eVTOL技术详解

低空经济是以各种有人驾驶和无人驾驶航空器的各类低空飞行活动为牵引&#xff0c;辐射带动相关领域融合发展的综合性经济形态。它广泛体现于第一、第二、第三产业之中&#xff0c;在促进经济发展、加强社会保障、服务国防事业等方面发挥着日益重要的作用。 飞行汽车&#xff0c…

## CSDN创作活动:缓解工作压力:程序员的健康之道

缓解工作压力&#xff1a;程序员的健康之道 在当今快节奏的社会中&#xff0c;程序员作为一个高度专业化和技术密集的群体&#xff0c;往往需要面对持续的工作压力和创新挑战。在如此高强度的工作环境下&#xff0c;如何有效缓解工作压力&#xff0c;保持工作效率和个人健康成…

7个AI工具助力产品管理提升

大家好&#xff0c;人工智能AI技术不断进步&#xff0c;AI在产品管理领域的应用也日益广泛。AI以辅助者的角色助力提升产品优化流程的效率&#xff0c;同时激发创新&#xff0c;是不可或缺的强大伙伴。本文将介绍七个AI工具&#xff0c;旨在自动化产品管理者的日常工作流程&…

Unity SteamVR入门

概述 VR项目现在在当前已经是非常热门的技术&#xff0c;可以给玩家身临其境的感觉&#xff0c;接下来让我们学习这部分的内容吧&#xff01; SteamVR Input SteamVR绑定流程&#xff0c;在Windows窗口的点击SteamVR-input&#xff0c;图1&#xff0c;在这里可以选择你需要绑定…

探秘Redis分布式锁:实战与注意事项

【更多精彩内容,欢迎关注小米的微信公众号“软件求生”】 大家好!我是小米,一个热爱分享技术的29岁技术达人。今天,我们来聊聊一个很有意思的主题——Redis分区容错之分布式锁。在分布式系统中,锁是一个非常重要的概念,它能确保系统中资源的并发访问不会出现问题。Redis…

如何使用Go语言进行基准测试(benchmark)?

文章目录 一、基准测试的基本概念二、编写基准测试函数三、运行基准测试四、优化代码性能五、注意事项总结 在Go语言中&#xff0c;基准测试&#xff08;benchmark&#xff09;是一种评估代码性能的有效方式。通过基准测试&#xff0c;我们可以测量代码执行的时间、内存使用情况…

【CANoe示例分析】TCP Chat(CAPL) with TLS encription

1、工程路径 C:\Users\Public\Documents\Vector\CANoe\Sample Configurations 15.3.89\Ethernet\Simulation\TLSSimChat 在CANoe软件上也可以打开此工程:File|Help|Sample Configurations|Ethernet - Simulation of Ethernet ECUs|Basic AUTOSAR Adaptive(SOA) 2、示例目…

快速掌握Element-Ul,构建高效网页应用【AI写作】

首先&#xff0c;这篇文章是基于笔尖AI写作进行文章创作的&#xff0c;喜欢的宝子&#xff0c;也可以去体验下&#xff0c;解放双手&#xff0c;上班直接摸鱼~ 按照惯例&#xff0c;先介绍下这款笔尖AI写作&#xff0c;宝子也可以直接下滑跳过看正文~ 笔尖Ai写作&#xff1a;…

并发编程之线程池的设计和原理

一、线程池 提前创建一系列的线程&#xff0c;保存在这个线程池中&#xff0c;有任务要执行的时候&#xff0c;从线程池中取出线程来执行。没有任务的时候&#xff0c;线程池放回去。 二、为什么要使用线程池 线程使用上的问题: 线程的频繁创建 和 销毁 线程的数量过多&…

注册表获取autoCAD安装位置

注意事项 注意&#xff1a;①64位操作系统注册表会重定向&#xff0c;RegOpenKeyEx第4个参数得加上KEY_WOW64_64KEY&#xff1b;②RegOpenKeyEx遍历子项时注意第2和第4参数&#xff0c;参考图&#xff1a; ③RegQueryValueEx同样得注意第6参数 完整代码 std::unordered_map…

Mybatis进阶(映射关系多对一 )

文章目录 1.需求分析2.应用实例&#xff08;xml配置&#xff09;1.数据表设计2.entity设计&#xff08;不要使用toString会栈溢出&#xff09;1.Pet.java2.User.java 3.编写Mapper1.PetMapper.java2.UserMapper.java 4.编写Mapper.xml1.UserMapper.xml2.PetMapper.xml 5.测试Us…

OPPO A72/A55/K7X/A53真我Q3S等手机ROOT刷机后广电卡没信号不读卡解决办法

目前运营商除了移动联通电信以外&#xff0c;还存在1个中国广电&#xff0c;广电属于第四大运营商&#xff0c;由于广电起步较晚&#xff0c;对于手机频段要求也自然不一样&#xff0c;导致目前市面上部分手机出厂没有信号或者不读卡等问题&#xff0c;特别在手机被用户自行刷机…

如何快速的追加文章的内容(在不知道内容的情况下)

首先&#xff0c;需要用到的这个工具&#xff1a; 度娘网盘 提取码&#xff1a;qwu2 蓝奏云 提取码&#xff1a;2r1z 1、打开工具&#xff0c;切换到文章模块下&#xff0c;快捷键&#xff1a;Ctrl1 2、新建一个文章做演示&#xff0c;001 3、添加一个内容&#xff0c;就随…

蚂蚁面试:Springcloud核心组件的底层原理,你知道多少?

尼恩说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团、蚂蚁、得物的面试资格&#xff0c;遇到很多很重要的相关面试题&#xff1a; 说说&#xff1a;蚂蚁面试&#xff1…
最新文章