Skip to main content

A financial options pricing and analysis library.

Project description

OptPricing: A Quantitative Finance Library for Derivative Pricing and Analysis

Tests Coverage Ruff Docs PyPI version Python 3.10+ License: MIT

optpricing is a Python library for pricing, calibrating, and analyzing financial derivatives. It is built with a focus on architectural clarity, model breadth, and practical usability through a robust API, command-line interface, and an interactive dashboard.

Diljit Singh linkedin.com/in/singhdiljit/


Core Features

  • Model Library: Implements a comprehensive set of models, including:

    • Stochastic Volatility: Heston, SABR
    • Jump-Diffusion: Merton, Bates, Kou, SABR with Jumps
    • Pure Levy Processes: Variance Gamma (VG), Normal Inverse Gaussian (NIG), CGMY, Hyperbolic
    • Interest Rate Models: Vasicek, Cox-Ingersoll-Ross (CIR), Put-Call Parity Implied Rate
    • Local Volatility: Dupire's Equation
  • Pricing Engines: Provides a suite of numerical methods, allowing for technique comparison and validation:

    • Analytic closed-form solutions
    • Numerical integration and FFT-based pricing via characteristic functions
    • Finite difference (PDE) solver using a Crank-Nicolson scheme
    • Binomial and trinomial tree methods (CRR, TOPM, Leisen-Reimer) for European and American options
    • High-performance Monte Carlo engine for European and American options, accelerated with numba, featuring variance reduction techniques (e.g., antithetic variates, control variates, importance sampling)
  • Interfaces:

    • Programmatic API: Use the package as a Python library to build custom financial models in your scripts. Define options, stocks, rates, and models programmatically to compute prices and other metrics.
    • Command-Line Interface (CLI): A robust CLI for live pricing, data management, model calibration, and historical backtesting.
    • Interactive Dashboard (UI): A Streamlit application for visual analysis of option chains, implied volatility surfaces, and model calibrations.
  • Workflow Automation: High-level classes that orchestrate complex tasks like daily calibration runs and out-of-sample performance evaluation.


Quick Start

optpricing is designed for a straightforward installation using pip and is compatible with Python 3.10 and higher.

1. Install the Library

pip install optpricing

2. Download Historical Data

Some models require historical data (e.g., for calibration). Download data for a ticker like SPY:

optpricing data download --ticker SPY

For more details, see the Getting Started Guide.

3. Use the CLI

Price an option directly from the terminal. The command below fetches the live option chain for AAPL, retrieves the current dividend rate, calculates the implied risk-free rate from at-the-money contracts, and prices the contract with Heston’s model using its default pricing technique (FFT):

optpricing price --ticker AAPL --strike 630 --maturity 2025-12-19 --model Heston --param "rho=-0.7" --param "vol_of_vol=0.5"

To price the same contract as an American Option use:

optpricing price -t AAPL -k 210 -T 2025-12-19 --style american --model Heston --param "rho=-0.7" --param "vol_of_vol=0.5"

For more details, see the CLI Guide.

4. Launch the Dashboard

Visualize option chains and model outputs, interact with a pricing calculator featuring 15 models and 10 techniques.

optpricing dashboard

For more details, see the Dashboard Guide.

5. Use the Programmatic API

The most powerful way to use the package is via the API, which provides customization of nearly every aspect of pricing:

from optpricing import Option, OptionType, Rate, Stock, ZeroCouponBond
from optpricing.models import BSMModel, CIRModel, VasicekModel
from optpricing.techniques import ClosedFormTechnique

# Define an option, underlying and rate
option = Option(strike=105, maturity=1.0, option_type=OptionType.CALL)
stock = Stock(spot=100, dividend=0.01)
rate = Rate(rate=0.05)

# Choose a model and technique
bsm_model = BSMModel(params={"sigma": 0.20})
cf_technique = ClosedFormTechnique()

result = cf_technique.price(option, stock, bsm_model, rate)
print(f"The option price is: {result.price:.4f}")


delta = cf_technique.delta(option, stock, bsm_model, rate)
gamma = cf_technique.gamma(option, stock, bsm_model, rate)
vega = cf_technique.vega(option, stock, bsm_model, rate)

print(f"Delta: {delta:.4f}")
print(f"Gamma: {gamma:.4f}")
print(f"Vega:  {vega:.4f}")

target_price = 7.50
iv = cf_technique.implied_volatility(
    option, stock, bsm_model, rate, target_price=target_price
)
print(f"Implied volatility for price ${target_price:.2f}: {iv:.4%}")


# Zero Coupon Bond
bond = ZeroCouponBond(maturity=1.0)
r0_stock = Stock(spot=0.05)  # initial short rate
dummy_rate = Rate(rate=0.0)  # ignored by rate models

vasicek = VasicekModel(params={"kappa": 0.86, "theta": 0.09, "sigma": 0.02})
cir = CIRModel(params={"kappa": 0.86, "theta": 0.09, "sigma": 0.02})

p_vasi = cf_technique.price(bond, r0_stock, vasicek, dummy_rate).price
p_cir = cf_technique.price(bond, r0_stock, cir, dummy_rate).price

print(f"Vasicek ZCB Price: {p_vasi:.4f}")
print(f"CIR ZCB Price:     {p_cir:.4f}")

For more details, see the API Guide.


Documentation

The full documentation includes installation instructions, user guides, examples, and a complete API reference.

Guides

Contributing

Contributions are welcome; see CONTRIBUTING for details.

License

This project is licensed under the MIT License. See LICENSE for details.

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

optpricing-2.3.2.tar.gz (20.0 MB view details)

Uploaded Source

Built Distribution

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

optpricing-2.3.2-py3-none-any.whl (128.1 kB view details)

Uploaded Python 3

File details

Details for the file optpricing-2.3.2.tar.gz.

File metadata

  • Download URL: optpricing-2.3.2.tar.gz
  • Upload date:
  • Size: 20.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for optpricing-2.3.2.tar.gz
Algorithm Hash digest
SHA256 f1150a6c1f56ba52e00cf4a71e3cc408f5587044d8d64cf80bcd68b4abf8a66d
MD5 bf75b0942d547551382de8a1290916d1
BLAKE2b-256 f5b101167ac97e205a260b8d86b7bf1c369fceb948c806b1a927b6d98381c424

See more details on using hashes here.

Provenance

The following attestation bundles were made for optpricing-2.3.2.tar.gz:

Publisher: publish.yml on Diljit22/quantFin

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

File details

Details for the file optpricing-2.3.2-py3-none-any.whl.

File metadata

  • Download URL: optpricing-2.3.2-py3-none-any.whl
  • Upload date:
  • Size: 128.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for optpricing-2.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 03c5cce3fffa24dada451b990efafe93ef6b2db6438842107ce29d288a862a4a
MD5 6615835423ba9cd33bca9dcccda436f9
BLAKE2b-256 7f4a084dfb59a5870368d2857c26e16ec01ef1c0fe1ccc02e1de1c22ec1e82c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for optpricing-2.3.2-py3-none-any.whl:

Publisher: publish.yml on Diljit22/quantFin

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