lambda <- 3; pstr1 <- 0.2; x <- (-1):7
(ii <- doipospois(x, lambda, pstr1 = pstr1))
table(roipospois(100, lambda, pstr1 = pstr1))
round(doipospois(1:10, lambda, pstr1 = pstr1) * 100) # Similar?
if (FALSE) x <- 0:10
par(mfrow = c(2, 1)) # One-Inflated Positive Poisson
barplot(rbind(doipospois(x, lambda, pstr1 = pstr1),
dpospois(x, lambda)),
beside = TRUE, col = c("blue", "orange"),
main = paste0("OIPP(", lambda, ", pstr1 = ", pstr1,
") (blue) vs PosPoisson(", lambda, ") (orange)"),
names.arg = as.character(x))
# 0-deflated Pos Poisson:
deflat.limit <- -lambda / (expm1(lambda) - lambda)
newpstr1 <- round(deflat.limit, 3) + 0.001 # Near the boundary
barplot(rbind(doipospois(x, lambda, pstr1 = newpstr1),
dpospois(x, lambda)),
beside = TRUE, col = c("blue","orange"),
main = paste0("ODPP(", lambda, ", pstr1 = ", newpstr1,
") (blue) vs PosPoisson(", lambda, ") (orange)"),
names.arg = as.character(x))
Run the code above in your browser using DataLab