ggplot2--geom_smooth和曲线拟合画图

本文通过实例演示了如何使用R语言中的ggplot2包绘制带有线性回归拟合曲线的散点图,并展示了如何调整拟合公式以实现不同的回归曲线。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目的:使用geom_smooth来画曲线拟合图
 
R代码:
#!/usr/bin/Rscript
 
##Reference:
#http://stackoverflow.com/questions/1476185/how-to-overlay-a-line-for-an-lm-object-on-a-ggplot2-scatterplot
 
library(ggplot2)
N = 300
x=1:N+rnorm(N, 10, 60)
y=1:N+rnorm(N, 10, 60)
colour=sample(c('red','blue'), N, replace=TRUE)
 
df = data.frame(x=x, y=y, colour=colour)
 
##
g1=ggplot(df)+geom_smooth(aes(x=x,y=y),method='lm')+geom_point(data=df, aes(x=x,y=y, colour=colour), alpha=.9)
SSS= rnorm(N, 4, 10)
 
ggplot(df)+geom_smooth(aes(x=x,y=y),method='lm')+geom_point(data=df, aes(x=x,y=y, colour=colour,size=SSS),alpha=.9)
 
## You can provide a formula for regression
g2=ggplot(df)+geom_smooth(aes(x=x,y=y),method='lm', formula=y~I(x*x))+geom_point(data=df, aes(x=x,y=y, colour=colour), alpha=.9)
 
## Provide an arbitrary formula for regressing
g3=ggplot(df)+geom_smooth(aes(x=x,y=y, colour=colour),method='lm', formula=y~I(poly(x,3)))+geom_point(data=df, aes(x=x,y=y, colour=colour), alpha=.9)
 
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值