constrOptim<-function(theta,f,grad,ui,ci,mu=0.0001,control=list(), method=if(is.null(grad)) "Nelder-Mead" else "BFGS", outer.iterations=100,outer.eps=0.00001,...){ if (!is.null(control$fnscale) && control$fnscale<0) mu<- -mu ##maximizing R<-function(theta,theta.old,...){ ui.theta<-ui%*%theta gi<- ui.theta-ci if (any(gi<0)) return(NaN) gi.old<-ui%*%theta.old-ci bar<-sum( gi.old*log(gi)-ui.theta) if (!is.finite(bar)) bar<- -Inf f(theta,...)-mu*bar } dR<-function(theta,theta.old,...){ ui.theta<-ui%*%theta gi<-drop(ui.theta-ci) gi.old<-drop(ui%*%theta.old-ci) dbar<-colSums( ui*gi.old/gi-ui) grad(theta,...)-mu*dbar } if (any(ui%*%theta-ci<=0)) stop("initial value not feasible") obj<-f(theta,...) r<-R(theta,theta,...) for(i in 1:outer.iterations){ obj.old<-obj r.old<-r theta.old<-theta fun<-function(theta,...){ R(theta,theta.old,...)} gradient<-function(theta,...) { dR(theta,theta.old,...)} a<-optim(theta.old, fun, gradient, control=control,method=method,...) r<-a$value if (is.finite(r) && is.finite(r.old) && abs(r-r.old)/(outer.eps+abs(r-r.old))obj.old) break } if (i==outer.iterations){ a$convergence<-7 a$message<-"Barrier algorithm ran out of iterations and did not converge" } if (mu>0 && obj>obj.old){ a$convergence<-11 a$message<-paste("Objective function increased at outer iteration",i) } if (mu<0 && obj