Skip to main content

A high-performance, professional-grade (i tried) quantitative option pricing library with Numba and Cython optimizations.

Project description

OptionPricer

A high-performance, professional-grade (to the best of my ability) quantitative finance library for option pricing, optimized heavily via NumPy vectorization, Numba JIT, and Cython AOT compilation.

Development Journey & Architecture

This package was built systematically through strict, high-performance architectural phases:

  1. Phase 1: NumPy Vectorization

    • Eliminated slow Python loops in the core hot paths.
    • Replaced scalar stock price reconstructions with precomputed power arrays, yielding a 3.7x baseline speedup on the binomial lattice.
  2. Phase 2: Advanced Monte Carlo & Variance Reduction

    • Implemented Sobol Quasi-Random sequences to ensure superior space-filling over standard pseudo-random engines.
    • Introduced Antithetic Variates ($Z$ and $-Z$) and Control Variates (using terminal spot price correlation) to achieve up to 800x variance reduction, allowing high precision at drastically lower path counts.
  3. Phase 3: Numba JIT Compilation

    • Compiled the sequential backward-induction algorithms into machine code via LLVM.
    • Handled Python's GIL overhead by isolating numerical loops inside pure-C equivalents, dropping execution time from 48ms down to 5ms for large $N$.
  4. Phase 4: Cython Extensions & Pre-compiled Wheels

    • Statically typed the core mathematical functions (cdef, double[:] memoryviews) into an AOT compiled C-extension to completely eliminate runtime compilation warmup.
  5. Phase 5: Algorithmic Routing

    • Engineered smart heuristics for implied volatility. Routes to Peter Jäckel's 'Let's Be Rational' for standard Euro options, falls back to Newton-Raphson for near-ATM scenarios, and seamlessly redirects to SciPy's robust brentq for deep OTM/ITM and American edge cases.
  6. Phase 6: Professional Software Engineering

    • Enforced strict dependency boundaries.
    • Fully annotated with Python Type Hints and Google-style docstrings.
    • Prepared for distribution via PyPA build and twine CI/CD standards.

Performance Benchmarks

  • Black-Scholes (Analytical): ~0.028 ms
  • Implied Volatility (Brentq Solver): ~0.144 ms
  • Binomial Tree (American, N=1000): ~0.362 ms
  • Monte Carlo (Optimized, N=32,768): ~0.519 ms
  • Binomial Tree (American, N=5000): ~6.766 ms

Usage

pip install optionpricer
from optionpricer import build_tree, monte_carlo_prices, implied_vol

# Price a 5,000-step American Put via Cython
price = build_tree(S=100, K=100, T=1, r=0.05, sigma=0.2, N=5000, option_type="put", american=True)

# Generate 32,000 variance-reduced Monte Carlo paths
mc_price = monte_carlo_prices(S=100, K=100, T=1, r=0.05, sigma=0.2)

Painstakingly written manual code :sob:
buzzword buzzowrd buzzword

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

optionpricer-0.1.8.tar.gz (64.9 kB view details)

Uploaded Source

Built Distribution

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

optionpricer-0.1.8-cp313-cp313-macosx_10_13_universal2.whl (101.9 kB view details)

Uploaded CPython 3.13macOS 10.13+ universal2 (ARM64, x86-64)

File details

Details for the file optionpricer-0.1.8.tar.gz.

File metadata

  • Download URL: optionpricer-0.1.8.tar.gz
  • Upload date:
  • Size: 64.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for optionpricer-0.1.8.tar.gz
Algorithm Hash digest
SHA256 18a31a329e71502235373155de65fe6da811fd8fae3b4fa7f2a1eda698ecfd7a
MD5 61fa8c3018be579d8e0050343eb5866f
BLAKE2b-256 19b07cec4d2201ed6667b1dad239eca931f673215e4381e4d57c26d4a60bcc7c

See more details on using hashes here.

File details

Details for the file optionpricer-0.1.8-cp313-cp313-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for optionpricer-0.1.8-cp313-cp313-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 16679261882a8ea64a1e5153f73cb4e7f4325c9991f019c386e007b6012a2dba
MD5 479bd039dcf5f0a8a7c0db99490a2abf
BLAKE2b-256 0fb1884ec1e242310f96a7a80a252a37fdf0eb7514b6d4b5010e14033360c61b

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