Skip to main content

Calibrating microdata

Project description

MicroCalibrate

CI codecov PyPI version Python Version

MicroCalibrate is a Python package for calibrating survey weights to match population targets, with advanced features including L0 regularization for sparsity, hyperparameter tuning, and robustness evaluation.

Features

  • Survey Weight Calibration: The package adjusts sample weights to match known population totals.
  • L0 Regularization: The system creates sparse weights to reduce dataset size while maintaining accuracy.
  • Automatic Hyperparameter Tuning: The optimization module automatically finds optimal regularization parameters using cross-validation.
  • Robustness Evaluation: The evaluation tools assess calibration stability using holdout validation.
  • Target Assessment: The analysis features help identify which targets complicate calibration.
  • Performance Monitoring: The system tracks calibration progress with detailed logging.
  • Interactive Dashboard: Users can visualize calibration performance at https://microcalibrate.vercel.app/.

Installation

pip install microcalibrate

The package requires the following dependencies:

  • Python version 3.13 or higher is required.
  • PyTorch version 2.7.0 or higher is needed.
  • Additional required packages include NumPy, Pandas, Optuna, and L0-python.

Quick start

Basic calibration

from microcalibrate import Calibration
import numpy as np
import pandas as pd

# Create sample data for calibration
n_samples = 1000
weights = np.ones(n_samples)  # Initial weights are set to one

# Create an estimate matrix that represents the contribution of each record to targets
estimate_matrix = pd.DataFrame({
    'total_income': np.random.normal(50000, 15000, n_samples),
    'total_employed': np.random.binomial(1, 0.6, n_samples),
})

# Set the target values to achieve through calibration
targets = np.array([
    50_000_000,  # This is the total income target
    600,         # This is the total employed target
])

# Initialize the calibration object and configure the optimization parameters
cal = Calibration(
    weights=weights,
    targets=targets,
    estimate_matrix=estimate_matrix,
    epochs=500,
    learning_rate=1e-3,
)

# Perform the calibration to adjust weights
performance_df = cal.calibrate()

# Retrieve the calibrated weights from the calibration object
new_weights = cal.weights

API reference

Calibration class

The Calibration class is the main class for weight calibration.

Parameters:

  • weights: The initial weights array for each record.
  • targets: The target values to match during calibration.
  • estimate_matrix: A DataFrame containing the contribution of each record to targets.
  • estimate_function: An alternative to estimate_matrix that uses a custom function.
  • epochs: The number of optimization iterations to perform (default is 32).
  • learning_rate: The optimization learning rate (default is 1e-3).
  • noise_level: The amount of noise added for robustness (default is 10.0).
  • dropout_rate: The dropout rate for regularization (default is 0).
  • regularize_with_l0: This parameter enables L0 regularization (default is False).
  • l0_lambda: The L0 regularization strength parameter (default is 5e-6).
  • init_mean: The initial proportion of non-zero weights (default is 0.999).
  • temperature: The sparsity control parameter (default is 0.5).

Methods:

  • calibrate(): This method performs the weight calibration process.
  • tune_l0_hyperparameters(): This method automatically tunes L0 parameters using cross-validation.
  • evaluate_holdout_robustness(): This method assesses calibration stability using holdout validation.
  • assess_analytical_solution(): This method analyzes the difficulty of achieving target combinations.
  • summary(): This method returns a summary of the calibration results.

Examples and documentation

For detailed examples and interactive notebooks, see the documentation.

Contributing

Contributions are welcome to the project. Please feel free to submit a Pull Request with your improvements.

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

microcalibrate-0.21.2.tar.gz (200.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

microcalibrate-0.21.2-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file microcalibrate-0.21.2.tar.gz.

File metadata

  • Download URL: microcalibrate-0.21.2.tar.gz
  • Upload date:
  • Size: 200.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for microcalibrate-0.21.2.tar.gz
Algorithm Hash digest
SHA256 bb8d2c29835db7257e886d9f5cdbcc1337d6642cf5772ac6ae5ffb3561cdd72a
MD5 6ef8e2b11f9cf445bbcb7484b5a93d64
BLAKE2b-256 f0db6b7179a8f67cb5ce2d7392ee7b0b0744ef66477d65790e02db327b756cee

See more details on using hashes here.

File details

Details for the file microcalibrate-0.21.2-py3-none-any.whl.

File metadata

File hashes

Hashes for microcalibrate-0.21.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0db982956566d8d5a4f1f06e0191b05506fc040364f87bd37cb6c42f00a5279d
MD5 26a0688a9c38fb5945601d541a5128c7
BLAKE2b-256 41443c436340250d01a6d25fd7e684a009207afc1d5691fd893c5fd7db305423

See more details on using hashes here.

Supported by

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