From bf76151ea2fffc1f294a6d108b3d8d2c554e113e Mon Sep 17 00:00:00 2001 From: Spencer Pease Date: Tue, 1 Sep 2020 12:14:52 -0700 Subject: [PATCH 1/5] feat: Inital setup of MACB function This defines the API and core calculation for calculating MACB from an input `data.table`. References #60, #19 --- NAMESPACE | 1 + R/mcab.R | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 53 insertions(+) create mode 100644 R/mcab.R diff --git a/NAMESPACE b/NAMESPACE index 93221c6..9a0fa48 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -17,6 +17,7 @@ export(gen_u5_ax) export(iterate_ax) export(leslie_matrix) export(lifetable) +export(macb_from_nfx) export(mx_ax_to_qx) export(mx_qx_to_ax) export(mx_to_ax) diff --git a/R/mcab.R b/R/mcab.R new file mode 100644 index 0000000..86354eb --- /dev/null +++ b/R/mcab.R @@ -0,0 +1,52 @@ +#' @title Calculate Mean Age of Childbearing from Fertility Rate (MACB) +#' +#' @description +#' The mean age at childbearing is the mean age of mothers at the birth of their +#' children if women were subject throughout their lives to the age-specific +#' fertility rates observed in a given year. +#' +#' See [UNPOP page][1] for more deatils. +#' +#' [1]: https://www.un.org/en/development/desa/population/publications/dataset/fertility/age-childbearing.asp +#' +#' @param dt \[`data.table()`\]\cr A data.table with columns 'age_start', +#' 'age_end', and a column of fertility rates named after `nfx_col`. +#' @param nfx_col \[`character(1)`\]\cr Name of fertility rate column in `dt`. +#' Defualts to "nfx". +#' @inheritParams gen_lifetable_parameters +#' @param value_col \[`character(1)`\]\cr Name of output 'MACB' column. Defaults +#' to "mcab" +#' +#' @return \[`data.table()`\] A data.table with calculated 'MACB' for each +#' unique grouping in `id_cols`, stored in `value_col`. +#' +#' @export +#' +#' @examples +macb_from_nfx <- function(dt, id_cols, nfx_col = "nfx", value_col = "macb") { + + + # Validate parameters ----------------------------------------------------- + + assertthat::assert_that( + assertthat::is.string(nfx_col), + assertthat::is.string(value_col) + ) + + + # Prep id columns --------------------------------------------------------- + + id_cols_no_age <- id_cols[!id_cols %in% c("age_start", "age_end")] + + + # Calculate MACB ---------------------------------------------------------- + + macb_dt <- dt[ + , + get(value_col) = weighted.mean((age_end - age_start) / 2, get(nfx_col)), + by = id_cols_no_age + ] + + return(macb_dt) + +} From ccf14d64a92c40542e78f3cff8016102c8a14a25 Mon Sep 17 00:00:00 2001 From: Spencer Pease Date: Tue, 8 Sep 2020 11:32:47 -0700 Subject: [PATCH 2/5] fix: Output column naming of `macb_from_nfx()` references #60, #19 --- R/mcab.R | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/R/mcab.R b/R/mcab.R index 86354eb..fe8759c 100644 --- a/R/mcab.R +++ b/R/mcab.R @@ -43,10 +43,12 @@ macb_from_nfx <- function(dt, id_cols, nfx_col = "nfx", value_col = "macb") { macb_dt <- dt[ , - get(value_col) = weighted.mean((age_end - age_start) / 2, get(nfx_col)), + .(macb = weighted.mean((age_end + age_start) / 2, get(nfx_col))), by = id_cols_no_age ] + setnames(macb_dt, "macb", value_col) + return(macb_dt) } From ab6602a154babe9398b2d65823286fdffbf980c8 Mon Sep 17 00:00:00 2001 From: Spencer Pease Date: Tue, 8 Sep 2020 11:33:57 -0700 Subject: [PATCH 3/5] test: add macb tests references #60, #19 --- tests/testthat/test-mcab.R | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 tests/testthat/test-mcab.R diff --git a/tests/testthat/test-mcab.R b/tests/testthat/test-mcab.R new file mode 100644 index 0000000..d4f45f9 --- /dev/null +++ b/tests/testthat/test-mcab.R @@ -0,0 +1,23 @@ +test_that("MACB works", { + + asfr_data <- data.table( + asfr = c(.051, .196, .208, .147, .075, .024, .004), + age_start = seq(15, 45, 5), + age_end = seq(20, 50, 5) + ) + + asfr_data2 <- data.table( + nfx = c(.2, .2), + age_start = c(20, 25), + age_end = c(25, 30) + ) + + id_cols <- c("age_start", "age_end") + + macb_dt <- macb_from_nfx(asfr_data, id_cols = id_cols, nfx_col = "asfr") + macb_dt2 <- macb_from_nfx(asfr_data2, id_cols = id_cols) + + testthat::expect_equal(macb_dt$macb, 28.11702, tolerance = 1e-5) + testthat::expect_equal(macb_dt2$macb, 25) + +}) From bf262754432132e121e6611fe761d49206b32139 Mon Sep 17 00:00:00 2001 From: Spencer Pease Date: Tue, 8 Sep 2020 11:35:06 -0700 Subject: [PATCH 4/5] docs: Add macb --- man/macb_from_nfx.Rd | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 man/macb_from_nfx.Rd diff --git a/man/macb_from_nfx.Rd b/man/macb_from_nfx.Rd new file mode 100644 index 0000000..8bd0fdd --- /dev/null +++ b/man/macb_from_nfx.Rd @@ -0,0 +1,32 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/mcab.R +\name{macb_from_nfx} +\alias{macb_from_nfx} +\title{Calculate Mean Age of Childbearing from Fertility Rate (MACB)} +\usage{ +macb_from_nfx(dt, id_cols, nfx_col = "nfx", value_col = "macb") +} +\arguments{ +\item{dt}{[\code{data.table()}]\cr A data.table with columns 'age_start', +'age_end', and a column of fertility rates named after \code{nfx_col}.} + +\item{id_cols}{[\code{character()}]\cr Columns that uniquely identify each row +of \code{dt}. Must include 'age_start' and 'age_end'.} + +\item{nfx_col}{[\code{character(1)}]\cr Name of fertility rate column in \code{dt}. +Defualts to "nfx".} + +\item{value_col}{[\code{character(1)}]\cr Name of output 'MACB' column. Defaults +to "mcab"} +} +\value{ +[\code{data.table()}] A data.table with calculated 'MACB' for each +unique grouping in \code{id_cols}, stored in \code{value_col}. +} +\description{ +The mean age at childbearing is the mean age of mothers at the birth of their +children if women were subject throughout their lives to the age-specific +fertility rates observed in a given year. + +See \href{https://www.un.org/en/development/desa/population/publications/dataset/fertility/age-childbearing.asp}{UNPOP page} for more deatils. +} From 1b2decb59039fff62ad132fafee25b9ddf6766dd Mon Sep 17 00:00:00 2001 From: Spencer Pease Date: Tue, 8 Sep 2020 11:39:52 -0700 Subject: [PATCH 5/5] docs: Add macb example References #60, #19 --- R/mcab.R | 10 ++++++++++ man/macb_from_nfx.Rd | 12 ++++++++++++ 2 files changed, 22 insertions(+) diff --git a/R/mcab.R b/R/mcab.R index fe8759c..809a21d 100644 --- a/R/mcab.R +++ b/R/mcab.R @@ -23,6 +23,16 @@ #' @export #' #' @examples +#' asfr_data <- data.table( +#' asfr = c(.051, .196, .208, .147, .075, .024, .004), +#' age_start = seq(15, 45, 5), +#' age_end = seq(20, 50, 5) +#' ) +#' +#' id_cols <- c("age_start", "age_end") +#' macb_dt <- macb_from_nfx(asfr_data, id_cols = id_cols, nfx_col = "asfr") +#' +#' macb_from_nfx <- function(dt, id_cols, nfx_col = "nfx", value_col = "macb") { diff --git a/man/macb_from_nfx.Rd b/man/macb_from_nfx.Rd index 8bd0fdd..48ff96a 100644 --- a/man/macb_from_nfx.Rd +++ b/man/macb_from_nfx.Rd @@ -30,3 +30,15 @@ fertility rates observed in a given year. See \href{https://www.un.org/en/development/desa/population/publications/dataset/fertility/age-childbearing.asp}{UNPOP page} for more deatils. } +\examples{ +asfr_data <- data.table( + asfr = c(.051, .196, .208, .147, .075, .024, .004), + age_start = seq(15, 45, 5), + age_end = seq(20, 50, 5) + ) + +id_cols <- c("age_start", "age_end") +macb_dt <- macb_from_nfx(asfr_data, id_cols = id_cols, nfx_col = "asfr") + + +}