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

news2024/12/29 9:22:12

我们处理的变量可以分为两类,一类是连续型变量,另一类叫做分类型变量,其中对于连续型变量,如果服从正态分布就用平均值填充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.coloradmin.cn/o/1644053.html

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

相关文章

记服务器被挖矿的一次排查

1、top 查看进程使用情况,进程名为 kswapd0 用了180%的CPU,我的机器是2C的,所以基本上算是吃掉了所有的CPU资源,很明显罪魁祸首就是它。 2、执行命令 netstat -antlp | grep kswapd0 查询该进程的网络信息,发现一个与…

漫谈音频深度伪造技术

作为人工智能时代的新型媒体合成技术,深度伪造技术近年来在网络媒体中的涉及领域越发广泛、出现频次越发频繁。据路透社报道,2023年,社交媒体网站上发布50万个深度伪造的语音和视频。 1、深度伪造技术的五个方面 音频深度伪造技术&#xff…

Unity 性能优化之静态批处理(三)

提示:仅供参考,有误之处,麻烦大佬指出,不胜感激! 文章目录 前言一、静态批处理是什么?二、使用步骤1.勾选Static Batching2.测试静态合批效果 三、静态合批得限制1、游戏对象处于激活状态。2、游戏对象有一…

tomcat+maven+java+mysql图书管理系统1-配置项目环境

目录 一、软件版本 二、具体步骤 一、软件版本 idea2022.2.1 maven是idea自带不用另外下载 tomcat8.5.99 Javajdk17 二、具体步骤 1.新建项目 稍等一会,创建成功如下图所示,主要看左方目录相同不。 给maven配置国外镜像 在左上…

前端工程化06-JavaScript模块化CommonJS规范ES Module

7、JavaScript模块化 在js开发中,他并没有拆分的概念,并不像java一样他可以拆分很多的包,很多的类,像搭积木一样完成一个大型项目的开发,所以js在前期的时候并不适合大型后端的项目开发,但是这些问题在后来…

16_Scala面向对象编程_函数

文章目录 1.声明Scala函数2.访问伴生对象3.空对象直接用的方法4.构造对象--通过object获取单例对象--直接new--scala独有apply()方式--scala有参构造--scala构造方法两大类使用辅构造如下上述代码主构造为辅助构造方法甚至可以多个多个辅助构造形参内容不能重不使用辅助构造和使…

Linux文件类型及目录和文件的权限

一、Linux 文件类型 1、Windows文件类型 2、Linux文件类型 1普通文件类型 Linux 中最多的一种文件类型, 包括 纯文本文件(ASCII);二进制文件(binary);数据 格式的文件(data);各种压缩文件.第一个属性为 - 2目录文件 就是目录, 能用 # cd 命…

【微服务】服务保护(通过Sentinel解决雪崩问题)

Sentinel解决雪崩问题 雪崩问题服务保护方案服务降级保护 服务保护技术SentinelFallback服务熔断 雪崩问题 在微服务调用链中如果有一个服务的问题导致整条链上的服务都不可用,称为雪崩 原因 微服务之间的相互调用,服务提供者出现故障服务的消费者没有…

Unity 热更--AssetBundle学习笔记 1.0【AB包资源加载工具类的实现】

合集 - Unity学习笔记(13)1.Unity学习笔记–基础2023-11-012.Unity学习笔记–入门2023-10-293.Unity学习笔记–数据持久化之PlayerPrefs的使用2023-11-194.Unity学习笔记–数据持久化XML文件(1)2023-11-205.Unity学习笔记–数据持久化XML文件(2)2023-12-…

ADS基础教程8-仿真库加载

目录 一、系统库介绍二、厂商库1.模型下载1)登录官网2)选择所需模型3)点击下载4)指定保存路径 二.模型加载1)设计套件选择2)选择解压文件3)解压文件成功4)添加到当前workspace5&…

在STM32中用寄存器方式点亮流水灯

文章目录 实验资料一、对寄存器的理解1.通俗认识寄存器2.深入了解寄存器(1)端口配置低寄存器(配置0到7引脚的寄存器)(2)端口配置高寄存器(配置8到15引脚) 3.GPIO口的功能描述 二、配…

在线协作,开源的设计和原型创作平台:penpot

penpot:面向团队,设计自由- 精选真开源,释放新价值。 概览 Penpot 是一款专为跨职能团队量身定制的开源设计软件,与行业领先的 Figma 齐名,提供了一个强大而灵活的在线设计解决方案。其最大的亮点在于,用户…

五一假期零碎时间练习学习过的内容(商城版)

目录 1 总览1.1 技术架构1.2 其他1.2.1 数据库1.2.2 后端部分1.2.2.1 复习feign1.2.2.2 复习下网关网关的核心功能特性:网关路由的流程断言工厂过滤器工厂全局过滤器 过滤器执行顺序解决跨域问题 1.2.2.3 es部分复习 1.2.3 前端部分 2 day1 配置网关2.1 任务2.2 网关…

5.3 调制与解调

信号的调制与解调是通信系统中一对基本的概念,涉及将信息(语音、视频、数据等)在发送之前进行处理以便在传输介质(如无线电波、电话线等)上有效传输,以及在接收端恢复这些信息的过程。 一、调制&#xff0…

Java | Leetcode Java题解之第60题排列序列

题目&#xff1a; 题解&#xff1a; class Solution {public String getPermutation(int n, int k) {int[] factorial new int[n];factorial[0] 1;for (int i 1; i < n; i) {factorial[i] factorial[i - 1] * i;}--k;StringBuffer ans new StringBuffer();int[] valid…

虚拟机jvm下

jvm原理与实践 java程序的跨平台特性 jvm基本结构 JVM类加载流程和内存结构总览 类加载 加载阶段 类加载 验证阶段 类加载 准备阶段 类加载 解析阶段 类加载 初始化阶段 程序计数器 虚拟机栈&本地方法栈 栈帧操作 堆 方法区 永久代 元空间 垃圾回收 可触及性

Day12-JavaWeb开发-登录校验(概述/JWT令牌/Fitter/Interceptor)登录认证(会话技术/会话跟踪)

1. 基础登录功能 2. 登录校验-概述 3. 登录认证-登录校验-会话技术 3.1 会话技术 3.2 会话跟踪方案对比 4. 登录校验-JWT令牌 4.1 JWT令牌-介绍 4.2 JWT令牌-生成和校验 4.3 JWT令牌-登录后下发令牌 5. 登录校验-过滤器Fitter 5.1 Fitter-入门 5.2 Fitter-详解(执行流程) 5.3…

Windows php 安装 Memcached扩展、php缺失 Memcached扩展、Class ‘Memcached‘ not found

在Windows系统下如何安装 php Memcached 扩展 下载dll文件 pecl地址&#xff1a;https://pecl.php.net/package/memcached 根据版本进行选择 &#xff1a; 解压下载的文件后得到了这么样的文件结构&#xff1a; 配置 移动dll文件到相应文件位置 重点&#xff1a; libme…

cefsharp实现资源替换如网页背景、移除替换标签、html标识、执行javascript脚本学习笔记(含源码说明)

(一)实现测试(仅供学习参考) 1.1 目标系统页面(登录页)和登录后首页面中2处(一个替换一个移除) 1.2 实现后效果(使用cefsharp自定义浏览器实现以上功能) 1.3 登录后页面替换和移除 系统名称和一个功能菜单li (二)通过分析代码实现脚本编写 2.1 分开处理,设置了…

Swish和H-Swish激活函数:提升模型训练效率

文章目录 Swish激活函数H-Swish激活函数实现总结参考 在深度学习领域&#xff0c;激活函数是神经网络中的关键组成部分&#xff0c;它决定了网络的输出和性能。近年来&#xff0c;研究人员提出了许多新的激活函数&#xff0c;其中Swish激活函数因其独特的性能优势而备受关注。这…