Skip to main content

A package for solving actuarial math and life contingent risks

Project description

This Python package implements fundamental methods for modeling life contingent risks, and closely follows the coverage of traditional topics in actuarial exams and standard texts such as the “Fundamentals of Actuarial Math - Long-term” exam syllabus by the Society of Actuaries, and “Actuarial Mathematics for Life Contingent Risks” by Dickson, Hardy and Waters.

Overview

The package comprises three sets of classes, which:

  1. Implement general actuarial methods

    • Basic interest theory and probability laws

    • Survival functions, expected future lifetimes and fractional ages

    • Insurance, annuity, premiums, policy values, and reserves calculations

  2. Adjust results for

    • Extra mortality risks

    • 1/mthly payment frequency using UDD or Woolhouse approaches

  3. Specify and load a particular form of assumptions

    • Recursion inputs

    • Life table, select life table, or standard ultimate life table

    • Mortality laws, such as constant force of maturity, beta and uniform distributions, or Makeham’s and Gompertz’s laws

Quick Start

  1. pip install actuarialmath

    • also requires numpy, scipy, matplotlib and pandas.

  2. Start Python (version >= 3.10) or Jupyter-notebook

    • Select a suitable subclass to initialize with your actuarial assumptions, such as MortalityLaws (or a special law like ConstantForce), LifeTable, SULT, SelectLife or Recursion.

    • Call appropriate methods to compute intermediate or final results, or to solve parameter values implicitly.

    • Adjust the answers with ExtraRisk or Mthly (or its UDD or Woolhouse) classes.

Examples

# SOA FAM-L sample question 5.7
from actuarialmath import Recursion, Woolhouse
# initialize Recursion class with actuarial inputs
life = Recursion().set_interest(i=0.04)\
                  .set_A(0.188, x=35)\
                  .set_A(0.498, x=65)\
                  .set_p(0.883, x=35, t=30)
# modfy the standard results with Woolhouse mthly approximation
mthly = Woolhouse(m=2, life=life, three_term=False)
# compute the desired temporary annuity value
print(1000 * mthly.temporary_annuity(35, t=30)) #   solution = 17376.7
# SOA FAM-L sample question 7.20
from actuarialmath import SULT, Contract
life = SULT()
# compute the required FPT policy value
S = life.FPT_policy_value(35, t=1, b=1000)  # is always 0 in year 1!
# input the given policy contract terms
contract = Contract(benefit=1000,
                    initial_premium=.3,
                    initial_policy=300,
                    renewal_premium=.04,
                    renewal_policy=30)
# compute gross premium using the equivalence principle
G = life.gross_premium(A=life.whole_life_insurance(35), **contract.premium_terms)
# compute the required policy value
R = life.gross_policy_value(35, t=1, contract=contract.set_contract(premium=G))
print(R-S)   # solution = -277.19

Resources

  1. Jupyter notebook or run in Colab, to solve all sample SOA FAM-L exam questions

  2. User Guide, or download pdf

  3. API reference

  4. Github repo and issues

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

actuarialmath-1.1.0.tar.gz (63.2 kB view details)

Uploaded Source

Built Distribution

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

actuarialmath-1.1.0-py3-none-any.whl (72.6 kB view details)

Uploaded Python 3

File details

Details for the file actuarialmath-1.1.0.tar.gz.

File metadata

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

File hashes

Hashes for actuarialmath-1.1.0.tar.gz
Algorithm Hash digest
SHA256 5eba5480a1cb53faedd6823c0d735ed450211c89f03a8826b016e8b84dd16dfa
MD5 87f997269ee2bfa3044c7a7709d9b773
BLAKE2b-256 911c040643cc529aecd0044ab08799b3dc440e85ccd3516e3fae8c99a98ea88c

See more details on using hashes here.

File details

Details for the file actuarialmath-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: actuarialmath-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 72.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for actuarialmath-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b19990e4378aaa19fe6bc1182b4269faec6617cb62b0677fea1e624fbbb3ff6f
MD5 9d57a13e7160fb9ef8b2968fe0f637a8
BLAKE2b-256 3fae9d2653d7a10280c717574ef7c675b5af6fea3be3ec7aaf608594e8b4fc4b

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