Skip to main content

Add your description here

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(df_agg, base_indices=[1.0, 1.05, 1.12])

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(df, base_indices)
window_spliced = pin.window_splice(df, window_size=13)

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 = {Luigi},
  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
  • pandas: Alternative DataFrame library
  • 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.0.tar.gz (119.6 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.0-py3-none-any.whl (18.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyindexnum-0.1.0.tar.gz
  • Upload date:
  • Size: 119.6 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.0.tar.gz
Algorithm Hash digest
SHA256 a76d250f05a8b7328455c8e805ed6cf5981228544bc83c439e8ed00a36715adc
MD5 9f72c0c6408605db8fa8066b9ddb5fd0
BLAKE2b-256 472da4f6602c11173392d10d44ad5c58341dc8b86005c472858150467f066e68

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyindexnum-0.1.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: pyindexnum-0.1.0-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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 649320eaa7a1e222ffe446c16dd70c65843bb08161d2096a9fb3f524d7e29fa0
MD5 bb6ca5ce414130897d8cec34f2d552ea
BLAKE2b-256 d1c4fb08f0024f03fd1ade7403215a477e9321ce2817ab400aec8f56595decf0

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyindexnum-0.1.0-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