用R语言生成指定品种与对照的一元回归直线(含置信区间)

在对品种的产量数据进行分析时,常用的、且比较简单的分析方法就是一元线性回归分析方法。我们可以用excel进行作图并生成回归曲线和方程,但无法绘制回归方程的置信区间。回归方程执行曲线可以让我们更直观看到品种在整个生态区不同环境条件下的产量稳定性。

我们通常以某一点所有参试品种产量的平均值作为该测试点的环境值(即x值,也是下面代码中展示的env),我们分析的品种和对照品种自身产量均值就是y(也就是下面代码中展示的yield),我们的品种和对照品种名称放在一列,成为group列。

R 复制代码
library(ggplot2)
library(broom)

#导入数据
data1<-read.csv("lm.csv")
# 查看数据
data1

ggplot(data1,aes(x=env,y=yield,color=group))+
  # 添加点图以查看原始数据
  geom_point()+
  # 添加回归线及置信区间,se=TRUE表示显示置信区间
  geom_smooth(method="lm", se=TRUE,aes(fill=hue),alpha=0.2)+
  # 自定义颜色
  scale_color_manual(values=c("VAR"="#FC4E07", "CK"="#00AFBB"))+  
  # 自定义填充颜色(置信区间)
  scale_fill_manual(values=c("VAR"="#FC4E07", "CK"="#00AFBB"))  


data2<-data1[data1$hue=="VAR",]
model2<-lm(yield ~ env,data=data2)
tidied_model <- tidy(model2)  # 获取模型参数的tidy格式
glanced_model <- glance(model2)  # 获取模型统计摘要的tidy格式
print(paste("y =", round(tidied_model$estimate[2], 4), "* x +", round(tidied_model$estimate[1], 4)))
print(paste("R^2 =", round(glanced_model$r.squared, 4)))

data3<-data1[data1$hue=="CK",]
model3<-lm(yield ~ env,data=data3)
tidied_model <- tidy(model3)  # 获取模型参数的tidy格式
glanced_model <- glance(model3)  # 获取模型统计摘要的tidy格式
print(paste("y =", round(tidied_model$estimate[2], 4), "* x +", round(tidied_model$estimate[1], 4)))
print(paste("R^2 =", round(glanced_model$r.squared, 4)))

运行结果如下:

相关推荐
凡人叶枫5 小时前
Effective C++ 条款33:避免遮掩继承而来的名字
linux·服务器·开发语言·c++·嵌入式开发
10岁的博客5 小时前
NOIP2010普及组「接水问题」详解:模拟算法与优先队列解法
开发语言·c++·算法
凡人叶枫5 小时前
Effective C++ 条款31:将文件间的编译依存关系降至最低
linux·开发语言·c++·php·嵌入式开发·effective c++
heimeiyingwang5 小时前
【架构实战】数据脱敏与隐私保护:合规是底线
java·开发语言·架构
于指尖飞舞6 小时前
java后端面试题(常用集合极简)
java·开发语言·面试
稷下元歌6 小时前
python核心基础,这关于基于Moveltg加 Ros2实战Python编程基础实课
开发语言·python
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第114题】【并发篇】第14题:说一下悲观锁的优点和缺点?
java·开发语言·面试
盒马盒马6 小时前
Rust:Vec
开发语言·rust
devilnumber6 小时前
Java 迭代器(Iterator)完全指南:从入门到实战
java·开发语言·迭代器
罗超驿6 小时前
13.Java多线程进阶:手动实现线程池与定时器机制详解
开发语言·面试·javaee