Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/anbarief/actuarydesk

Python package for actuary to model and analyze simple products or for actuarial students to practice.
https://github.com/anbarief/actuarydesk

actuarial economics financial insurance mathematics python statistics

Last synced: 3 months ago
JSON representation

Python package for actuary to model and analyze simple products or for actuarial students to practice.

Awesome Lists containing this project

README

        

# Actuarydesk

These modules are aimed to become a tool for actuary to model and analyze simple products or for actuarial students to practice.

Published: 29-8-2020

Author: Arief Anbiya - anbarief (at) live (dot) com

Version: 0.2.0

Requirements: Python >= 3.6, Pandas

Website: https://anbarief.github.io/actuarydesk/

Dataset download for `math_economics_viz`: [dataset link](https://drive.google.com/drive/folders/1n8XRWpmX1tOz1Uu1PaT9gXv9Feu4-k5i?usp=sharing)

---

Installation: `py -m pip install actuarydesk`

---

Example of using the `financial_math.py`: analysing the growth of money from investments made at time 0, 1, and 1.5 with amount of 100, 100, and 200 respectively.
Assuming the interest rate is 0.04 annually for the first year and 0.03 semi-annually after that.

```

import actuarydesk.financial_math as fm

deposits = [fm.Contribution(0, 100), \
fm.Contribution(1, 100), \
fm.Contribution(1.5, 200)]
int_rates = [fm.InterestRate(0, 0.04, 'annual'), \
fm.InterestRate(1, 0.03, 'semi-annual')]
timeline = fm.FinancialTL(deposits, int_rates)

print(timeline.acc_value_at_point(5))
dynamics = timeline.acc_value_dynamics(5, 0.5)
dynamics_df = timeline.acc_value_dynamics_df(5, 0.5)
present_value = timeline.value_at(0)

```

Example of generating a cashflow for a particular actuarial model: insured age 50 with a 15-year life insurance term, the benefit amount is 10000
payable at the end year of death, the level-premium are paid at beginning of each year until term ends or as long as survival.

```

import actuarydesk.financial_math as fm
import actuarydesk.actuarial_tables as at
import actuarydesk.actuarial_math as am

table = at.UK_ONS_2016_to_2018_male
int_rate = [fm.InterestRate(0, 0.05, 'annual')]
x = 50; term = 15;
benefits = [am.Benefit(i, 10000) for i in range(x+1, x+term+1)]
ins_model = am.TermLifeInsurance(x, term, benefits, int_rate, table)
model = am.ActuarialModel(ins_model, ['due', 'annual'], 2020)
reserves = model.reserves_dynamics_df(0.5, 70)
cashflow = model.cashflow_df(65)

```
---

The tables are collected from: https://www.ons.gov.uk/ , https://mort.soa.org/