Skip to content

Robust SE & Heteroskedasticity-consistent estimation

10 messages · Achim Zeileis, RATIARISON Eric, Ott-Siim Toomet +1 more

#
On Mon, 10 May 2010, RATIARISON Eric wrote:

            
This is discussed in
   vignette("sandwich-OOP", package = "sandwich")
one of the vignettes accompanying the "sandwich" package that provides the 
vcovHC() function. At the very least, you need an estfun() method which 
extracts the gradient contributions per observation. Then you need a 
bread() function, typically based on the observed Hessian. Then you can 
compute the basic sandwich() estimators.

Best,
Z
#
On 11 May 2010 00:52, Achim Zeileis <Achim.Zeileis at uibk.ac.at> wrote:
Is it possible to implement the estfun() method and the bread()
function in the maxLik package so that vcovHC() can be easily used by
all users of the maxLik package? If yes: should we (Eric, Achim, Ott,
Arne) implement this feature together?

/Arne
#
On Tue, 11 May 2010, Arne Henningsen wrote:

            
Ah, I didn't realize that the request could have been about the "maxLik" 
package (as opposed to generic maximum likelihood estimation).

Yes, bread() should be easy and estfun() is also easy provided you have 
analytical gradients.

The bread() method can simply return
   vcov(x) * number_of_observations

The estfun() method should return an n x k matrix (n = #obs, k = #par) 
where each row contains the gradient contribution of the corresponding 
observation. Thus
   colSums(estfun(x))
would correspond to
   x$gradient
You typically only get the latter from numerical gradients, but with 
analytical gradients you can easily evaluate it observation-wise.

With these two methods available, you can then call
   sandwich(x)
   sandwich(x, adjust = TRUE)
which computes the basic robust standard errors. In HC terminology, these 
are the HC0 and HC1 estimators.

Calling vcovHC() is more difficult because you have to assure that the 
model is based on a single linear predictor. Also I'm not sure about the 
applicability of HC2-HC4 outside the linear regression model.

For more details, see the "sandwich" vignettes.

Best,
Z
#
Thank you all of you,;
I submit you my case:
( Pseudo likehood for exponential family with offset )


loglik <- function(param)  {
   b<-param
   m=as.vector(of+z%*%b)
   ll <- sum(v*m-exp(m))   }


gradlik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     gg<-(v-exp(m))*z      }

hesslik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     hh <- -t(exp(m)*z)%*%z }

resMaxlik <- maxLik(loglik,grad=gradlik,hess=hesslik,start=sc,method="nr",tol=1e-4);

n<-NROW(v)
k<-NROW(resMaxlik$estimate)

meat <-function(obj,nrow,npar,adjust=FALSE,...) 
{ psi<-obj$gradient
  k<-npar
  n<-nrow
  rval<-crossprod(as.matrix(psi))/n
  if (adjust) rval <- n/(n-k)*rval
  rval
}

M<-as.vector(meat(resMaxlik,n,k))
B <-as.matrix(ginv(resMaxlik$hessian))

vcovhc=B*M*B

#new standard errors
coeftest(resMaxlik,vcov.=vcovhc)

 
do you think it's sound good ?




-----Message d'origine-----
De?: Arne Henningsen [mailto:arne.henningsen at googlemail.com] 
Envoy??: mardi 11 mai 2010 08:25
??: Achim Zeileis; RATIARISON Eric; r-help at r-project.org; Ott-Siim Toomet
Objet?: Re: [R] Robust SE & Heteroskedasticity-consistent estimation
On 11 May 2010 00:52, Achim Zeileis <Achim.Zeileis at uibk.ac.at> wrote:
Is it possible to implement the estfun() method and the bread()
function in the maxLik package so that vcovHC() can be easily used by
all users of the maxLik package? If yes: should we (Eric, Achim, Ott,
Arne) implement this feature together?

/Arne
#
Hi,
I think my "meat"function is wrong.
But the "estfun(resMaxlik)" doesn't work;
Error message :
"Erreur dans UseMethod("estfun") : 
  pas de m?thode pour 'estfun' applicable pour un objet de classe "c('maxLik', 'maxim', 'list')""



-----Message d'origine-----
De?: RATIARISON Eric 
Envoy??: mardi 11 mai 2010 11:47
??: 'Arne Henningsen'; Achim Zeileis; r-help at r-project.org; Ott-Siim Toomet
Objet?: RE: [R] Robust SE & Heteroskedasticity-consistent estimation

Thank you all of you,;
I submit you my case:
( Pseudo likehood for exponential family with offset )


loglik <- function(param)  {
   b<-param
   m=as.vector(of+z%*%b)
   ll <- sum(v*m-exp(m))   }


gradlik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     gg<-(v-exp(m))*z      }

hesslik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     hh <- -t(exp(m)*z)%*%z }

resMaxlik <- maxLik(loglik,grad=gradlik,hess=hesslik,start=sc,method="nr",tol=1e-4);

n<-NROW(v)
k<-NROW(resMaxlik$estimate)

meat <-function(obj,nrow,npar,adjust=FALSE,...) 
{ psi<-obj$gradient
  k<-npar
  n<-nrow
  rval<-crossprod(as.matrix(psi))/n
  if (adjust) rval <- n/(n-k)*rval
  rval
}

M<-as.vector(meat(resMaxlik,n,k))
B <-as.matrix(ginv(resMaxlik$hessian))

vcovhc=B*M*B

#new standard errors
coeftest(resMaxlik,vcov.=vcovhc)

 
do you think it's sound good ?




-----Message d'origine-----
De?: Arne Henningsen [mailto:arne.henningsen at googlemail.com] 
Envoy??: mardi 11 mai 2010 08:25
??: Achim Zeileis; RATIARISON Eric; r-help at r-project.org; Ott-Siim Toomet
Objet?: Re: [R] Robust SE & Heteroskedasticity-consistent estimation
On 11 May 2010 00:52, Achim Zeileis <Achim.Zeileis at uibk.ac.at> wrote:
Is it possible to implement the estfun() method and the bread()
function in the maxLik package so that vcovHC() can be easily used by
all users of the maxLik package? If yes: should we (Eric, Achim, Ott,
Arne) implement this feature together?

/Arne
#
On Tue, 11 May 2010, RATIARISON Eric wrote:

            
Yes.
Because you haven't supplied one.

It's as I wrote in my previous mails: You need to write a bread() and an 
estfun() method as specified in my previous mail. Details are in the 
sandwich vignette I already pointed you to. The meat() function does not 
have to be modified.
Z
1 day later
#
Hi, here my new version:
I submit you my case:
( Pseudo likehood for exponential family with offset )

loglik <- function(param)  {
   b<-param
   m=as.vector(of+z%*%b)
   ll <- sum(v*m-exp(m))   }

gradlik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     gg<-(v-exp(m))*z      }

hesslik <- function(param) {
     b<-param
     m=as.vector(of+z%*%b)
     hh <- -t(exp(m)*z)%*%z }

resMaxlik <- maxLik(loglik,grad=gradlik,hess=hesslik,start=sc,method="nr",tol=1e-4);

resMaxlik$offset<-of
resMaxlik$x<-z
resMaxlik$y<-v



estfun <- function(obj,...)
{
m=as.vector(obj$offset+obj$x%*%obj$estimate)
(obj$y-exp(m))*obj$x
}

M <- function(obj, adjust = FALSE, ...)
{
psi <- estfun(obj)
k <- NCOL(psi)
n <- NROW(psi)
rval <- crossprod(as.matrix(psi))/n
if(adjust) rval <- n/(n - k) * rval
rval
}


B <- function(obj, ...)
{ as.matrix(ginv(obj$hessian))
}
     

So S <-B(resMaxlik)*M(resMaxlik)*B(resMaxlik) directly. It's ok.

But I call sandwich function like this : sandwich(resMaxlik,meat.=M,bread.=B)
It returns a error message : "Erreur dans UseMethod("estfun") : 
  pas de m?thode pour 'estfun' applicable pour un objet de classe "c('maxLik', 'maxim', 'list')"





-----Message d'origine-----
De?: Arne Henningsen [mailto:arne.henningsen at googlemail.com] 
Envoy??: mardi 11 mai 2010 08:25
??: Achim Zeileis; RATIARISON Eric; r-help at r-project.org; Ott-Siim Toomet
Objet?: Re: [R] Robust SE & Heteroskedasticity-consistent estimation
On 11 May 2010 00:52, Achim Zeileis <Achim.Zeileis at uibk.ac.at> wrote:
Is it possible to implement the estfun() method and the bread()
function in the maxLik package so that vcovHC() can be easily used by
all users of the maxLik package? If yes: should we (Eric, Achim, Ott,
Arne) implement this feature together?

/Arne
#
Hi,

the error message tells you that there is no method "estfun" for maxLik
objects.  Which is (unfortunately) true.  I try to look at this stuff
during the weekend (given my son sleeps well ;-).

Actually, maxLik can only implement estfun & friends given the user
supplies them.  AFAIK, you need to supply your likelihood function in
"BHHH form", i.e. without 'sum' in the last row in your example below, and
the gradient in the same way.  If your function only returns a single
likelihood value, there is now way maxLik can "distribute" it to
individual observations.

Best,
Ott
4 days later
#
On 13 May 2010 00:41, RATIARISON Eric <ERATIARISON at monceauassurances.com> wrote:
I have added an estfun() method and a bread() method for objects of
class "maxLik" so that you can use "sandwich" now.

Please note:

a) The methods can be applied only if maxLik() was called with
argument "grad" equal to a gradient function or (if no gradient
function is specified) argument "logLik" equal to a log-likelihood
function that return the gradients or log-likelihood values,
respectively, for *each observation* (i.e. in the BHHH form).

b) The package with the new features is not yet available on CRAN but
on R-Forge: http://r-forge.r-project.org/scm/?group_id=254

Please let me know if you experience any problems.

/Arne