
Calculate Severe Anemia Prevalence from DHS Data (Standardized)
Source:R/indicator_anemia.R
calc_severe_anemia_dhs.RdComputes anemia indicators from DHS Person Records (PR) data. Returns survey-weighted proportions with logit confidence intervals in standardized long format.
Usage
calc_severe_anemia_dhs(
dhs_pr,
survey_vars = list(cluster = "hv001", weight = "hv005", stratum = "hv022", adm1 =
"hv024", adm2 = NULL, age = "hc1", hemoglobin = "hc56", hemoglobin_adj = "hw53",
present = "hv103", mother = "hv042"),
altitude_adjusted = TRUE,
region_var = NULL,
gps_data = NULL,
gps_vars = list(cluster = "DHSCLUST", lat = "LATNUM", lon = "LONGNUM"),
shapefile = NULL,
admin_level = NULL,
join_nearest = TRUE,
ci_method = "logit"
)Arguments
- dhs_pr
DHS Person Records dataset (data.frame or tibble).
- survey_vars
Named list mapping DHS variable names. Required keys:
cluster: Cluster ID (default: "hv001")weight: Survey weight (default: "hv005", divided by 1,000,000)stratum: Stratum variable (default: "hv022")adm1: First administrative level (default: "hv024")age: Child's age in months (default: "hc1")hemoglobin: Raw hemoglobin in tenths of g/dL (default: "hc56")hemoglobin_adj: Altitude-adjusted hemoglobin (default: "hw53")present: Present in household (default: "hv103")mother: Mother listed in household (default: "hv042")
- altitude_adjusted
Logical. If TRUE (default), uses altitude-adjusted hemoglobin variable (hw53). If FALSE, uses raw hemoglobin (hc56).
- region_var
Optional column name for subnational grouping (e.g., "hv024"). If NULL, defaults to survey_vars$adm1.
- gps_data
Optional DHS GE (GPS) cluster dataset used to attach admin-unit labels when
shapefileis supplied. DefaultNULL.- gps_vars
Named list mapping cluster/lat/lon column names in
gps_data. Defaults to the standard DHS GE names (DHSCLUST,LATNUM,LONGNUM).- shapefile
Optional
sfpolygon dataset whose attributes carry admin labels for the cluster-to-admin spatial join. WhenNULL(default) the spatial join step is skipped.- admin_level
Character vector of admin column names in
shapefileto retain (e.g.c("adm1", "adm2")). DefaultNULL(use all).- join_nearest
Logical. If
TRUE(default), clusters that fall outside any polygon are re-assigned to the nearest polygon. IfFALSE, unmatched clusters are left asNA.- ci_method
Method for confidence intervals. Default: "logit".
Value
Named list of tibbles:
adm0National-level estimates (always present)
adm1Admin-1 estimates (when
region_varor adm1 available)
Each tibble contains columns: survey_id, iso3, iso2, survey_type, survey_year, adm0, adm1, type, geo_source, point, ci_l, ci_u, numerator, denominator, indicator, indicator_code, numerator_description, denominator_description, denominator_code.
Details
Computes six anemia indicators following WHO thresholds. See
severe_anemia_dictionary() for the full indicator list.
See also
severe_anemia_dictionary() for indicator metadata,
calc_severe_anemia_dhs_core() for legacy wide-format output