Skip to main content

Build and run complex models composed of formulas and data

Project description

Use Python like a spreadsheet!

https://github.com/fumitoh/modelx/actions/workflows/python-package.yml/badge.svg https://img.shields.io/pypi/pyversions/modelx https://img.shields.io/pypi/v/modelx https://img.shields.io/pypi/l/modelx

What is modelx?

modelx is a numerical computing tool that enables you to use Python like a spreadsheet by quickly defining cached functions. modelx is best suited for implementing mathematical models expressed in a large system of recursive formulas, in such fields as actuarial science, quantitative finance and risk management.

See also the GitHub Copilot instructions for modelx.

Feature highlights

modelx enables you to interactively develop, run and debug complex models in smart ways. modelx allows you to:

  • Define cached functions as Cells objects by writing Python functions

  • Quickly build object-oriented models, utilizing prototype-based inheritance and composition

  • Quickly parameterize a set of formulas and get results for different parameters

  • Trace formula dependency

  • Import and use any Python modules, such as Numpy, pandas, SciPy, scikit-learn, etc..

  • See formula traceback upon error and inspect local variables

  • Save models to text files and version-control with Git

  • Save data such as pandas DataFrames in Excel or CSV files within models

  • Auto-document saved models by Python documentation generators, such as Sphinx

  • Use Spyder with a plugin for modelx (spyder-modelx) to interface with modelx through GUI

  • Export models as Python modules independent of modelx

  • Translate exported models to Cython optimized code and compile them for performance improvement using Cython through modelx-cython

modelx sites

Home page

https://modelx.io

Blog

https://modelx.io/allposts

Documentation site

https://docs.modelx.io

Development

https://github.com/fumitoh/modelx

Discussion Forum

https://github.com/fumitoh/modelx/discussions

modelx on PyPI

https://pypi.org/project/modelx/

Who is modelx for?

modelx is designed to be domain agnostic, so it’s useful for anyone in any field. Especially, modelx is suited for modeling in such fields such as:

  • Quantitative finance

  • Risk management

  • Actuarial science

lifelib (https://lifelib.io) is a library of actuarial and financial models that are built on top of modelx.

How modelx works

Below is an example showing how to build a simple model using modelx. The model performs a Monte Carlo simulation to generate 10,000 stochastic paths of a stock price that follow a geometric Brownian motion and to price an European call option on the stock.

import modelx as mx
import numpy as np

model = mx.new_model()                  # Create a new Model named "Model1"
space = model.new_space("MonteCarlo")   # Create a UserSpace named "MonteCralo"

# Define names in MonteCarlo
space.np = np
space.M = 10000     # Number of scenarios
space.T = 3         # Time to maturity in years
space.N = 36        # Number of time steps
space.S0 = 100      # S(0): Stock price at t=0
space.r = 0.05      # Risk Free Rate
space.sigma = 0.2   # Volatility
space.K = 110       # Option Strike


# Define Cells objects in MonteCarlo from function definitions
@mx.defcells
def std_norm_rand():
    gen = np.random.default_rng(1234)
    return gen.standard_normal(size=(N, M))


@mx.defcells
def stock(i):
    """Stock price at time t_i"""
    dt = T/N; t = dt * i
    if i == 0:
        return np.full(shape=M, fill_value=S0)
    else:
        epsilon = std_norm_rand()[i-1]
        return stock(i-1) * np.exp((r - 0.5 * sigma**2) * dt + sigma * epsilon * dt**0.5)


@mx.defcells
def call_opt():
    """Call option price by Monte Carlo"""
    return np.average(np.maximum(stock(N) - K, 0)) * np.exp(-r*T)

Running the model from IPython is as simple as calling a function:

>>> stock(space.N)      # Stock price at i=N i.e. t=T
array([ 78.58406132,  59.01504804, 115.148291  , ..., 155.39335662,
        74.7907511 , 137.82730703])

>>> call_opt()
16.26919556999345

Changing a parameter is as simple as assigning a value to a name:

>>> space.K = 100   # Cache is cleared by this assignment

>>> call_opt()    # New option price for the updated strike
20.96156962064

You can even dynamically create multiple copies of MonteCarlo with different combinations of r and sigma, by parameterizing MonteCarlo with r and sigma:

>>> space.parameters = ("r", "sigma")   # Parameterize MonteCarlo with r and sigma

>>> space[0.03, 0.15].call_opt()  # Dynamically create a copy of MonteCarlo with r=3% and sigma=15%
14.812014828333284

>>> space[0.06, 0.4].call_opt()   # Dynamically create another copy with r=6% and sigma=40%
33.90481014639403

License

Copyright 2017-2024, Fumito Hamamura

modelx is free software; you can redistribute it and/or modify it under the terms of GNU Lesser General Public License v3 (LGPLv3).

Contributions, productive comments, requests and feedback from the community are always welcome. Information on modelx development is found at Github https://github.com/fumitoh/modelx

Requirements

  • Python 3.7+

  • NetwrkX 2.0+

  • asttokens

  • LibCST

  • Pandas

  • OpenPyXL

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

modelx-0.30.1.tar.gz (200.6 kB view details)

Uploaded Source

Built Distribution

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

modelx-0.30.1-py3-none-any.whl (227.7 kB view details)

Uploaded Python 3

File details

Details for the file modelx-0.30.1.tar.gz.

File metadata

  • Download URL: modelx-0.30.1.tar.gz
  • Upload date:
  • Size: 200.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for modelx-0.30.1.tar.gz
Algorithm Hash digest
SHA256 1854008351b4deb12b21cf3f5b6fb1fdfc4c3461eb2fed5e329256f9f820dc6e
MD5 cf70a31d3fc145e32969c6aa2047f939
BLAKE2b-256 b5de3760f7f7c9ddbf9e87f3ea5c3c6e05edd1cbf2020c0c4feb2d05295b312b

See more details on using hashes here.

File details

Details for the file modelx-0.30.1-py3-none-any.whl.

File metadata

  • Download URL: modelx-0.30.1-py3-none-any.whl
  • Upload date:
  • Size: 227.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for modelx-0.30.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9618838c7865de044137c54545e9918abb31d85b536c62ff48e5309652ceb2e6
MD5 6430144ce601b145eb7b4726925e9557
BLAKE2b-256 b9ee1a6b7a49fff59de0543e3edc86349c3e5a7439764745352c0b4dc5248986

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