分享好友 编程语言首页 频道列表

拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

r语言文章/教程  2023-03-08 11:010

原文链接:http://tecdat.cn/?p=18169

 

比如说分类变量为是否幸存、是因变量,连续变量为年龄、是自变量,这两者可以做相关分析吗?两者又是否可以做回归分析?

我们考虑泰坦尼克号数据集,

  1.  
     
  2.  
    titanic = titanic[!is.na(titanic$Age),]
  3.  
    attach(titanic)

 考虑两个变量,年龄x(连续变量)和幸存者指标y(分类变量)

  1.  
     
  2.  
    X = Age
  3.  
    Y = Survived

 年龄可能是逻辑回归中的有效解释变量,

  1.  
    summary(glm(Survived~Age,data=titanic,family=binomial))
  2.  
     
  3.  
    Coefficients:
  4.  
    Estimate Std. Error z value Pr(>|z|)
  5.  
    (Intercept) -0.05672 0.17358 -0.327 0.7438
  6.  
    Age -0.01096 0.00533 -2.057 0.0397 *
  7.  
    ---
  8.  
    Signif. codes: 0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1
  9.  
     
  10.  
    (Dispersion parameter for binomial family taken to be 1)
  11.  
     
  12.  
    Null deviance: 964.52 on 713 degrees of freedom
  13.  
    Residual deviance: 960.23 on 712 degrees of freedom
  14.  
    AIC: 964.23

 此处的显着性检验的p值略低于4%。实际上,可以将其与偏差值(零偏差和残差)相关联。

拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

在x毫无价值的假设下,D_0趋于具有1个自由度的χ2分布。我们可以计算似然比检验的p值自由度,

  1.  
     
  2.  
    1-pchisq(
  3.  
    [1] 0.03833717

 与高斯检验一致。但是如果我们考虑非线性变换

  1.  
    glm(Survived~bs(Age)
  2.  
     
  3.  
    Coefficients:
  4.  
    Estimate Std. Error z value Pr(>|z|)
  5.  
    (Intercept) 0.8648 0.3460 2.500 0.012433 *
  6.  
    bs(Age)1 -3.6772 1.0458 -3.516 0.000438 ***
  7.  
    bs(Age)2 1.7430 1.1068 1.575 0.115299
  8.  
    bs(Age)3 -3.9251 1.4544 -2.699 0.006961 **
  9.  
    ---
  10.  
    Signif. codes: 0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1
  11.  
     
  12.  
    (Dispersion parameter for binomial family taken to be 1)
  13.  
     
  14.  
    Null deviance: 964.52 on 713 degrees of freedom
  15.  
    Residual deviance: 948.69 on 710 degrees of freedom

Age的p值更小,似乎“更重要”

  1.  
     
  2.  
    [1] 0.001228712

为了可视化非零相关性,可以考虑给定y = 1时x的条件分布,并将其与给定y = 0时x的条件分布进行比较,

  1.  
     
  2.  
    Two-sample Kolmogorov-Smirnov test
  3.  
     
  4.  
    data: X[Y == 0] and X[Y == 1]
  5.  
    D = 0.088777, p-value = 0.1324
  6.  
    alternative hypothesis: two-sided

 即p值大于10%时,两个分布没有显着差异。

  1.  
     
  2.  
    v= seq(0,80
  3.  
    v1 = Vectorize(F1)(vx)

 拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

我们可以查看密度

拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

 

另一种方法是离散化变量x并使用Pearson的独立性检验,

  1.  
     
  2.  
    table(Xc,Y)
  3.  
    Y
  4.  
    Xc 0 1
  5.  
    (0,19] 85 79
  6.  
    (19,25] 92 45
  7.  
    (25,31.8] 77 50
  8.  
    (31.8,41] 81 63
  9.  
    (41,80] 89 53
  10.  
     
  11.  
    Pearson's Chi-squared test
  12.  
     
  13.  
    data: table(Xc, Y)
  14.  
    X-squared = 8.6155, df = 4, p-value = 0.07146

 p值在此处为7%,分为年龄的五个类别。实际上,我们可以比较p值

  1.  
    pvalue = function(k=5){
  2.  
    LV = quantile(X,(0:k)/k)
  3.  
     
  4.  
     
  5.  
    plot(k,p,type="l")
  6.  
    abline(h=.05,col="red",lty=2)

 拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“

 

只要我们有足够的类别,P值就会接近5%。实际上年龄在试图预测乘客是否幸存时是一个重要的变量。


拓端tecdat|R语言逻辑回归分析连续变量和分类变量之间的“相关性“ 

最受欢迎的见解

1.R语言多元Logistic逻辑回归 应用案例

2.面板平滑转移回归(PSTR)分析案例实现

3.matlab中的偏最小二乘回归(PLSR)和主成分回归(PCR)

4.R语言泊松Poisson回归模型分析案例

5.R语言回归中的Hosmer-Lemeshow拟合优度检验

6.r语言中对LASSO回归,Ridge岭回归和Elastic Net模型实现

7.在R语言中实现Logistic逻辑回归

8.python用线性回归预测股票价格

9.R语言如何在生存分析与Cox回归中计算IDI,NRI指标

 

查看更多关于【r语言文章/教程】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
拓端tecdat|R语言VAR模型的不同类型的脉冲响应分析
原文链接:http://tecdat.cn/?p=9384目录模型与数据估算值预测误差脉冲响应识别问题正交脉冲响应结构脉冲反应广义脉冲响应参考文献脉冲响应分析是采用向量自回归模型的计量经济学分析中的重要一步。它们的主要目的是描述模型变量对一个或多个变量的冲击的演化

0评论2023-03-16712

Visual Studio 编辑R语言环境搭建
Visual Studio 编辑R语言环境搭建关于Visual Studio 编辑R语言环境搭建具体的可以看下面三个网址里的内容,我这里就讲两个问题,关于r包管理和换本地的r的服务。1.r包管理:Ctrl+72.R本地服务管理:Ctrl+9Visual Studio R官方帮助文档(中文): https://docs

0评论2023-03-16320

拓端tecdat|R语言代写实现向量自回归VAR模型
原文链接:http://tecdat.cn/?p=8478 澳大利亚在2008 - 2009年全球金融危机期间发生了这种情况。澳大利亚政府发布了一揽子刺激计划,其中包括2008年12月的现金支付,恰逢圣诞节支出。因此,零售商报告销售强劲,经济受到刺激。因此,收入增加了。VAR面临的批

0评论2023-03-16915

[译]用R语言做挖掘数据《五》 r语言数据挖掘简单实例
一、实验说明1. 环境登录无需密码自动登录,系统用户名shiyanlou,密码shiyanlou2. 环境介绍本实验环境采用带桌面的Ubuntu Linux环境,实验中会用到程序:1. LX终端(LXTerminal): Linux命令行终端,打开后会进入Bash环境,可以使用Linux命令2. GVim:非常好

0评论2023-03-08418

[译]用R语言做挖掘数据《三》 数据挖掘——基于r语言的实战
一、实验说明1. 环境登录无需密码自动登录,系统用户名shiyanlou,密码shiyanlou2. 环境介绍本实验环境采用带桌面的Ubuntu Linux环境,实验中会用到程序:1. LX终端(LXTerminal): Linux命令行终端,打开后会进入Bash环境,可以使用Linux命令2. GVim:非常好

0评论2023-03-08596

数据科学与R语言: 关于我 Rer
数据科学与R语言: 关于我关于我钱钟书曾说,鸡蛋好吃不一定要去认识下蛋的母鸡。不过人类是社会化的动物,访客和博主都希望有多一些的交流。在2012年元旦之即,写下这篇短文算是我的简介吧。 最早接触的计算机还是一台386,那时作为Geek的成就感来自于迅速的

0评论2023-03-08403

使用R语言和XML包抓取网页数据-Scraping data from web pages in R with XML package
In the last years a lot of data has been released publicly in different formats, but sometimes the data we're interested in are still inside the HTML of a web page: let's see how to get those data. One of the existing packages for doing th

0评论2023-02-12524

R语言的ARIMA模型预测 r语言arima参数估计
R通过RODBC连接数据库stats包中的st函数建立时间序列funitRoot包中的unitrootTest函数检验单位根forecast包中的函数进行预测差分用timeSeries包中diffstats包中的acf和pacf处理自相关和偏自相关stats包中的arima函数模型 

0评论2023-02-09490

3.3-Cypher语言及语法使用 cypher读法
Cypher是一种图数据库查询语言,表现力丰富,查询效率高,其地位和作用与关系型数据库中的SQL语言相当。Cypher具备的能力:Cypher通过模式匹配图数据库中的节点和关系,来提取信息或者修改数据。Cypher语句中允许使用变量,用来表示命名、绑定元素和参数。Cyp

0评论2023-02-09514

更多推荐