R/calibev.r

Defines functions calibev

Documented in calibev

calibev<-function(Ys,Xs,total,pikl,d,g,q=rep(1,length(d)),with=FALSE,EPS=1e-6)
{
if(any(is.na(g))) 
   stop("There are missing values in g")
stopifnot((ns <- length(g)) >= 1)
if(min(pikl)==0) 
{ss=NULL
warning("There are zero values in the 'pikl' matrix. The variance estimator can not be computed.\n")
}
piks=as.vector(diag(pikl))
if(!checkcalibration(Xs,d,total,g,EPS)$result) 
stop("The calibration is not possible. The calibration estimator is not computed.\n")
if(is.data.frame(Xs)) Xs=as.matrix(Xs)
if(!is.vector(Ys)) Ys=as.vector(Ys)
if(is.matrix(Xs)) n=nrow(Xs)
else n=length(Xs)
if(ns!=length(Ys) | ns!=length(piks) | ns!=n | ns!=length(d)) stop("The parameters have different sizes.\n")
w=g*d
wtilde=w*q
B=t(Xs*wtilde) 
beta=ginv(B%*%Xs)%*%B%*%Ys
e=Ys-Xs%*%beta
if(!with) e=e*w else e=e*d
ss=0
for(k in 1:ns)
 {ss2=0
 for(l in 1:ns)
   ss2=ss2+(1-piks[k]*piks[l]/pikl[k,l])*e[l]
 ss=ss+e[k]*ss2
 }
list(calest=sum(w*Ys),evar=as.numeric(ss))
}

Try the sampling package in your browser

Any scripts or data that you put into this service are public.

sampling documentation built on Nov. 2, 2023, 6:26 p.m.