Calibrating microdata
Project description
MicroCalibrate
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb8d2c29835db7257e886d9f5cdbcc1337d6642cf5772ac6ae5ffb3561cdd72a
|
|
| MD5 |
6ef8e2b11f9cf445bbcb7484b5a93d64
|
|
| BLAKE2b-256 |
f0db6b7179a8f67cb5ce2d7392ee7b0b0744ef66477d65790e02db327b756cee
|
File details
Details for the file microcalibrate-0.21.2-py3-none-any.whl.
File metadata
- Download URL: microcalibrate-0.21.2-py3-none-any.whl
- Upload date:
- Size: 27.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0db982956566d8d5a4f1f06e0191b05506fc040364f87bd37cb6c42f00a5279d
|
|
| MD5 |
26a0688a9c38fb5945601d541a5128c7
|
|
| BLAKE2b-256 |
41443c436340250d01a6d25fd7e684a009207afc1d5691fd893c5fd7db305423
|