f(yi | lambda1, lambda2) = p f(yi | lambda1) + (1- p) f(yi | lambda2),
where we assume f(yi | lambda) is Poisson with mean lambda and we assume we know p = .4.
Suppose we assume that (lambda1, lambda2) has the prior 1/(lambda1 lambda2). Then the posterior is given (up to a proportionality constant) by
g(lambda1, lambda2 | y) = 1/(lambda1 lambda2) prod from i=1 to 20 [p f(yi | lambda1) + (1- p) f(yi | lambda2)]
Here is some simulated data
25 42 29 29 28 25 21 34 19 11 16 13 15 17 10 16 21 17 16 20
We first transform the parameters to the real-valued parameters
theta1 = log(lambda1), theta2 = log(lambda2)
and write the following function that computes the posterior of (theta1, theta2). Here the input variable data.p is a list that contains two elements: p, the known value of p, and y, the vector of observations.
poisson.mix=function(theta, data.p)
{
lambda1=exp(theta[,1])
lambda2=exp(theta[,2])
y=data.p$y
p=data.p$p
val=0*lambda1
for (i in 1:length(y))
val=val+log(p*dpois(y[i],lambda1)+(1-p)*dpois(y[i],lambda2))
return(val)
}
The data is stored in the vector y. We use the mycontour function to graph the bivariate posterior. We also show a perspective plot of this posterior.
mycontour(poisson.mix,c(2.2,3.8,2.2,3.8),list(y=y,p=.4))
data:image/s3,"s3://crabby-images/f7da2/f7da2d1a9282d37eb92801978da130b1cb43ea78" alt=""
data:image/s3,"s3://crabby-images/ec042/ec0429ab4e9bc8d8b71c5095a50b427073a27d01" alt=""
No comments:
Post a Comment