inst/Beispiele/Example_Endowment.R

library(LifeInsuranceContracts)
library(MortalityTables)
library(lubridate)
mortalityTables.load("Austria_Census")

################################################################### #
#              DEFINITION TARIF                                  ####
################################################################### #
#
# Beispieltarif:
#    endowment with regular premiums
#    death benefit = survival benefit
#    Costs: Alpha: 4% of premium sum up-front (2,5% Zillmer)
#           Beta:  5% of each premium paid
#           Gamma: 0,1% of sum insured per year over the whole contract maturity
#           Unitcosts: 10 EUR + 5% Premium Sum (max. 50 EUR), during premium period
################################################################### #

costs.Bsp = initializeCosts();
costs.Bsp[["alpha", "SumPremiums", "once"]] = 0.04;
costs.Bsp[["Zillmer", "SumPremiums", "once"]] = 0.025; # deutsche Beschränkung der Zillmerung
costs.Bsp[["beta", "GrossPremium", "PremiumPeriod"]] = 0.05;
costs.Bsp[["gamma", "SumInsured", "PolicyPeriod"]] = 0.001;


initializeCosts(alpha = 0.04, Zillmer = 0.025, beta = 0.05, gamma.contract = 0.001)


costs.Bsp.Unterjaehrigkeit = list("1" = 0.0, "2" = 0.01, "4" = 0.015, "12" = 0.02);

# Stückkosten: 10EUR + 5% PS, maximal 50
costs.Bsp.Stueckkosten       = function (params, values) { min(50, 10 + 0.05*values$premiums[["gross"]]) }


surrender.Bsp = function(surrenderReserve, params, values) {
  n = params$ContractData$policyPeriod - params$ContractData$blockStart;
  # Rückkaufsabschlag linear fallend von 10 auf 0%:
  sf = c(rep(0, params$ContractData$blockStart), 1 - 0.1 * (1 - (0:n)/n));
  surrenderReserve * sf
}

Tarif.Bsp = InsuranceTarif$new(
  name = "Example Tariff - Standard Endowment",
  type = "endowment",
  tarif = "BSP",
  desc = "Gemischte Versicherung (Standardtarif)",
  premiumPeriod = 1,
  #alphaRefundLinear = FALSE,

  mortalityTable = mort.AT.census.2011.unisex,
  i = 0.005,
  costs = costs.Bsp,
  Costs = costs.Bsp,
  unitcosts = costs.Bsp.Stueckkosten,

  premiumFrequencyOrder = -1, # Unterjährige Prämienzahlung wird nicht im BW berücksichtigt, sondern durch Prämienaufschlag
  premiumFrequencyLoading = costs.Bsp.Unterjaehrigkeit,
  premiumRefund = 0,
  tax = 0.04,

  surrenderValueCalculation = surrender.Bsp
);

################################################################### #
# Example contract with dynamiocs                               ####
################################################################### #


contract.Bsp = InsuranceContract$
  new(
    Tarif.Bsp,
    age = 35, policyPeriod = 15, premiumPeriod = 15,
    premiumFrequency = 12,
    sumInsured = 100000,
    contractClosing = as.Date("2020-07-01"),
    id = "Hauptvertrag"
  )$
  addDynamics(t = 5, NewSumInsured = 200000, id = "Dynamik 1", i = 0.05, age = 70)$
  addDynamics(t = 10, NewSumInsured = 250000, id = "Dynamik 2", i = 0.01);

options('LIC.debug.premiumCalculation' = TRUE)
contract.Bsp$premiumWaiver(t = 13)

options('LIC.debug.premiumCalculation' = FALSE)
# exportInsuranceContractExample(contract.Bsp, t = 5);
# showVmGlgExamples(contract.Bsp, t = 10)
#
# exportInsuranceContract.xlsx(contract.Bsp, filename = "BEISPIEL_Contract.xlsx")
#
#
# contract.Bsp$Values$cashFlowsBasic
# contract.Bsp$Values$cashFlows
# contract.Bsp$Values$cashFlowsCosts
# contract.Bsp$Values$presentValues
# # contract.U17_3J$Values$presentValuesCosts
# contract.Bsp$Values$premiumSum
# contract.Bsp$Values$premiums
# contract.Bsp$Values$premiumComposition
# contract.Bsp$Values$reserves


################################################################### #
# Testing premium waivers                                        ####
################################################################### #


contract.Bsp.waiver = InsuranceContract$
  new(
    Tarif.Bsp,
    age = 35, policyPeriod = 15, premiumPeriod = 15,
    premiumFrequency = 12,
    sumInsured = 100000,
    contractClosing = as.Date("2020-07-01"),
    id = "Hauptvertrag"
  )$premiumWaiver(t = 5)
exportInsuranceContract.xlsx(contract.Bsp.waiver, filename = "BEISPIEL_Contract_PrWaiver.xlsx")
kainhofer/r-life-insurance-contracts documentation built on Sept. 18, 2022, 7:56 p.m.