R/tweedie.R

Defines functions tweedie

Documented in tweedie

##  TWEEDIE.R

tweedie <- function(var.power=0, link.power=1-var.power)
#	Tweedie generalized linear model family
#	Gordon Smyth
#	22 Oct 2002.  Last modified 25 Aug 2020.
{
	lambda <- link.power
	if(is.character(lambda)) {
		m <- match(lambda,c("identity","log","inverse"))
		if(is.na(m)) 
			stop("link.power should be a number")
		else {
			lambda <- c(1,0,-1)[m]
			message("Setting link.power = ",lambda)
		}
	}
	if(lambda==0) {
		linkfun <- function(mu) log(mu)
		linkinv <- function(eta) pmax(exp(eta), .Machine$double.eps)
		mu.eta <- function(eta) pmax(exp(eta), .Machine$double.eps)
		valideta <- function(eta) TRUE
	} else {
		linkfun <- function(mu) mu^lambda
		linkinv <- function(eta) eta^(1/lambda)
		mu.eta <- function(eta) (1/lambda) * eta^(1/lambda - 1)
		valideta <- function(eta) TRUE
	}
	p <- var.power
	if(is.character(p)) {
		m <- match(p,c("gaussian","poisson","Gamma","gamma","inverse.gaussian"))
		if(is.na(m)) 
			stop("var.power should be a number")
		else {
			p <- c(0,1,2,2,3)[m]
			message("Setting var.power = ",p)
		}
	}
	variance <- function(mu) mu^p
	if(p == 0)
		validmu <- function(mu) TRUE
	else if(p > 0)
		validmu <- function(mu) all(mu >= 0)
	else
		validmu <- function(mu) all(mu > 0)
	dev.resids <- function(y, mu, wt) {
		y1 <- y + 0.1*(y == 0)
		if (p == 1)
			theta <- log(y1/mu)
		else
			theta <- ( y1^(1-p) - mu^(1-p) ) / (1-p)
		if (p == 2)
#			Returns a finite somewhat arbitrary residual for y==0, although theoretical value is -Inf
			kappa <- log(y1/mu)
		else
			kappa <- ( y^(2-p) - mu^(2-p) ) / (2-p)
		2 * wt * (y*theta - kappa)
	}	
	initialize <- expression({
		n <- rep(1, nobs)
		mustart <- y + 0.1 * (y == 0)
	})
	aic <- function(y, n, mu, wt, dev) NA
	structure(list(
		family = "Tweedie", variance = variance, dev.resids = dev.resids, aic = aic,
		link = paste("mu^",as.character(lambda),sep=""), linkfun = linkfun, linkinv = linkinv,
		mu.eta = mu.eta, initialize = initialize, validmu = validmu, valideta = valideta), 
		class = "family")
}

Try the statmod package in your browser

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

statmod documentation built on Jan. 6, 2023, 5:14 p.m.