文章目录
-
-
- [1.Simple linear regression](#1.Simple linear regression)
- [2.Simple linear correlation](#2.Simple linear correlation)
-
方差分析
组间差异和
分类变量解释连续变量的情况用回归和相关。
线性回归是因果分析,相关性没有因果分析。
data:image/s3,"s3://crabby-images/4ca16/4ca16221fea73d548e98e73ae0f2650f609ac5da" alt=""
1.Simple linear regression
让残差最小。
data:image/s3,"s3://crabby-images/29998/299980579d9d4b807f4ec69fb0dd73b9acc519c2" alt=""
是斜率b, x的平方的加和是总变异。
data:image/s3,"s3://crabby-images/e20ba/e20ba3e4e25e8515d55484381c699e224e1a1ba9" alt=""
回归分析也是线性模型,方差具有可加性。
每个都可以计算。
data:image/s3,"s3://crabby-images/1ed15/1ed15cbb89bbaf959c56cf26a527caad1c07671c" alt=""
y的总变异。
data:image/s3,"s3://crabby-images/fd154/fd1546a5e3367f59a089f723629a985d99489499" alt=""
{r}
plot(trees$Girth, trees$Height)
abline(lm(trees$Height~trees$Girth))
X = trees$Girth
Y = trees$Height
# The famous five sums
sum(X)
sum(X^2)
sum(Y)
sum(Y^2)
sum(X*Y)
sum(X);sum(X^2);sum(Y);sum(Y^2);sum(X*Y)
# matrix multiplication
XY <- cbind(1,X,Y)
t(XY) %*% XY
式子是相等的。
{r}
# Sums of squares and sums of products
SSX = sum((X-mean(X))^2); SSX
SSY = sum((Y-mean(Y))^2); SSY
SSXY = sum((Y-mean(Y))*(X-mean(X))); SSXY
# 后面的是前面的
# The alternative way using the 5 sums
SSX = sum(X^2)-sum(X)^2/length(X); SSX
SSY = sum(Y^2)-sum(Y)^2/length(Y); SSY
SSXY = sum(X*Y)-sum(X)*sum(Y)/length(X); SSXY
{r}
# Model (Y=a+bX) coefficients
b = SSXY/SSX; b
a = mean(Y)-b*mean(X); a
lm(Y~X)
证明:生成这条直线是过均值点的。
data:image/s3,"s3://crabby-images/c2a7d/c2a7d003bef563ac7067e2f92f6749042cd982b4" alt=""
data:image/s3,"s3://crabby-images/a62b2/a62b24489a48496c15e4b785d982c0ba3fa7b89a" alt=""
data:image/s3,"s3://crabby-images/2861d/2861df5d1ef65082c67519fd0f999d0ef26ce9c4" alt=""
连续变量需要减去一个变量。
data:image/s3,"s3://crabby-images/a2fce/a2fced2aca24ccf6706385611267cae0ff49281b" alt=""
{r}
# Analysis of variance in regression
anova(lm(Y~X)) # data: trees
qf(0.95,1,29) # 4.18
1-pf(10.707,1,29)
data:image/s3,"s3://crabby-images/55e12/55e12eea5bcbd53ba81589c4a63a430fbefa6635" alt=""
{r}
# Unreliability estimates for the parameters
summary(lm(Y~X))
confint(lm(Y~X))
斜率的标准error表明
data:image/s3,"s3://crabby-images/dee3a/dee3aea0cd70d2cfa89c1f747a49664103998ab9" alt=""
模型中x解释的变异。使得残差最小,然后就是R方最大。
data:image/s3,"s3://crabby-images/8d7e8/8d7e8c4069914901fbd52c53a74bca6ded6b82d8" alt=""
{r}
# Degree of scatter
SSY = deviance(lm(Y~1)); SSY # SSY
SSE = deviance(lm(Y~X)); SSE # SSE
rsq = (SSY-SSE)/SSY; rsq # R square
summary(lm(Y~X))[[8]]
下面的代码是R方和调整过的R方。事实上,当涉及到多变量的时候,会用调整后的R方。
{r}
summary(lm(Volume~Girth, trees))$r.squared
# 当涉及到多个变量时候,会进行矫正
summary(lm(Volume~Girth, trees))$adj.r.squared
n是记录的行数,数据量大的话不支持多个变量。
data:image/s3,"s3://crabby-images/7c8b0/7c8b0a421335169ac26741640c02ced1af782415" alt=""
各个名词的区别。R方是用来解释能解释的变异。F 统计量衡量已解释的数占未解释数的比例
data:image/s3,"s3://crabby-images/f3cbc/f3cbc2392a81cd5cd14c49f2499fc306be4ca41f" alt=""
data:image/s3,"s3://crabby-images/b6ecb/b6ecb241b935d44adc526736dd35d508e5f2646e" alt=""
这里计算的t值和后文有较大的关系。
data:image/s3,"s3://crabby-images/c0e99/c0e99bf8f6b464d2b97e8d29db971ff14e6875e8" alt=""
{r}
summary(lm(Y~X))[[4]][4] # The standard error of the slope
summary(lm(Y~X))[[4]]
中间是最准的。样本量越大,预测越准。
data:image/s3,"s3://crabby-images/78933/78933b24824723b2e99e199a45f75422614b4ee9" alt=""
data:image/s3,"s3://crabby-images/454fa/454facda53c706d3a9081b4c17aebe81380ac3b1" alt=""
这个是实验设计。
data:image/s3,"s3://crabby-images/76fed/76fedac943cc097e6aa8902930ac2ebfaa34b3ff" alt=""
预测空间在外面,置信空间在里面。
data:image/s3,"s3://crabby-images/c8471/c8471fd454f06fccd6371526dc7d3b942cd1a3e6" alt=""
{r}
# Prediction using the fitted model
model <- lm(Y~X)
predict(model, list(X = c(14,15,16)))
{r}
ci.lines<-function(model){
xm <- mean(model[[12]][,2])
n <- length(model[[12]][[2]])
ssx<- sum(model[[12]][2]^2)- sum(model[[12]][2])^2/n
s.t<- qt(0.975,(n-2))
xv <- seq(min(model[[12]][2]),max(model[[12]][2]),
(max(model[[12]][2])-min(model[[12]][2]))/100)
yv <- coef(model)[1]+coef(model)[2]*xv
se <- sqrt(summary(model)[[6]]^2*(1/n+(xv-xm)^2/ssx))
ci <- s.t * se
uyv<- yv + ci
lyv<- yv - ci
lines(xv, uyv, lty=2)
lines(xv, lyv, lty=2)
}
plot(X, Y, pch = 16)
abline(model)
ci.lines(model)
# Another method
X = trees$Girth; Y = trees$Height
model <- lm(Y~X)
plot(X, Y, pch = 16, ylim=c(60,95))
xv <- seq(8,22,1)
y.c <- predict(model,list(X=xv),int="c") # "c": 95% CI
y.p <- predict(model,list(X=xv),int="p") # "p": prediction
matlines(xv, y.c, lty=c(1,2,2), lwd=2, col="black")
matlines(xv, y.p, lty=c(1,2,2), lwd=1, col=c("black","grey","grey"))
x的总变异,y的总变异。
{r}
x1 <- rep( 0:1, each=500 ); x2 <- rep( 0:1, each=250, length=1000 )
y <- 10 + 5*x1 + 10*x2 - 3*x1*x2 + rnorm(1000,0,2) #values
fit1 <- lm( y ~ x1*x2 )
newdat <- expand.grid( x1=0:1, x2=0:1 )
pred.lm.ci <- predict(fit1, newdat, interval='confidence')
pred.lm.pi <- predict(fit1, newdat, interval='prediction')
pred.lm.ci; pred.lm.pi
# function for plotting error bars from http://monkeysuncle.stanford.edu/?p=485
error.bar <- function(x, y, upper, lower=upper, length=0.1,...){
if(length(x) != length(y) | length(y) !=length(lower) | length(lower) != length(upper))
stop("vectors must be same length")
arrows(x,y+upper, x, y-lower, angle=90, code=3, length=length, ...)}
barx <- barplot(pred.lm.ci[,1], names.arg=1:4, col="blue", axis.lty=1, ylim=c(0,28),
xlab="Levels", ylab="Values")
# Error bar for confidence interval
error.bar(barx, pred.lm.ci[,1], pred.lm.ci[,2]-pred.lm.ci[,1],pred.lm.ci[,1]-pred.lm.ci[,3])
# Error bar for prediction interval
error.bar(barx, pred.lm.pi[,1], pred.lm.pi[,2]-pred.lm.pi[,1],pred.lm.pi[,1]-pred.lm.pi[,3],col='red')
{r}
# Model checking
par(mfrow=c(2,2)); plot(model)
(1)影响因子
影响因素是不一样的。
data:image/s3,"s3://crabby-images/65fe5/65fe57a694755b3a70a06224a15a8fd175d78745" alt=""
x和观测值变化一点点,对模型影响的程度。
回归线最边上的点的变化对影响是非常大的。
data:image/s3,"s3://crabby-images/8248c/8248c3784ec4c9a70ddea58c899c05c870189938" alt=""
丢点这个点,对预测值的影响的大小。是对整体的影响。
data:image/s3,"s3://crabby-images/63bc0/63bc0ba227ac69ff31114de690a994a21ab570e5" alt=""
{r}
# 计算贡献后,计算其斜率
# Model update (remove one outlier)
model2 <- update(model,subset=(X != 15))
summary(model2)
# Slope
coef(model2)[2] # 1.054369
model2$coefficients[2] # 1.054369
(2)线性回归的假定
线性回归不需要x和y分别正态,是要对应x上y上正态分布
方差齐性
线性关系
x没有错误
data:image/s3,"s3://crabby-images/c92e1/c92e186766a0c6c581edf91dd00cdc6904aeff4c" alt=""
data:image/s3,"s3://crabby-images/838b8/838b80b4fe4e7ddaca57ea6397cdc41aaad6089e" alt=""
s代表啥意思呢?这个部分我还是没弄太明白。
data:image/s3,"s3://crabby-images/d4b27/d4b278969811bd84fc02994246dcc3865fe2ea92" alt=""
data:image/s3,"s3://crabby-images/229d9/229d971d0c2df857eadda9015dfbd3d3bbca20c7" alt=""
{r}
reg.tree <- lm(Volume~Height, data=trees)
reg.tree
{r}
summary(reg.tree)
{r}
par(mfrow=c(2,2))
plot(lm(Volume~Height, data=trees))
检查几种情况
{r}
library(car)
fit = lm(Girth ~ Height, data = trees)
# Computes residual autocorrelations and generalized Durbin-Watson statistics
# and their bootstrapped p-values
durbinWatsonTest(fit) # check independence
# P < 0.05, autocorrelation exists.
# component + residual plots (also called partial-residual plots) for linear
# and generalized linear models
crPlots(fit) # check linearity
# the red line (regression) and green line (residual) match well, the linearity is good.
# Score Test for Non-Constant Error Variance
ncvTest(fit) #检查方差齐性的方法
# p = 0.15, error variance is homogeneous
回归中看p值中,看斜率的p值。截距p值过大,则可以将其视为0.
2.Simple linear correlation
{r}
# correlation coefficient and p value
cor(X, Y, use = 'pairwise.complete.obs')
cor.test(X, Y, alternative = c("two.sided"), method = c("pearson"))$p.value
# correlation coefficient
r = SSXY/(SSX*SSY)^.5
data:image/s3,"s3://crabby-images/17ae1/17ae11281e245c025b1ad3eefd22a84509965e57" alt=""
data:image/s3,"s3://crabby-images/f317b/f317bb482e966b8c399677b230a0c62ca648bf7a" alt=""
data:image/s3,"s3://crabby-images/475a6/475a6f26d1c1af838eae44c3d005fa9680eb99d2" alt=""
对相关系数的解释
data:image/s3,"s3://crabby-images/af8e5/af8e5b92e7c6c6a4a5106cb60038d45c328bb379" alt=""
(1)相关性的解释
对相关性的解释
data:image/s3,"s3://crabby-images/8ef66/8ef66ac70fde38ab3fdafcad9e1ffbe2723c88b3" alt=""
相关系数的误差可以这样看出来。
data:image/s3,"s3://crabby-images/fd8ab/fd8abb8fccdd74a0f6b2860f7b2f1fd310c21d07" alt=""
认为这种可能是偶然的情况。即事实上也需要对其进行t检验。
data:image/s3,"s3://crabby-images/49a95/49a95c0ab16ef99512840d2629d749db51e8d5a1" alt=""
相关性的假设检验
data:image/s3,"s3://crabby-images/7bff2/7bff2e78d27c0a258966338861a5e8d70b9ffc3d" alt=""
data:image/s3,"s3://crabby-images/83569/835692ded4fe4fda5d716de4ed26a2335a6a74c3" alt=""
data:image/s3,"s3://crabby-images/1ea5a/1ea5a1890af6386cc101673a006b607cbc5a2f99" alt=""
(2)不同的相关性
data:image/s3,"s3://crabby-images/88299/88299267bcb77b4db93898ac6ee6f42797ed4f02" alt=""
bash
head(mtcars)
plot(mtcars$wt, mtcars$hp)
# Pearson correlation coefficient
cor(mtcars$wt, mtcars$hp) # 0.66
wt.rank = rank(mtcars$wt)
hp.rank = rank(mtcars$hp)
# Spearman correlation coefficient
cor(wt.rank, hp.rank) # 0.77
X = seq(0.5* pi, 1.5*pi, length=100)
Y = 1 - sin(X)
plot(Y, X)
cor(X, Y) # 0.99
cor(rank(X),rank(Y)) # 1
Hmisc这个可以做各种各样的相关系数
library(Hmisc)
head(mtcars)
rcorr(as.matrix(mtcars), type="pearson")
rcorr(as.matrix())
样本量和相关系数决定量p值
连续变量对连续变量的关系