Description Usage Arguments Details Value Author(s) References See Also Examples
k-fold Cross Validation to find optimal lambda
for Cyclic Coordinate Descent for logistic regression
1 | cv.logit.reg(x, y, k, lam.vec)
|
x |
|
y |
Outcome of length |
k |
Number of folds for k-fold cross validation |
lam.vec |
Vector of penalization parameters |
K-fold cross validation to select optimal lambda for use in cyclic coordinate descent for logistic regression logit.reg
. The optimal value is considered the lambda
value that retuns the lowest testing error over the cross validation. If more than one lambda
value give the minumum testing error, the largest lambda
is selected.
Plot of the cross validation can be viewed through plot.cv.logit.reg
k |
The value of |
lam.vec |
The values of lambda tested. |
lam.opt |
The determined lambda value among |
error.cv |
The prediction error matrix returned by cross validation method. |
num.pred |
The number of selected predictors when using the corresponding lambda value. |
Edward Grant, Kenneth Lange, Tong Tong Wu
Maintainer: Edward Grant edward.m.grant@gmail.com
Wu, T.T., Chen, Y.F., Hastie, T., Sobel E. and Lange, K. (2009). Genome-wide association analysis by lasso penalized logistic regression. Bioinformatics, Volume 25, No 6, 714-721.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | set.seed(1001)
n=250;p=50
beta=c(1,1,1,1,1,rep(0,p-5))
x=matrix(rnorm(n*p),p,n)
xb = t(x) %*% beta
logity=exp(xb)/(1+exp(xb))
y=rbinom(n=length(logity),prob=logity,size=1)
rownames(x)<-1:nrow(x)
colnames(x)<-1:ncol(x)
lam.vec = (0:15)*2
#K-fold cross validation
cv <- cv.logit.reg(x,y,5,lam.vec)
plot(cv)
cv
#Lasso penalized logistic regression using optimal lambda
out<-logit.reg(x,y,cv$lam.opt)
#Re-estimate parameters without penalization
out2<-logit.reg(x[out$selected,],y,0)
out2
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.