GHK algorithm explained

The GHK algorithm (Geweke, Hajivassiliou and Keane)[1] is an importance sampling method for simulating choice probabilities in the multivariate probit model. These simulated probabilities can be used to recover parameter estimates from the maximized likelihood equation using any one of the usual well known maximization methods (Newton's method, BFGS, etc.). Train[2] has well documented steps for implementing this algorithm for a multinomial probit model. What follows here will apply to the binary multivariate probit model.

Consider the case where one is attempting to evaluate the choice probability of

\Pr(yi
|Xi\beta,

\Sigma)

where
yi

=(y1,...,yJ),(i=1,...,N)

and where we can take

j

as choices and

i

as individuals or observations,
Xi\beta
is the mean and

\Sigma

is the covariance matrix of the model. The probability of observing choice
yi
is
\begin{align} \Pr(yi|Xi\beta,

\Sigma)=&

\int
AJ
\int
A1
*
f
i|Xi\beta,

\Sigma)

*
dy
1...
*
dy
J
\\ \Pr(yi|Xi\beta,

\Sigma)=&\int

1
y*\inA
*
f
i|Xi\beta,

\Sigma)

*
dy
i \end{align}

Where

A=A1 x x AJ

and,

Aj=\begin{cases}(-infty,0]&yj=0\\ (0,infty)&yj=1\end{cases}

Unless

J

is small (less than or equal to 2) there is no closed form solution for the integrals defined above (some work has been done with

J=3

[3]). The alternative to evaluating these integrals closed form or by quadrature methods is to use simulation. GHK is a simulation method to simulate the probability above using importance sampling methods.

Evaluating

\Pr(yi|Xi\beta,

\Sigma)=\int

1
y*\inA
*
f
i|Xi\beta,

\Sigma)

*
dy
i
is simplified by recognizing that the latent data model
*
y
i

=

Xi\beta

+\epsilon

can be rewritten using a Cholesky factorization,

\Sigma=CC'

. This gives
*
y
i

=

Xi\beta

+Cηi

where the

ηi

terms are distributed

N(0,I)

.

Using this factorization and the fact that the

ηi

are distributed independently one can simulate draws from a truncated multivariate normal distribution using draws from a univariate random normal.

For example, if the region of truncation

A

has lower and upper limits equal to

[a,b]

(including a,b =

\pminfty

) then the task becomes

\begin{array}{lcl} a<&

*
y
1

&<b\\ a<&

*
y
2

&<b\ \vdots&\vdots&\vdots\\ a<&

*
y
J

&<b\\ \end{array}

Note:
*
y
i

=

Xi\beta

+Cηi

, substituting:

\begin{array}{lcl} a<&x1\beta1+c11η1&<b\\ a<&x2\beta2+c21η1+c22η2&<b\ \vdots&\vdots&\vdots\\ a<&xJ\betaJ+

J
\sum
k=1

cJ,kηk&<b\\ \end{array}

Rearranging above,

\begin{array}{ccc} a-x1\beta1
c11

&<η1<&

b-x1\beta1\\
c11
a-(x2\beta2+c21η1)
c22

&<η2<&

b-(x2\beta2+c21η1)
c22

\ \vdots&\vdots&\vdots\\

a-(xJ\betaJ+
J-1
\sum
k=1
cJ,k)
cJ,J

&<ηk<&

b-(xJ\betaJ+
J-1
\sum
k=1
cJ,k)
cJ,J

\\ \end{array}

Now all one needs to do is iteratively draw from the truncated univariate normal distribution with the given bounds above. This can be done by the inverse CDF method and noting the truncated normal distribution is given by,

u=

\Phi(
x-\mu
\sigma
)-
\Phi(a-\mu
\sigma
)
\Phi(b-\mu
\sigma
)-
\Phi(a-\mu
\sigma
)

Where

u

will be a number between 0 and 1 because the above is a CDF. This suggests to generate random draws from the truncated distribution one has to solve for

x

giving,

x=\sigmaF-1(u*(F(\beta)-F(\alpha))+F(\alpha))+\mu

where

\alpha=

a-\mu
\sigma

and

\beta=

b-\mu
\sigma

and

F

is the standard normal CDF. With such draws one can reconstruct the
*
y
i
by its simplified equation using the Cholesky factorization. These draws will be conditional on the draws coming before and using properties of normals the product of the conditional PDFs will be the joint distribution of the
*
y
i
,
q(
*
y
i
|X1\beta,

\Sigma)=

*
q(y
1|X1\beta,
*
\Sigma)q(y
1,
X1\beta,

\Sigma)...

*
q(y
J-1
,X1\beta,

\Sigma)

Where

q()

is the multivariate normal distribution.

Because

*
y
j
conditional on

yk,k<j

is restricted to the set

A

by the setup using the Cholesky factorization then we know that

q()

is a truncated multivariate normal. The distribution function of a truncated normal is,
\phi(x-\mu
\sigma
)
\sigma(\Phi(b-\mu)-
\Phi(a-\mu
\sigma
))
\sigma

Therefore,

*
y
j
has distribution,
\begin{align} q(
*
y
i

|

Xi\beta,

\Sigma)&=

1
c11
\phi1(
*
y-x1\beta
j
c11
)
(\Phi1(
b-x1\beta
c11
)-\Phi1(
a-x1\beta
c11
))

x ... x

1
\phi
J(
*
y-(xJ\beta+cJ1η1+cJ2η2+...+cJJ-1ηJ-1)
J
cJJ
)
cJJ
(\Phi(
b-(xJ\beta+cJ1η1+cJ2η2+...+cJJ-1ηJ-1)
cJJ
)-\PhiJ(
a-(xJ\beta+cJ1η1+cJ2η2+...+cJJ-1ηJ-1
cJJ
))
J

\\ &=

J
\prod
1
cjj
\phij(
*
y-
k<j
\sum
k=1
cjkηk
j
cjj
)
j=1
J
\prod
j=1
(\Phij(
b-
k<j
\sum
k=1
cjkηk
cjj
)-\Phi(
a-
k<j
\sum
k=1
cjkηk
cjj
))

\end{align}

where

\phij

is the standard normal pdf for choice

j

.

Because

*
y
j|
*
\{y
k<j
\
} \sim N(\mathbf + \sum_^ c_\eta_k, c_^2) the above standardization makes each term mean 0 variance 1.

Let the denominator

J
\prod
j=1

\Phij(

b-
k<j
\sum
k=1
cjkηk
cjj

)-\Phi(

a-
k<j
\sum
k=1
cjkηk
cjj

)=

J
\prod
j=1

ljj

and the numerator
J
\prod
j=1
1
cjj

\phij(

*
y-
k<j
\sum
k=1
cjkηk
j
cjj

)=fN

(
*
y
i

|

Xi\beta,

\Sigma)

where

fN()

is the multivariate normal PDF.

Going back to the original goal, to evaluate the

\begin{align} \Pr(yi|Xi\beta,

\Sigma)=&

\int
Aj
*
f
i|Xi\beta,

\Sigma)

*
dy
j

\\ \end{align}

Using importance sampling we can evaluate this integral,

\begin{align} \Pr(yi|Xi\beta,

\Sigma)=&

\int
Aj
*
f
i|Xi\beta,

\Sigma)

*
dy
j

\\ =

&\int
Aj
*
f\Sigma)
i|Xi\beta,
q(
*
y
i
|
Xi\beta,
\Sigma)
q(
*
y
i

|

Xi\beta,

\Sigma)

*
dy
j

\\ =&

\int
Aj
*
f\Sigma)
i|Xi\beta,
*
f\Sigma)
i|Xi\beta,
J
\prodljj
j=1
q(
*
y
i

|

Xi\beta,

\Sigma)

*
dy
j

\\ =&Eq(

J
\prod
j=1

ljj)\\ \end{align}

This is well approximated by

1
S
S
\sum
s=1
J
\prod
j=1

ljj

.

Notes and References

  1. Hajivassiliou. Vassilis. CLASSICAL ESTIMATION METHODS FOR LDV MODELS USING SIMULATION. Handbook of econometrics. 1994.
  2. Book: Discrete Choice Methods With Simulation. Train. Kenneth. 2003. Cambridge University Press.
  3. Book: Greene. William. Econometric Analysis. 2003. Prentice Hall.