https://github.com/cran/emplik
Raw File
Tip revision: 0a13baf815199c799dedcf0559f4a52598d3f0fd authored by Mai Zhou on 13 August 2014, 00:00:00 UTC
version 0.9-9-5
Tip revision: 0a13baf
el.test.wt.R
eltestwtinC<-function(x,wt,mu){
	pi=x;
	Lx=length(x);
	lam0=0;
 	if (sum(is.na(x))>0)stop('NaNs');	
 	re=.C('eltestwt',
		x=as.numeric(x),
		wt=as.numeric(wt),
		mu1=mu,
		Lx1=Lx,
		pi=as.numeric(pi),
		lamre=lam0
	     )
	return(list(x=re$x, wt=re$wt, prob=re$pi, lam=re$lamre));
 }


el.test.wt <- function(x, wt, mu,usingC=TRUE) {
#x <- as.matrix(x)
#if( ncol(x) != 1 ) stop("x must be a vector") 

if( length(mu) != 1 ) stop("mu must be a scalar")

if(usingC){
return(eltestwtinC(x,wt,mu));
}else{
xmu <- x-mu
allw <- sum(wt)
BU <- 0.02*allw/max(abs(xmu))

lamfun <- function(lam,xmu,wt,allw) { sum(wt*xmu/(allw+lam*xmu)) }

if(lamfun(0,xmu,wt,allw) == 0) lam0 <- 0 
else {
 if( lamfun(0,xmu,wt,allw) > 0 ) {lo <- 0
                                up <- BU
                                while(lamfun(up,xmu,wt,allw)>0)
                                     up <- up + BU
                                 }
 else {up <- 0
      lo <- - BU
      while(lamfun(lo,xmu,wt,allw) < 0 )
           lo <- lo - BU
     }
 lam0 <- uniroot(lamfun,lower=lo,upper=up,tol=1e-9,xmu=xmu,wt=wt,allw=allw)$root
}
pi <- wt/(allw + lam0*xmu)
return(list(x=x, wt=wt, prob=pi, lam=lam0));
}
}
### add output of lam0, 5/2007 
back to top