Projection horizon

Actuarial cash flow models predict the future. During development, actuaries need to decide on the projection horizon of the cash flow model.

In this post, we will discuss how to decide on the horizon and how to set it up in the model's settings.


List of content:

  1. Maximal calculation period (T_MAX_CALCULATION)
  2. Maximal output period (T_MAX_OUTPUT)

While deciding on the projection horizon, it's worth taking into consideration two aspects:

  • precision - the longer the projection horizon, the higher the precision of the results,
  • runtime - the shorter the projection horizon, the faster the model.

Let's see how the maximal calculation period impacts the results. For this post, we will use the cashflower package. In particular, we wil discuss two settings: T_MAX_CALCULATION and T_MAX_OUTPUT.

Maximal calculation period

The projection horizon is one of the cash flow model's settings. The setting is called T_MAX_CALCULATION and its default value is 720 months (60 years). The value is set in the settings.py script.

# settings.py
settings = {
  # ...
  "T_MAX_CALCULATION": 720,
  # ...
}

Should we change maximal calculation period?

If you are not sure what maximal calculation period to use, it's always better to be on the safe side and set it to a high number. The maximum number that is used in life insurance is usually 1440 (120 years). This is because most of the Statistics Offices publish mortality rates up to 120 years old. After the age of 120, the probability of death is assumed to be 100%.

However, if you know that the insurance product does not last that long, you can decrease it. For example, if the insurance product is sold only to adults or only to pensioners, then the horizon of 120 years is unnecessarily long.

Let's see how it works on a simple example.

In our example, there is a payment of €100 is made each month for a year.

# model.py
@variable()
def payment(t):
    if 1 <= t <= 12:
        return 100
    return 0

We want to calculate the total value of future payments.

# model.py
@variable()
def future_payments(t):
    if t == settings["T_MAX_CALCULATION"]:
        return payment(t)
    return payment(t) + future_payments(t+1)

The default value of the T_MAX_CALCULATION setting is 720 (60 months).

The result of the total payments is correctly calculated to €1200.

# settings.py
settings = {
  # ...
  "T_MAX_CALCULATION": 720,
  # ...
}

# output
  t  payment  future_payments
  0        0             1200
  1      100             1200
  2      100             1100
  3      100             1000
  4      100              900
  5      100              800
  6      100              700
  7      100              600
  8      100              500
  9      100              400
 10      100              300
 11      100              200
 12      100              100
 13        0                0
...
719        0                0
720        0                0

The cash flows only appear until the 12th period. So if we change the T_MAX_CALCULATION setting to 12, there will be no impact on the result. Let's try it out.

# settings.py
settings = {
  # ...
  "T_MAX_CALCULATION": 12,
  # ...
}

# output
  t  payment  future_payments
  0        0             1200
  1      100             1200
  2      100             1100
  3      100             1000
  4      100              900
  5      100              800
  6      100              700
  7      100              600
  8      100              500
  9      100              400
 10      100              300
 11      100              200
 12      100              100

The total value of future payments is again correctly calculated and amounts to €1200.

However, if we incorrectly set the T_MAX_CALCULATION setting to something lower than 12, then we will get incorrect results. Let's set the maximal calculation period to 8.

# settings.py
settings = {
  # ...
  "T_MAX_CALCULATION": 8,
  # ...
}

# output
 t  payment  future_payments
 0        0              800
 1      100              800
 2      100              700
 3      100              600
 4      100              500
 5      100              400
 6      100              300
 7      100              200
 8      100              100

The value of future payments has been calculated as €800 instead of €1200. This is an incorrect answer because we have decreased the horizon too much.

Maximal output period

So far, we have discussed the T_MAX_CALCULATION setting which reflects the projection horizon for the underlying calculation.

A similar setting is T_MAX_OUTPUT. The T_MAX_OUTPUT setting reflects how many projection periods we want in the output file.

Often, these two values are the same. However, if you need only some results at t=0 there is no need to save results for all periods. Fewer projection periods in the output file mean smaller files and faster post-processing.

For example, let's set T_MAX_CALCULATION to 12 and T_MAX_OUTPUT to 0.

# settings.py
settings = {
  # ...
  "T_MAX_CALCULATION": 12,
  "T_MAX_OUTPUT": 0,
  # ...
}

Let's take a look at the results.

# output
  t  payment  future_payments
  0        0             1200

The model has calculated the correct value for future payments but saved a file with only one row. If we only need results for t=0 then it's enough. The file is smaller and easier to handle.

The value of T_MAX_OUTPUT can not exceed the value of T_MAX_CALCULATION. If the user sets T_MAX_OUTPUT to 100 and T_MAX_CALCULATION to 12, there will be anyway only results up to the 12th period.


Do you have any issues or questions? You can raise them on the GitHub repository. You can also use the comment section under this post!

Read also:

Log in to add your comment.