多元线性回归:用户定义函数错误
multiple linear regression: error in user defined function
我已经为 MLR 编写了函数。但是,输出似乎有问题(请参阅最后的示例)。
但是当我运行代码时,逐行输出是正确的。
mlr <- function(dependentvar, dataset) {
x <- model.matrix(dependentvar ~., dataset) # Design Matrix for x
y <- dependentvar # dependent variable
betas <- solve(crossprod(x))%*%crossprod(x,y) # beta values
SST <- t(y)%*%y - (sum(y)^2/dim(dataset)[1]) # total sum of squares
SSres <- t(y)%*%y -(t(betas)%*%crossprod(x,y)) # sum of squares of residuals
SSreg <- SST - SSres # regression sum of squares
sigmasqr <- SSres/(length(y) - dim(dataset)[2]) # variance or (MSE)
varofbeta <- sigmasqr[1]*solve( crossprod(x)) # variance of beta
cat("SST:", SST,"SSresiduals:", SSres,"SSregression:", SSreg, sep = "\n", append = FALSE)
return(betas)
}
要查看问题,请尝试
mlr(trees$Height, trees)
即使我去掉$
我也遇到同样的问题
Height <- trees$Height
mlr(Height, trees)
使用以下内容:
x <- model.matrix(reformulate(".", dependentvar), dataset)
y <- dataset[[dependentvar]]
并将 dependentvar
作为字符串传入。
示例:
mlr("Height", trees)
我已经为 MLR 编写了函数。但是,输出似乎有问题(请参阅最后的示例)。
但是当我运行代码时,逐行输出是正确的。
mlr <- function(dependentvar, dataset) {
x <- model.matrix(dependentvar ~., dataset) # Design Matrix for x
y <- dependentvar # dependent variable
betas <- solve(crossprod(x))%*%crossprod(x,y) # beta values
SST <- t(y)%*%y - (sum(y)^2/dim(dataset)[1]) # total sum of squares
SSres <- t(y)%*%y -(t(betas)%*%crossprod(x,y)) # sum of squares of residuals
SSreg <- SST - SSres # regression sum of squares
sigmasqr <- SSres/(length(y) - dim(dataset)[2]) # variance or (MSE)
varofbeta <- sigmasqr[1]*solve( crossprod(x)) # variance of beta
cat("SST:", SST,"SSresiduals:", SSres,"SSregression:", SSreg, sep = "\n", append = FALSE)
return(betas)
}
要查看问题,请尝试
mlr(trees$Height, trees)
即使我去掉$
Height <- trees$Height
mlr(Height, trees)
使用以下内容:
x <- model.matrix(reformulate(".", dependentvar), dataset)
y <- dataset[[dependentvar]]
并将 dependentvar
作为字符串传入。
示例:
mlr("Height", trees)