Skip to main content

Python library for index numbers calculations

Project description

PyIndexNum

PyPI version Python 3.11+ License: MIT Documentation Status

A high-performance Python library for calculating economic index numbers using Polars. Designed for statisticians and economists working with price and quantity indices.

Features

  • High Performance: Built on Polars for efficient data processing of large datasets
  • Comprehensive Index Methods: Support for bilateral and multilateral price/quantity indices
  • Data Preparation Tools: Built-in utilities for data standardization and temporal aggregation
  • Panel Data Handling: Robust methods for dealing with unbalanced panels through removal or imputation
  • Extension Methods: Support for index splicing and rolling window calculations
  • Type Safety: Full type annotations for better IDE support and code reliability

Installation

Using pip

pip install pyindexnum

Using uv

uv add pyindexnum

From source

git clone https://github.com/paluigi/PyIndexNum.git
cd PyIndexNum
uv sync

Quick Start

Here's the typical workflow for calculating economic indices:

import polars as pl
import pyindexnum as pin

# Load your price data
df = pl.read_csv("price_data.csv")

# 1. Standardize column names
df_std = pin.standardize_columns(df, date_col="date", price_col="price", id_col="product_id", quantity_col="quantity")

# 2. Aggregate to desired time frequency
df_agg = pin.aggregate_time(df_std, freq="1mo", agg_type="arithmetic")

# 3. Handle unbalanced panels (optional)
df_balanced = pin.remove_unbalanced(df_agg)
# or
df_imputed = pin.carry_forward_imputation(df_agg, ["aggregated_price", "aggregated_quantity"])

# 4. Calculate bilateral indices (two periods)
laspeyres_idx = pin.laspeyres(df_balanced)
fisher_idx = pin.fisher(df_balanced)

# 5. Calculate multilateral indices (multiple periods)
geks_fisher_idx = pin.geks_fisher(df_agg)

# 6. Apply extension methods (optional)
extended_idx = pin.movement_splice(geks_fisher_idx1, geks_fisher_idx2)

Supported Index Methods

Bilateral Indices (Two-Period Comparisons)

Index Formula Use Case
Jevons Geometric mean of price relatives Unweighted geometric average
Dudot Arithmetic mean of price relatives Unweighted arithmetic average
Carli Ratio of arithmetic means Simple price average comparison
Laspeyres Weighted by base period quantities Fixed basket approach
Paasche Weighted by current period quantities Current basket approach
Fisher Geometric mean of Laspeyres and Paasche Ideal index (time/quantity reversal)
Törnqvist Weighted geometric mean with average shares Symmetric treatment
Walsh Geometric mean with base quantity weights Alternative symmetric approach

Multilateral Indices (Multi-Period Comparisons)

Index Method Description
GEKS-Fisher Chained Fisher indices Most widely used multilateral method
GEKS-Törnqvist Chained Törnqvist indices Alternative chaining approach
Geary-Khamis System of equations Global approach
Time Product Dummy Regression-based Econometric approach

Extension Methods

  • Movement Splice: Chain indices using movement ratios
  • Window Splice: Moving window chaining
  • Half Splice: Half-year overlapping windows
  • Mean Splice: Average of overlapping windows
  • Fixed Base Rolling Window: Rolling window with fixed base

Data Requirements

Your data should contain:

  • Date column: Date or datetime values
  • Price column: Numeric price observations
  • Product ID column: Unique identifier for each product/variety
  • Quantity column: Numeric quantities (required for weighted indices)

Example data structure:

┌────────────┬────────────┬───────┬──────────┐
│ date       ┆ product_id ┆ price ┆ quantity │
│ ---        ┆ ---        ┆ ---   ┆ ---      │
│ date       ┆ str        ┆ f64   ┆ f64      │
╞════════════╪════════════╪═══════╪══════════╡
│ 2023-01-01 ┆ A          ┆ 100.0 ┆ 10.0     │
│ 2023-01-01 ┆ B          ┆ 200.0 ┆ 5.0      │
│ 2023-02-01 ┆ A          ┆ 105.0 ┆ 12.0     │
│ 2023-02-01 ┆ B          ┆ 210.0 ┆ 4.5      │
└────────────┴────────────┴────────────┴──────────┘

API Overview

Data Preparation

# Standardize column names and types
df_std = pin.standardize_columns(df, date_col="date", price_col="price", id_col="id")

# Aggregate time series data
df_agg = pin.aggregate_time(df_std, freq="1mo", agg_type="weighted_arithmetic")

# Handle unbalanced panels
df_balanced = pin.remove_unbalanced(df_agg)
df_imputed = pin.carry_forward_imputation(df_agg, ["price", "quantity"])

Index Calculation

# Bilateral indices
jevons = pin.jevons(df)
laspeyres = pin.laspeyres(df)
fisher = pin.fisher(df)

# Multilateral indices
geks = pin.geks_fisher(df)
gk = pin.geary_khamis(df)

Extensions

# Splicing methods
movement_spliced = pin.movement_splice(multilateral_index1, multilateral_index2)
window_spliced = pin.window_splice(multilateral_index1, multilateral_index2)

Documentation

Full documentation is available at https://pyindexnum.readthedocs.io/

Contributing

PyIndexNum is an open-source project and welcomes contributions! See our contributing guide for details.

Development Setup

# Clone and setup
git clone https://github.com/paluigi/PyIndexNum.git
cd PyIndexNum
uv sync --dev

# Run tests
uv run pytest

# Build documentation
cd docs && make html

Areas for Contribution

  • New index methods and formulations
  • Performance optimizations
  • Additional data validation
  • Enhanced documentation and examples
  • Bug fixes and improvements

Citation

If you use PyIndexNum in your research, please cite:

@software{pyindexnum,
  title = {PyIndexNum: A Python Library for Economic Index Numbers},
  author = {Palumbo, Luigi, and Yu, Mengting},
  url = {https://github.com/paluigi/PyIndexNum},
  version = {0.1.0},
}

License

PyIndexNum is licensed under the MIT License. See LICENSE for details.

Related Projects

  • Polars: The high-performance DataFrame library that powers PyIndexNum
  • NumPy: Fundamental package for scientific computing

Built with ❤️ for the economic statistics community

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

pyindexnum-0.1.1.tar.gz (86.2 kB view details)

Uploaded Source

Built Distribution

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

pyindexnum-0.1.1-py3-none-any.whl (18.8 kB view details)

Uploaded Python 3

File details

Details for the file pyindexnum-0.1.1.tar.gz.

File metadata

  • Download URL: pyindexnum-0.1.1.tar.gz
  • Upload date:
  • Size: 86.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyindexnum-0.1.1.tar.gz
Algorithm Hash digest
SHA256 f89e4babcbe5fe87e04ac57c894be2851afb126d461052712ca206db34dd2681
MD5 d12f87baccbf17b263608c96bf2d628c
BLAKE2b-256 cc67f594716f037394faa0127dda6a2d596b3695214ed35127fc03bc31a24fa8

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyindexnum-0.1.1.tar.gz:

Publisher: python-publish.yml on paluigi/PyIndexNum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyindexnum-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: pyindexnum-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 18.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyindexnum-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 384fcfbc64bbd20c86e9d6a53d3aad6f27106617b55237196f4a45ae04c56b78
MD5 458f81bc0ce60b5bebe54d643afd2142
BLAKE2b-256 5c59f898263ed7d466fac17ab7e8db9486f4eead0012572dd4eb982904e9e7f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyindexnum-0.1.1-py3-none-any.whl:

Publisher: python-publish.yml on paluigi/PyIndexNum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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