R语言中lm函数构建线性和非线性回归模型

目录

一、lm函数建立线性回归模型

(1)一元线性回归

(2)多元线性回归

二、lm函数建立非线性回归模型 

三、回归诊断


一、lm函数建立线性回归模型

(1)一元线性回归

  1.首先加载R语言的MASS、ISLR2程序包,然后加载数据集Boston。

install.packages("ISLR2")
library(ISLR2)
library(MASS)
head(Boston)

  2.接着,利用lm函数进行回归分析,并用回归拟合的函数进行预测。 系数均通过t检验,因此拟合的函数为 y=-0.95005x+34.55384。

lm.fit <- lm(medv~lstat, data = Boston)#回归拟合
summary(lm.fit)#展示回归函数的信息
coef(lm.fit)# 相关系数
confint(lm.fit)# 置信区间
predict(lm.fit, data.frame(lstat = c(5,10,15)), interval = 'prediction')#预测

  3.做数据集中medv和lstat的散点图,并画出拟合直线。其中plot函数中pch为符号命令,可自行修改。然后绘制拟合曲线的残差图,包括标准化残差图、QQ图等。

attach(Boston)
plot(lstat, medv)#绘制散点图
abline(lm.fit)#添加拟合直线
plot(lstat, medv, pch = 25)##pch用于修改符号表示vc
par(mfrow=c(2,2))
plot(lm.fit)#绘制回归曲线的图
which.max(hatvalues(lm.fit))#标识向量中最大元素的索引

    

  

  4.注意在函数后添加-1与+1的区别:添加-1意味着拟合函数中不含常数项,+1与不添加后缀均为含常数项的含义。

fit<-lm(medv~lstat-1,data=Boston)
summary(fit)
summary(lm.fit)

(2)多元线性回归

  同样,利用lm函数进行多元线性回归,自行选择自变量的个数。

#多元线性回归
mfit <- lm(medv~lstat + age)
summary(mfit)
lm.fit <- lm(medv ~ ., data = Boston)#因变量为除medv外的其余变量
summary(lm.fit)
install.packages("car")
library(car)
vif(lm.fit)##计算方差膨胀系数
summary(lm(medv ~ lstat * age, data = Boston))#交互项

二、lm函数建立非线性回归模型 

  利用lm函数进行非线性回归,如高阶多项式拟合、对数拟合等。

#非线性回归
lm.fit2 <- lm(medv ~ lstat + I(lstat^2))
summary(lm.fit2)
# 通过方差分析比较两个模型的好坏
lm.fit <- lm(medv ~ lstat)
anova(lm.fit, lm.fit2)
#绘制lm.fit2回归函数的图
par(mfrow = c(2, 2))
plot(lm.fit2)
#高阶多项式拟合
mfit5 <- lm(medv ~ poly(lstat, 5))
summary(mfit5)
# 取对数变换
logfit<-lm(medv ~ log(rm), data = Boston)
summary(logfit)


三、回归诊断

y<-residuals(lm.fit)#计算残差
y2<-rstandard(lm.fit)#计算标准化残差                       
shapiro.test(y)#检验残差的正态性
y1<-predict(lm.fit)#将原始数据带入拟合函数进行预测
plot(y2~y1,ylab="残差")#绘制
abline(h=2)
abline(h=-2)##若点分布在[-2,2]内,且不呈趋势,则残差近似满足正态性,模型合适

另加:利用逐步回归进行选取变量,根据AIC统计量最小的原则。

lm.new<-step(lm.fit)#做逐步回归,选择AIC最小的函数
summary(lm.new)
influence.measures(lm.fit)#检测有问题的样本

      以上就是本文的全部内容,如有错误,欢迎大家批评指正。

  • 21
    点赞
  • 173
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
多元非线性回归模型R语言可以使用lm函数进行建模。例如,可以使用lm函数进行高阶多项式拟合、对数拟合等。对于高阶多项式拟合,可以使用poly函数对自变量进行多项式转换,然后使用lm函数建立回归模型。例如,可以使用以下代码进行高阶多项式拟合: mfit5 <- lm(medv ~ poly(lstat, 5)) 同样地,对于对数拟合,可以使用log函数对自变量进行转换,然后使用lm函数建立回归模型。例如,可以使用以下代码进行对数拟合: logfit <- lm(medv ~ log(rm), data = Boston) 在建立回归模型之后,可以使用summary函数查看模型的统计信息,如参数估计值、标准误差、显著性水平等。例如,可以使用以下代码查看模型的统计信息: summary(mfit5) summary(logfit) 此外,还可以进行回归诊断来评估模型的合适性。常见的回归诊断方法包括检验残差的正态性、绘制残差图等。例如,可以使用shapiro.test函数检验残差的正态性,使用plot函数绘制残差图。以下是一些示例代码: y <- residuals(lm.fit) y2 <- rstandard(lm.fit) shapiro.test(y) plot(y2 ~ y1, ylab="残差") abline(h=2) abline(h=-2) 如果残差近似满足正态性,且不呈趋势,并且点分布在[-2,2]内,则可以认为模型合适。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [matlab多元非线性回归教程.docx](https://download.csdn.net/download/apple_51426592/85741923)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [R语言lm函数构建线性非线性回归模型](https://blog.csdn.net/weixin_69652071/article/details/126697700)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值