R/availableLaws.R

Defines functions print.availableLaws availableLaws

Documented in availableLaws print.availableLaws

# --------------------------------------------------- #
# Author: Marius D. PASCARIU
# Last update: Fri Feb 04 11:39:09 2022
# --------------------------------------------------- #

#' Check Available Mortality Laws
#'
#' The function returns information about the parametric models that can be
#' called and fitted in the \code{\link{MortalityLaw}} function.
#' For a comprehensive review of the most important mortality laws,
#' Tabeau (2001) is a good starting point.
#'
#' @param law Optional. Default: \code{NULL}. One can extract details about
#' a certain model by specifying its codename.
#' @return The output is of the \code{"availableLaws"} class with the components:
#' @return \item{table}{Table with mortality models and codes to be used in \code{\link{MortalityLaw}}}
#' @return \item{legend}{Table with details about the section of the mortality curve }
#' @references
#' \enumerate{
#' \item{Gompertz, B. (1825). \href{https://www.jstor.org/stable/107756}{On the
#' Nature of the Function Expressive of the Law of Human Mortality, and on a
#' New Mode of Determining the Value of Life Contingencies.}
#' Philosophical Transactions of the Royal Society of London, 115, 513-583.}
#' \item{Makeham, W. (1860).
#' On the Law of Mortality and Construction of Annuity Tables.
#' The Assurance Magazine and Journal of the Institute of Actuaries, 8(6),
#' 301-310. \doi{10.1017/S204616580000126X}}
#' \item{Thiele, T. (1871). On a Mathematical Formula to express the
#' Rate of Mortality throughout the whole of Life, tested by a Series of
#' Observations made use of by the Danish Life Insurance Company of 1871.
#' Journal of the Institute of Actuaries and Assurance Magazine, 16(5), 313-329.
#' \doi{10.1017/S2046167400043688}}
#' \item{Oppermann, L. H. F. (1870). On the graduation of life tables,
#' with special application to the rate of mortality in infancy and childhood.
#' The Insurance Record Minutes from a meeting in the Institute of Actuaries, 42.}
#' \item{Wittstein, T. and D. Bumsted. (1883).
#' \href{https://www.cambridge.org/core/journals/journal-of-the-institute-of-actuaries/article/the-mathematical-law-of-mortality/57A7403B578C84769A463EA2BC2F7ECD}{
#' The Mathematical Law of Mortality.}
#' Journal of the Institute of Actuaries and Assurance Magazine, 24(3), 153-173.}
#' \item{Steffensen, J. (1930). Infantile mortality from an actuarial point of
#' view. Skandinavisk Aktuarietidskrift 13, 272-286.
#' \doi{10.1080/03461238.1930.10416902}}
#' \item{Perks, W. (1932).
#' On Some Experiments in the Graduation of Mortality Statistics.
#' Journal of the Institute of Actuaries, 63(1), 12-57.
#' \doi{10.1017/S0020268100046680}}
#' \item{Harper, F. S. (1936). An actuarial study of infant mortality.
#' Scandinavian Actuarial Journal 1936 (3-4), 234-270.
#' \doi{10.1080/03461238.1936.10405113}}
#' \item{Weibull, W. (1951).
#' \href{http://web.cecs.pdx.edu/~cgshirl/Documents/Weibull-ASME-Paper-1951.pdf}{
#' A statistical distribution function of wide applicability.}
#' Journal of applied mechanics 103, 293-297.}
#' \item{Beard, R. E. (1971).
#' \href{http://longevity-science.org/Beard-1971.pdf}{
#' Some aspects of theories of mortality, cause of
#' death analysis, forecasting and stochastic processes.}
#' Biological aspects of demography 999, 57-68.}
#' \item{Vaupel, J., Manton, K.G., and Stallard, E. (1979).
#' The impact of heterogeneity in individual frailty on the dynamics of
#' mortality. Demography 16(3): 439-454.
#' \doi{10.2307/2061224}}
#' \item{Siler, W. (1979),
#' A Competing-Risk Model for Animal Mortality. Ecology, 60: 750-757.
#' \doi{10.2307/1936612}}
#' \item{Heligman, L., & Pollard, J. (1980). The age pattern of mortality.
#' Journal of the Institute of Actuaries, 107(1), 49-80.
#' \doi{10.1017/S0020268100040257}}
#' \item{Rogers A and Planck F (1983).
#' \href{https://pure.iiasa.ac.at/id/eprint/2210/1/WP-83-102.pdf}{
#' MODEL: A General Program for Estimating Parametrized Model Schedules of Fertility,
#' Mortality, Migration, and Marital and Labor Force Status Transitions.}
#' IIASA Working Paper. IIASA, Laxenburg, Austria: WP-83-102}
#' \item{Martinelle S. (1987). A generalized Perks formula for old-age mortality.
#' Stockholm, Sweden, Statistiska Centralbyran, 1987. 55 p.
#' (R&D Report, Research-Methods-Development, U/STM No. 38)}
#' \item{Carriere J.F. (1992). Parametric models for life tables.
#' Transactions of the Society of Actuaries. Vol.44}
#' \item{Kostaki A. (1992).
#' A nine-parameter version of the Heligman-Pollard formula.
#' Mathematical Population Studies. Vol. 3 277-288.
#' \doi{10.1080/08898489209525346}}
#' \item{Thatcher AR, Kannisto V and Vaupel JW (1998).
#' The force of mortality at ages 80 to 120. Odense Monographs on
#' Population Aging Vol. 5, Odense University Press, 1998. 104, 20 p.
#' Odense, Denmark}
#' \item{Tabeau E. (2001). A Review of Demographic Forecasting Models for
#' Mortality. In: Tabeau E., van den Berg Jeths A., Heathcote C. (eds)
#' Forecasting Mortality in Developed Countries.
#' European Studies of Population, vol 9. Springer, Dordrecht.
#' \doi{10.1007/0-306-47562-6_1}}
#' \item{Finkelstein M. (2012)
#' Discussing the Strehler-Mildvan model of mortality
#' Demographic Research, Vol. 26(9), 191-206.
#' \doi{10.4054/DemRes.2012.26.9}}
#' }
#' @seealso \code{\link{MortalityLaw}}
#' @author Marius D. Pascariu
#' @examples
#' availableLaws()
#' @export
availableLaws <- function(law = NULL){

  if (is.null(law)) {

    table <- as.data.frame(
      matrix(
        ncol = 7,
        byrow = TRUE,
        data = c(
          1825, 'Gompertz', 'mu[x] = A exp[Bx]', 3, 'gompertz', 'mu[x]', TRUE,
          NA, 'Gompertz', 'mu[x] = 1/sigma * exp[(x-M)/sigma)]', 3, 'gompertz0', 'mu[x]', TRUE,
          NA, 'Inverse-Gompertz', 'mu[x] = [1- exp(-(x-M)/sigma)] / [exp(-(x-M)/sigma) - 1]', 2, 'invgompertz', 'mu[x]', TRUE,
          1860, 'Makeham', 'mu[x] = A exp[Bx] + C', 3, 'makeham', 'mu[x]', TRUE,
          NA, 'Makeham', 'mu[x] = 1/sigma * exp[(x-M)/sigma)] + C', 3, 'makeham0', 'mu[x]', TRUE,
          1870, 'Opperman', 'mu[x] = A/sqrt(x) - B + C*sqrt(x)', 1, 'opperman', 'mu[x]', FALSE,
          1871, 'Thiele', 'mu[x] = A exp(-Bx) + C exp[-.5D (x-E)^2] + F exp(Gx)', 6, 'thiele', 'mu[x]', F,
          1883, 'Wittstein', 'q[x] = (1/B) A^-[(Bx)^N] + A^-[(M-x)^N]', 6, 'wittstein', 'q[x]', FALSE,
          1932, 'Perks', 'mu[x] = [A + BC^x] / [BC^-x + 1 + DC^x]', 3, 'perks', 'mu[x]', TRUE,
          1939, 'Weibull', 'mu[x] = 1/sigma * (x/M)^(M/sigma - 1)', 1, 'weibull', 'mu[x]', FALSE,
          NA, 'Inverse-Weibull', 'mu[x] = 1/sigma * (x/M)^[-M/sigma - 1] / [exp((x/M)^(-M/sigma)) - 1]', 2, 'invweibull', 'mu[x]', TRUE,
          1943, 'Van der Maen', 'mu[x] = A + Bx + Cx^2 + I/[N - x]', 4, 'vandermaen', 'mu[x]', TRUE,
          1943, 'Van der Maen', 'mu[x] = A + Bx + I/[N - x]', 5, 'vandermaen2', 'mu[x]', TRUE,
          1960, 'Strehler-Mildvan', 'mu[x] = K * exp[-V0 * (1 - Bx)/D]', 3, 'strehler_mildvan', 'mu[x]', TRUE,
          NA, 'Quadratic', 'mu[x] = A + Bx + Cx^2', 5, 'quadratic', 'mu[x]', TRUE,
          1971, 'Beard', 'mu[x] = A exp(Bx) / [1 + KA exp(Bx)]', 4, 'beard', 'mu[x]', TRUE,
          1971, 'Beard-Makeham', 'mu[x] = A exp(Bx) / [1 + KA exp(Bx)] + C', 4, 'beard_makeham', 'mu[x]', TRUE,
          1979, 'Gamma-Gompertz', 'mu[x] = A exp(Bx) / (1 + AG/B * [exp(Bx) - 1])', 4, 'ggompertz', 'mu[x]', TRUE,
          1979, 'Siler', 'mu[x] = A exp(-Bx) + C + D exp(Ex)', 6, 'siler', 'mu[x]', FALSE,
          1980, 'Heligman-Pollard', 'q[x]/p[x] = A^[(x + B)^C] + D exp[-E log(x/F)^2] + G H^x', 6, 'HP', 'q[x]', FALSE,
          1980, 'Heligman-Pollard', 'q[x] = A^[(x + B)^C] + D exp[-E log(x/F)^2] + GH^x / [1 + GH^x]', 6, 'HP2', 'q[x]', FALSE,
          1980, 'Heligman-Pollard', 'q[x] = A^[(x + B)^C] + D exp[-E log(x/F)^2] + GH^x / [1 + KGH^x]', 6, 'HP3', 'q[x]', FALSE,
          1980, 'Heligman-Pollard', 'q[x] = A^[(x + B)^C] + D exp[-E log(x/F)^2] + GH^(x^K) / [1 + GH^(x^K)]', 6, 'HP4', 'q[x]', FALSE,
          1983, 'Rogers-Planck', 'q[x] = A0 + A1 exp[-Ax] + A2 exp[B(x - u) - exp(-C(x - u))] + A3 exp[Dx]', 6, 'rogersplanck', 'q[x]', FALSE,
          1987, 'Martinelle', 'mu[x] = [A exp(Bx) + C] / [1 + D exp(Bx)] + K exp(Bx)', 6, 'martinelle', 'mu[x]', FALSE,
          1992, 'Carriere', 'l[x] = P1 l[x](weibull) + P2 l[x](invweibull) + P3 l[x](gompertz)', 6, 'carriere1', 'q[x]', TRUE,
          1992, 'Carriere', 'l[x] = P1 l[x](weibull) + P2 l[x](invgompertz) + P3 l[x](gompertz)', 6, 'carriere2', 'q[x]', TRUE,
          1992, 'Kostaki', 'q[x]/p[x] = A^[(x+B)^C] + D exp[-(E_i log(x/F_))^2] + G H^x', 6, 'kostaki', 'q[x]', FALSE,
          1998, 'Kannisto', 'mu[x] = A exp(Bx) / [1 + A exp(Bx)]', 5, 'kannisto', 'mu[x]', TRUE,
          1998, 'Kannisto-Makeham', 'mu[x] = A exp(Bx) / [1 + A exp(Bx)] + C', 5, 'kannisto_makeham', 'mu[x]', TRUE
          )
        )
      )

    colnames(table) <- c(
      'YEAR',
      'NAME',
      'MODEL',
      'TYPE',
      'CODE',
      'FIT',
      "SCALE_X"
      )

    legend <- as.data.frame(
      matrix(
        ncol = 2,
        byrow = TRUE,
        data = c(
          1, "Infant mortality",
          2, "Accident hump",
          3, "Adult mortality",
          4, "Adult and/or old-age mortality",
          5, "Old-age mortality",
          6, "Full age range"
          )
        )
      )

    colnames(legend) <- c("TYPE", "Coverage")
  }

  if (!is.null(law)) {
    A <- availableLaws()
    if (!(law %in% A$table$CODE)) {
      stop(
        "The specified 'law' is not available. ",
        "Run 'availableLaws()' to see the implemented models.",
        call. = FALSE)
    }
    table <- A$table[A$table$CODE %in% law, ]
    legend <- A$legend[A$legend$TYPE %in% unique(table$TYPE), ]
  }

  out <- structure(
    class = "availableLaws",
    list(table = table, legend = legend)
    )
  return(out)
}


#' Print availableLaws
#' @param x An object of class \code{"availableLaws"}
#' @param ... Further arguments passed to or from other methods.
#' @return print info on the console
#' @keywords internal
#' @export
print.availableLaws <- function(x, ...) {
  cat("\nMortality laws available in the package:\n\n")
  print(
    x$table[, 1:5],
    right = FALSE,
    row.names = FALSE
    )

  cat("\nLEGEND:\n")
  print(
    x$legend,
    right = FALSE,
    row.names = FALSE
    )
}

Try the MortalityLaws package in your browser

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

MortalityLaws documentation built on Aug. 8, 2023, 5:10 p.m.