返回顶部
首页 > 资讯 > 精选 >如何在R语言中使用quantile()函数
  • 186
分享到

如何在R语言中使用quantile()函数

2023-06-14 13:06:03 186人浏览 八月长安
摘要

这期内容当中小编将会给大家带来有关如何在R语言中使用quantile()函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、求某个百分位比> data <- c

这期内容当中小编将会给大家带来有关如何在R语言中使用quantile()函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1、求某个百分位比

> data <- c(1,2,3,4,5,6,7,8,9,10)> quantile(data,0.5)50% 5.5 > quantile(data,c(0.25,0.75)) 25%  75% 3.25 7.75

2、产生一个序列百分位比值

> quantile(data,seq(0.1,1,0.1)) 10%  20%  30%  40%  50%  60%  70%  80%  90% 100%  1.9  2.8  3.7  4.6  5.5  6.4  7.3  8.2  9.1 10.0

3、只取百分号下面的数值

> unname(quantile(data,seq(0.1,1,0.1))) [1]  1.9  2.8  3.7  4.6  5.5  6.4  7.3  8.2  9.1 10.0

补充:基于R语言的分位数回归(quantile regression)

分位数回归(quantile regression)

这一讲,我们谈谈分位数回归的知识,我想大家传统回归都经常见到。分位数回归可能大家见的少一些,其实这个方法也很早了,大概78年代就有了,但是那个时候这个理论还不完善。到2005年的时候,分位数回归的创立者Koenker R写了一本分位数回归的专著,剑桥大学出版社出版的。今年本来老爷子要出一本《handbook of quantile regression》,还没有正式出来呢,目前来看,分位数回归应用的范围非常广。在金融领域尤为重要。下面先给大家简单介绍一下,分位数回归的基本原理,完后拿R做一个完整的案例。为什么拿R软件,因为分位数回归的发明者最早拿R写了一个包,叫quantreag,是当时唯一一个分位数回归的包,现在的话,看到python,julia也有相关的包了。但是感觉这个R的还是最好的。

那么什么是分位数回归呢,这个就要从传统的回归说起,传统回归呢,一般叫最小二乘回归,也叫均值回归。这个均值是指条件均值。比较抽象,在前面有一篇博文中,我比较详细地解释过。那么分位数回归就是均值回归的拓展,也就是它可以拟合均值以外的其它分位点,形成多条回归线,这里首先需要强调的是分位数回归的分位点是指因变量y的分位点,不是x的。这样我们如果设定多个分位点就得到了多条回归直线。当然分位数回归现在也发展出来非线性分位数回归,就是可以拟合出多条曲线,或者和广义线性回归模型一样可以适用二值变量。要说分位数回归具体的原理,后面有空再细谈。下面我们拿R语言做一个案例,大家就可以逐渐感受到分位数回归具体的含义了。

案例所用的数据呢,大家应该都比较熟悉,就是收入和食品消费支出的数据

下面看代码

#导入分位数回归的包library(quantreg)                         # 引入数据data(engel)#查看数据格式mode(engel)[1] "list"#查看变量名names(engel)[1] "income"  "foodexp"#查看格式class(engel)[1] "data.frame"#查看数据的前五行head(engel)income  foodexp1 420.1577 255.83942 541.4117 310.95873 901.1575 485.68004 639.0802 402.99745 750.8756 495.56086 945.7989 633.7978#画个散点图看看数据plot(engel$income, engel$foodexp, xlab='income', ylab='foodexp')

图是这样的

如何在R语言中使用quantile()函数

下面我们继续简单查看一下数据

#查看foodexp的变化范围boxplot(engel$foodexp, xlab='foodexp')#简单验证一下因变量foodexp是否服从正态分布qqnORM(engel$foodexp, main='QQ plot')qqline(engel$foodexp, col='red', lwd=2)

结果如下:

如何在R语言中使用quantile()函数

下面是QQ图

如何在R语言中使用quantile()函数

结果表明,因变量y明显不服从正态分布,但是呢,分位数回归不要求y服从正态分布,不仅如此,而且分位数回归还对异常值点不敏感。

下面我们继续,为了对比,我们仍然做一个均值回归,再做一个分位数回归。

#可以直接调用数据框里变量attach(engel)#设置0.05, 0.25, 0.5, 0.75, 0.95五个分位点,并且进行分位数回归,这样可以得到五条分位数回归线rq_result <- rq(foodexp ~ income, tau=c(0.05, 0.25, 0.5, 0.75, 0.95))summary(rq_result)Call: rq(formula = foodexp ~ income, tau = c(0.05, 0.25, 0.5, 0.75,     0.95))tau: [1] 0.05Coefficients:            coefficients lower bd  upper bd (Intercept) 124.88004     98.30212 130.51695income        0.34336      0.34333   0.38975Call: rq(formula = foodexp ~ income, tau = c(0.05, 0.25, 0.5, 0.75,     0.95))tau: [1] 0.25Coefficients:            coefficients lower bd  upper bd (Intercept)  95.48354     73.78608 120.09847income        0.47410      0.42033   0.49433Call: rq(formula = foodexp ~ income, tau = c(0.05, 0.25, 0.5, 0.75,     0.95))tau: [1] 0.5Coefficients:            coefficients lower bd  upper bd (Intercept)  81.48225     53.25915 114.01156income        0.56018      0.48702   0.60199Call: rq(formula = foodexp ~ income, tau = c(0.05, 0.25, 0.5, 0.75,     0.95))tau: [1] 0.75Coefficients:            coefficients lower bd  upper bd (Intercept)  62.39659     32.74488 107.31362income        0.64401      0.58016   0.69041Call: rq(formula = foodexp ~ income, tau = c(0.05, 0.25, 0.5, 0.75,     0.95))tau: [1] 0.95Coefficients:            coefficients lower bd upper bd(Intercept) 64.10396     46.26495 83.57896income       0.70907      0.67390  0.73444#上面就是没条回归线的回归系数,我们做个图看一下plot(income, foodexp, cex=0.25, type='n', xlab='income', ylab='foodexp')points(income, foodexp, cex=0.5, col='blue')#加中位数数回归的直线abline(rq(foodexp~income, tau=0.5), col='blue')#加均值回归的五条直线abline(lm(foodexp~income), lty=2, col='red')#将分位数回归的五条线加上去taus <- c(0.05, 0.1, 0.25, 0.75, 0.9, 0.95)#for (i in 1:length(taus)){  abline(rq(foodexp~income, tau=taus[i]), col='gray')}

效果如下:

如何在R语言中使用quantile()函数

上述就是小编为大家分享的如何在R语言中使用quantile()函数了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: 如何在R语言中使用quantile()函数

本文链接: https://lsjlt.com/news/271282.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何在R语言中使用quantile()函数
    这期内容当中小编将会给大家带来有关如何在R语言中使用quantile()函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、求某个百分位比> data <- c...
    99+
    2023-06-14
  • R语言中quantile()函数的用法说明
    在R语言中取百分位比用quantile()函数,下面举几个简单的示例: 1、求某个百分位比 > data <- c(1,2,3,4,5,6,7,8,9,10) >...
    99+
    2024-04-02
  • 如何在R语言中使用lm函数
    如何在R语言中使用lm函数?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在使用lm函数做一元线性回归时,发现lm(y~x+1)和lm(y~x)的结果是一致的,一直没找到两者之间...
    99+
    2023-06-08
  • R语言中的fivenum与quantile()函数算法详解
    fivenum()函数: 返回五个数据:最小值、下四分位数数、中位数、上四分位数、最大值 对于奇数个数字=5,fivenum()先排序,依次返回最小值、下四分位数、中位数、上四分位数...
    99+
    2024-04-02
  • R语言中如何使用strsplit函数
    小编给大家分享一下R语言中如何使用strsplit函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、R语言strsplit用于分割字符串创建测试数据>&...
    99+
    2023-06-14
  • r语言中numeric函数如何使用
    在R语言中,numeric()函数用于创建一个指定长度的数值向量。以下是numeric()函数的使用方法:1. 创建一个长度为n的空...
    99+
    2023-09-04
    r语言 numeric
  • r语言median函数如何使用
    在R语言中,可以使用`median()`函数来计算一组数据的中位数。以下是使用`median()`函数的方法:1. 对向量使用`me...
    99+
    2023-09-15
    r语言
  • r语言annotate函数如何使用
    在R语言中,annotate()函数用于在绘图中添加注释。它的基本语法如下:annotate(text, x, y, ...)其中,...
    99+
    2023-09-13
    r语言
  • 怎么在R语言中使用cut()函数
    怎么在R语言中使用cut()函数?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是R语言R语言是用于统计分析、绘图的语言和操作环境,属于GNU系统的一个自由、...
    99+
    2023-06-14
  • 怎么在R语言中使用summary()函数
    本篇文章为大家展示了怎么在R语言中使用summary()函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。什么是R语言R语言是用于统计分析、绘图的语言和操作环境,属于GNU系统的一个自由、免费、源代...
    99+
    2023-06-14
  • 如何在R语言中使用matrix函数生成矩阵
    今天就跟大家聊聊有关如何在R语言中使用matrix函数生成矩阵,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在R语言中可以使用matrix()函数来创建矩阵,其语法格式如下:matr...
    99+
    2023-06-08
  • R语言apply系列函数如何使用
    这篇文章主要讲解了“R语言apply系列函数如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“R语言apply系列函数如何使用”吧!R语言的循环效率并不高,所以并不推荐循环以及循环嵌套。...
    99+
    2023-07-05
  • ggplot2包如何在R语言中使用
    今天就跟大家聊聊有关ggplot2包如何在R语言中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。添加文本注释你可以在图形中添加文本,增加可读性。我们在annotate函数中设置t...
    99+
    2023-06-14
  • R语言中assign函数怎么使用
    在R语言中,`assign`函数用于将一个值指派给一个变量名。其使用格式如下:```Rassign(x, value, envir ...
    99+
    2023-10-09
    R语言
  • r语言中scale函数怎么使用
    在R语言中,scale函数用于对数据进行标准化处理。它可以将数据集的每个特征(列)进行标准化,使其均值为0,标准差为1。scale函...
    99+
    2023-09-13
    r语言
  • R语言中readtable函数怎么使用
    在R语言中,可以使用read.table函数来读取以制表符分隔的文本文件。read.table函数的基本用法如下:read.tabl...
    99+
    2023-09-13
    R语言
  • r语言中cumsum函数怎么使用
    cumsum函数用于计算累积和。它将依次对向量或矩阵的元素进行求和操作,并将每一步的结果保存。以下是cumsum函数的使用方法:1....
    99+
    2023-09-04
    r语言 cumsum
  • 如何在Go语言中使用函数?
    Go语言是一种现代化的编程语言,它拥有高效的并发性能和强大的编译能力,越来越多的程序员开始使用它来开发软件。在Go语言中,函数是一种非常重要的概念,本篇文章将会介绍如何在Go语言中使用函数。 一、函数的定义 在Go语言中,函数的定义格式如下...
    99+
    2023-08-13
    数据类型 教程 函数
  • r语言中的filter函数怎么使用
    在R语言中,`filter()`函数是`dplyr`包中的函数,用于筛选数据框中满足指定条件的行。`filter()`函数接受一个数...
    99+
    2023-09-04
    r语言 filter
  • R语言中的merge函数怎么使用
    在R语言中,merge函数用于合并两个数据框(data frame)。该函数的一般用法如下: merged_df <- mer...
    99+
    2024-03-04
    R语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作