Skip to main content

A validation framework for causal models.

Project description

Causal Validation

This package provides functionality to define your own causal data generation process and then simulate data from the process. Within the package, there is functionality to include complex components to your process, such as periodic and temporal trends, and all of these operations are fully composable with one another.

A short example is given below

from causal_validation import Config, simulate
from causal_validation.effects import StaticEffect
from causal_validation.plotters import plot
from causal_validation.transforms import Trend, Periodic
from causal_validation.transforms.parameter import UnitVaryingParameter
from scipy.stats import norm

cfg = Config(
    n_control_units=10,
    n_pre_intervention_timepoints=60,
    n_post_intervention_timepoints=30,
)

# Simulate the base observation
base_data = simulate(cfg)

# Apply a linear trend with unit-varying intercept
intercept = UnitVaryingParameter(sampling_dist = norm(0, 1))
trend_component = Trend(degree=1, coefficient=0.1, intercept=intercept)
trended_data = trend_component(base_data)

# Simulate a 5% lift in the treated unit's post-intervention data
effect = StaticEffect(0.05)
inflated_data = effect(trended_data)

# Plot your data
plot(inflated_data)

Examples

To supplement the above example, we have two more detailed notebooks which exhaustively present and explain the functionalty in this package, along with how the generated data may be integrated with AZCausal.

  1. Data Synthesis: We here show the full range of available functions for data generation.
  2. Placebo testing: Validate your model(s) using placebo tests.
  3. AZCausal notebook: We here show how the generated data may be used within an AZCausal model.

Installation

In this section we guide the user through the installation of this package. We distinguish here between users of the package who seek to define their own data generating processes, and developers who wish to extend the existing functionality of the package.

Prerequisites

  • Python 3.10 or higher
  • Hatch (optional, but recommended for developers)

To install the latest stable version, run pip install causal-validation in your terminal.

For Users

  1. It's strongly recommended to use a virtual environment. Create and activate one using your preferred method before proceeding with the installation.
  2. Clone the package git clone git@github.com:amazon-science/causal-validation.git
  3. Enter the package's root directory cd causal-validation
  4. Install the package pip install -e .

For Developers

  1. Follow steps 1-3 from For Users
  2. Create a hatch environment hatch env create
  3. Open a hatch shell hatch shell
  4. Validate your installation by running hatch run dev:test

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

causal_validation-0.0.8.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

causal_validation-0.0.8-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file causal_validation-0.0.8.tar.gz.

File metadata

  • Download URL: causal_validation-0.0.8.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.12

File hashes

Hashes for causal_validation-0.0.8.tar.gz
Algorithm Hash digest
SHA256 d532ba36d7cfc7c6030ec86abbf023fbe0426d8f8d155e225050c7aa1583bbcb
MD5 8447dbf08976b29f0798ca850a3cfa85
BLAKE2b-256 38d5d8ab38ff806a4efa5ca20fb86c66aa003ab45b126ea2ba2d24ecc2d8c8fb

See more details on using hashes here.

File details

Details for the file causal_validation-0.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for causal_validation-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 e387b11810e1de3b2a5429633ca322b07fe70c3e17ae32abec80e3960d4871af
MD5 de86f05909d2ad47b851298f23dcc778
BLAKE2b-256 552ec06e56a063ca61163a5e880109afb31d5e1e7770049de9a0099ac7dd4c43

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page