---
title: "Introduction to konfound"
author: "Sarah Narvaiz, Qinyun Lin, Joshua M. Rosenberg, Kenneth A. Frank, Spiro Maroulis, Wei Wang, Ran Xu"
date: "`r Sys.Date()`"
bibliography: references.bib
output: rmarkdown::html_vignette
vignette: >
  %\VignetteIndexEntry{Introduction to konfound}
  %\VignetteEngine{knitr::rmarkdown}
  %\VignetteEncoding{UTF-8}
---
  
```{r setup, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>"
)
```

*Note*: This is identical to the following open-access paper: 

> Narvaiz, S., Lin, Q., Rosenberg, J. M., Frank, K. A., Maroulis, S. J., Wang, W., & Xu, R. (2024). konfound: An R Sensitivity Analysis Package to Quantify the Robustness of Causal Inferences. *Journal of Open Source Software, 9*(95), 1-6. https://joss.theoj.org/papers/10.21105/joss.05779.pdf

## Quantifying the Robustness of Inferences

Sensitivity analysis, a statistical method crucial for validating inferences across disciplines, quantifies the conditions that could alter conclusions [@razavi2021]. One line of work is rooted in linear models and foregrounds the sensitivity of inferences to the strength of omitted variables [@frank2000; @cinelli2019]. A more recent approach is rooted in the potential outcomes framework for causal inference and foregrounds how hypothetical changes in a sample would alter an inference if such cases were otherwise observed [@frank2007; @frank2008; @frank2013; @xu2019].

One sensitivity measure is the *Impact Threshold of a Confounding Variable*, or ITCV, which generates statements about the correlation of an omitted, confounding variable with both a predictor of interest and the outcome [@frank2000]. The ITCV index can be calculated for any linear model. The *Robustness of an Inference to Replacement*, RIR, assesses how replacing a certain percentage of cases with counterfactuals of zero treatment effect could nullify an inference [@frank2013]. The RIR index is more general than the ITCV index.

The sensitivity analysis techniques we describe in this paper and implement in the `konfound` R package differ from others in several ways. Unlike @linden2020conducting, whose approach focuses on dichotomous outcomes and omitted variable sensitivity, our approach extends to continuous outcomes and evaluates both changes in estimates and standard errors. @oster2019unobservable focuses only on selection into the treatment based on unobservable variables versus observable variables necessary to nullify an estimate. The ITCV index focuses on the relationship of the unobservable to the predictor of interest and to the outcome. More generally, many others used simulation-based approaches, while our approach uses closed-form expressions to generate a single term representing sensitivity. These techniques, along with others, are reviewed and discussed (along with the ITCV and RIR approaches) in @frank2023.

We have implemented the calculation of both the ITCV and RIR indices in the `konfound` R package. This package is intended to provide an easy-to-use and principled set of sensitivity techniques that are suitable for a range of model and dependent variable types and use cases. Its audience is broad: primarily social scientists, but also interested individuals in other disciplines (e.g., the health sciences). This paper provides an overview of two core functions within the `konfound` package, each of which can calculate the ITCV and RIR indices: `konfound()` and `pkonfound()`. These functions allow users to calculate the robustness of inferences using a model estimated (with R) or using information about a model from a published study, respectively. 

The `konfound` package is available from the Comprehensive R Archive Network (CRAN) at [https://CRAN.R-project.org/package=konfound](https://CRAN.R-project.org/package=konfound); it can be installed via the `install.packages(“konfound”)` function within R.

## Functionality

### **konfound**

This function calculates the ITCV and RIR for models fitted in R. This function currently works for linear models fitted with `lm()`, `glm()`, and `lmer()`. The output printed in the R console is the bias that must be present and the number of cases that would have to be replaced with cases for which there is no effect to nullify the inference.

#### *Example for linear models fit with lm()*

For this example, we will use the `concord1` dataset built into the `konfound` package. This dataset comes from a study that examines the causal mechanism behind household water conservation in a U.S. city.

We will estimate the effect of the following variables on household water consumption in 1981:

- household water consumption in 1980 (`water80`) 
- household income (`income`)
- education level of household survey respondent (`educat`)
- retirement status of respondent (`retire`)
- number of individuals in household in 1980 (`peop80`)

Here is the code we use to fit a linear model using these variables:
    
    m <- lm(water81 ~ water80 + income + educat + retire + peop80, data = concord1)

The results of the model fitting (which can be obtained by running `summary(m)` within R) indicate that all of the predictors apart from `retire` have a statistically significant effect on water consumption. In the example, we focus on the coefficient for `peop80` (β = 225.198, *SE* = 28.704, *t* = 7.845, *p* < .001).

#### *ITCV example for linear models fit with lm()*

Now, let's examine the robustness of the `peop80` effect by calculating the ITCV:

    library(konfound)
    
    konfound(m, peop80, index = "IT")

    ## Impact Threshold for a Confounding Variable:
    ## The minimum impact of an omitted variable to invalidate an inference
    ## for a null hypothesis of 0 effect is based on a correlation of 0.52 with 
    ## the outcome and at  0.52  with the predictor of interest (conditioning on
    ## observed covariates) based on a threshold of 0.089 for statistical 
    ## significance (alpha = 0.05).
    ## 
    ## Correspondingly the impact of an omitted variable (as defined in Frank 
    ## 2000) must be 0.52 X 0.52 = 0.27 to invalidate an inference for a null 
    ## hypothesis of 0 effect. See Frank (2000) for a description of the method.
    ## 
    ## Citation:
    ## Frank, K. (2000). Impact of a confounding variable on the
    ## inference of a regression coefficient. Sociological Methods and Research,
    ## 29(2), 147-194

    ## For more detailed output, consider setting `to_return` to table

    ## To consider other predictors of interest, consider setting `test_all` to
    ## TRUE.

The output indicates that to invalidate the inference that `peop80` has an effect on `water81` using statistical significance as a threshold (e.g., *p* = .05), an omitted variable would have to be correlated at 0.520 with `peop80` and 0.520 with `water81`, conditioning on observed covariates.

#### *RIR example for linear models fit with lm()*

We can also examine the robustness by calculating the RIR:

    konfound(m, peop80, index = "RIR") 

    ## Robustness of Inference to Replacement (RIR):
    ## To invalidate an inference,  74.955 % of the 
    ## estimate would have to be due to bias. 
    ## This is based on a threshold of 56.4 for statistical 
    ## significance (alpha = 0.05).
    ##
    ## To invalidate an inference,  372  observations would 
    ## have to be replaced with cases for which the effect is 0 (RIR = 372).
    ## 
    ## See Frank et al. (2013) for a description of the method.
    ## 
    ## Citation: Frank, K.A., Maroulis, S., Duong, M., and Kelcey, B. (2013).
    ## What would it take to change an inference?
    ## Using Rubin's causal model to interpret the robustness of causal inferences.
    ## Education, Evaluation and Policy Analysis, 35 437-460.

    ## For more detailed output, consider setting `to_return` to table

    ## To consider other predictors of interest, 
    ## consider setting `test_all` to TRUE.

The output presents two interpretations of the RIR. First, 74.956% of the estimated effect of `peop80` on `water81` would have to be attributed to bias to invalidate the inference. Equivalently, we would expect to have to replace 372 out of the 486 households (about 76%) with cases for which `peop80` had no effect to invalidate the inference. We have created guidelines for evaluating the RIR relative to the bias accounted for by observed covariates or published norms [@frank2013; @frank2021].

### **pkonfound**

This function quantifies the sensitivity for analyses that have already been conducted, such as in an already-published study or from analysis carried out using other software. This function calculates how much bias there must be in an estimate to invalidate/sustain an inference, which can be interpreted as the percentage of cases that would have to be replaced (e.g., with cases for which the predictor had no effect on the outcome) to invalidate the inference. It also calculates the impact of an omitted variable necessary to invalidate/sustain an inference for a regression coefficient, where impact is defined as the correlation between the omitted variable and the focal predictor multiplied with the correlation between the omitted variable and the outcome.

#### *ITCV example for a regression analysis*

For this example, the following estimated quantities from an estimated regression model would be entered into the `pkonfound` function: unstandardized beta coefficient for the predictor of interest (`est_eff` = 2), estimated standard error (`std_err` = .4), sample size (`n_obs` = 100), and the number of covariates (`n_covariates` = 3), as follows:

    pkonfound(2, .4, 100, 3, index = "IT")

    ## Impact Threshold for a Confounding Variable:
    ## The minimum impact of an omitted variable to invalidate an inference for 
    ## a null hypothesis of 0 effect is based on a correlation of  0.568 with 
    ## the outcome and at  0.568  with the predictor of interest (conditioning 
    ## on observed covariates) based on a threshold of 0.201 for statistical 
    ## significance (alpha = 0.05).
    ## 
    ## Correspondingly the impact of an omitted variable (as defined in Frank 
    ## 2000) must be 0.568 X 0.568 = 0.323 to invalidate an inference for a null
    ## hypothesis of 0 effect. See Frank (2000) for a description of the method.
    ## 
    ## Citation:
    ## Frank, K. (2000). Impact of a confounding variable on the inference of a 
    ## regression coefficient. Sociological Methods and Research, 29 (2), 147-194

    ## For other forms of output, run ?pkonfound and inspect the to_return argument

    ## For models fit in R, consider use of konfound().

#### *RIR example for a regression analysis*

We can also use the same inputs to calculate output for the RIR index:

    pkonfound(2, .4, 100, 3, index = "RIR")

    ## Robustness of Inference to Replacement (RIR):
    ## To invalidate an inference,  60.29 % of the estimate would have to be 
    ## due to bias. This is based on a threshold of 0.794 for statistical 
    ## significance (alpha = 0.05).
    ## 
    ## To invalidate an inference,  60  observations would have to be replaced 
    ## with cases for which the effect is 0 (RIR = 60).
    ## 
    ## See Frank et al. (2013) for a description of the method.
    ## 
    ## Citation: Frank, K.A., Maroulis, S., Duong, M., and Kelcey, B. (2013).
    ## What would it take to change an inference?
    ## Using Rubin's causal model to interpret the robustness of causal inferences.
    ## Education, Evaluation and Policy Analysis, 35 437-460.

    ## For other forms of output, run ?pkonfound and inspect the to_return argument

    ## For models fit in R, consider use of konfound().

## Doing and Learning More

We have created a website including a Shiny interactive web application at [http://konfound-it.com](http://konfound-it.com) that can be applied to linear models, 2x2 tables resulting corresponding to treatment and control by success and failure conditions, and logistic regression models. We are also developing extensions of the sensitivity analysis techniques described in this paper, including preserving the standard error [@frank2023] and calculating the coefficient of proportionality [@frank2022] for ITCV analyses. Functionality for designs including mediation, hazard functions, differences in difference, and regression discontinuity are also presently under development. Additional documentation on the R package and its future extensions are available at the [http://konfound-it.com](http://konfound-it.com) website.

## Acknowledgements

The research reported here was supported by the Institute of Education Sciences, U.S. Department of Education, through Grant R305D220022 to Michigan State University. The opinions expressed are those of the authors and do not represent views of the Institute or the U.S. Department of Education.

## References