NetLiabilityCashFlow.java

  1. package org.drip.portfolioconstruction.alm;

  2. /*
  3.  * -*- mode: java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
  4.  */

  5. /*!
  6.  * Copyright (C) 2020 Lakshmi Krishnamurthy
  7.  * Copyright (C) 2019 Lakshmi Krishnamurthy
  8.  * Copyright (C) 2018 Lakshmi Krishnamurthy
  9.  * Copyright (C) 2017 Lakshmi Krishnamurthy
  10.  * Copyright (C) 2016 Lakshmi Krishnamurthy
  11.  *
  12.  *  This file is part of DROP, an open-source library targeting analytics/risk, transaction cost analytics,
  13.  *      asset liability management analytics, capital, exposure, and margin analytics, valuation adjustment
  14.  *      analytics, and portfolio construction analytics within and across fixed income, credit, commodity,
  15.  *      equity, FX, and structured products. It also includes auxiliary libraries for algorithm support,
  16.  *      numerical analysis, numerical optimization, spline builder, model validation, statistical learning,
  17.  *      and computational support.
  18.  *  
  19.  *      https://lakshmidrip.github.io/DROP/
  20.  *  
  21.  *  DROP is composed of three modules:
  22.  *  
  23.  *  - DROP Product Core - https://lakshmidrip.github.io/DROP-Product-Core/
  24.  *  - DROP Portfolio Core - https://lakshmidrip.github.io/DROP-Portfolio-Core/
  25.  *  - DROP Computational Core - https://lakshmidrip.github.io/DROP-Computational-Core/
  26.  *
  27.  *  DROP Product Core implements libraries for the following:
  28.  *  - Fixed Income Analytics
  29.  *  - Loan Analytics
  30.  *  - Transaction Cost Analytics
  31.  *
  32.  *  DROP Portfolio Core implements libraries for the following:
  33.  *  - Asset Allocation Analytics
  34.  *  - Asset Liability Management Analytics
  35.  *  - Capital Estimation Analytics
  36.  *  - Exposure Analytics
  37.  *  - Margin Analytics
  38.  *  - XVA Analytics
  39.  *
  40.  *  DROP Computational Core implements libraries for the following:
  41.  *  - Algorithm Support
  42.  *  - Computation Support
  43.  *  - Function Analysis
  44.  *  - Model Validation
  45.  *  - Numerical Analysis
  46.  *  - Numerical Optimizer
  47.  *  - Spline Builder
  48.  *  - Statistical Learning
  49.  *
  50.  *  Documentation for DROP is Spread Over:
  51.  *
  52.  *  - Main                     => https://lakshmidrip.github.io/DROP/
  53.  *  - Wiki                     => https://github.com/lakshmiDRIP/DROP/wiki
  54.  *  - GitHub                   => https://github.com/lakshmiDRIP/DROP
  55.  *  - Repo Layout Taxonomy     => https://github.com/lakshmiDRIP/DROP/blob/master/Taxonomy.md
  56.  *  - Javadoc                  => https://lakshmidrip.github.io/DROP/Javadoc/index.html
  57.  *  - Technical Specifications => https://github.com/lakshmiDRIP/DROP/tree/master/Docs/Internal
  58.  *  - Release Versions         => https://lakshmidrip.github.io/DROP/version.html
  59.  *  - Community Credits        => https://lakshmidrip.github.io/DROP/credits.html
  60.  *  - Issues Catalog           => https://github.com/lakshmiDRIP/DROP/issues
  61.  *  - JUnit                    => https://lakshmidrip.github.io/DROP/junit/index.html
  62.  *  - Jacoco                   => https://lakshmidrip.github.io/DROP/jacoco/index.html
  63.  *
  64.  *  Licensed under the Apache License, Version 2.0 (the "License");
  65.  *      you may not use this file except in compliance with the License.
  66.  *  
  67.  *  You may obtain a copy of the License at
  68.  *      http://www.apache.org/licenses/LICENSE-2.0
  69.  *  
  70.  *  Unless required by applicable law or agreed to in writing, software
  71.  *      distributed under the License is distributed on an "AS IS" BASIS,
  72.  *      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  73.  *  
  74.  *  See the License for the specific language governing permissions and
  75.  *      limitations under the License.
  76.  */

  77. /**
  78.  * <i>NetLiabilityCashFlow</i> holds the Investor Time Snap's Singular Liability Flow Details.
  79.  *
  80.  *  <br><br>
  81.  *  <ul>
  82.  *      <li><b>Module </b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/PortfolioCore.md">Portfolio Core Module</a></li>
  83.  *      <li><b>Library</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/ALMAnalyticsLibrary.md">Asset Liability Management Analytics</a></li>
  84.  *      <li><b>Project</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/portfolioconstruction/README.md">Portfolio Construction under Allocation Constraints</a></li>
  85.  *      <li><b>Package</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/portfolioconstruction/alm/README.md">Sharpe-Tint Asset Liability Manager</a></li>
  86.  *  </ul>
  87.  *
  88.  * @author Lakshmi Krishnamurthy
  89.  */

  90. public class NetLiabilityCashFlow
  91. {
  92.     private boolean _isAlive = false;
  93.     private boolean _isRetired = false;
  94.     private double _age = java.lang.Double.NaN;
  95.     private double _horizon = java.lang.Double.NaN;
  96.     private double _afterTaxIncome = java.lang.Double.NaN;
  97.     private double _pensionBenefits = java.lang.Double.NaN;
  98.     private double _basicConsumption = java.lang.Double.NaN;
  99.     private double _workingAgeIncome = java.lang.Double.NaN;
  100.     private double _pensionBenefitsDF = java.lang.Double.NaN;
  101.     private double _basicConsumptionDF = java.lang.Double.NaN;
  102.     private double _workingAgeIncomeDF = java.lang.Double.NaN;

  103.     /**
  104.      * NetLiabilityCashFlow Constructor
  105.      *
  106.      * @param age The Investor Age
  107.      * @param isRetired The Retirement Indicator Flag
  108.      * @param isAlive The "Is Alive" Indicator Flag
  109.      * @param horizon The Snapshot's Investment Horizon
  110.      * @param afterTaxIncome The Basic After-Tax Income
  111.      * @param workingAgeIncome The Investor Working Age Income
  112.      * @param pensionBenefits The Investor Pension Benefits
  113.      * @param basicConsumption The Investor Basic Consumption
  114.      * @param workingAgeIncomeDF The Investor Working Age Income Discount Factor
  115.      * @param pensionBenefitsDF The Investor Pension Benefits Discount Factor
  116.      * @param basicConsumptionDF The Investor Basic Consumption Discount Factor
  117.      *
  118.      * @throws java.lang.Exception Thrown if the Inputs are invalid
  119.      */

  120.     public NetLiabilityCashFlow (
  121.         final double age,
  122.         final boolean isRetired,
  123.         final boolean isAlive,
  124.         final double horizon,
  125.         final double afterTaxIncome,
  126.         final double workingAgeIncome,
  127.         final double pensionBenefits,
  128.         final double basicConsumption,
  129.         final double workingAgeIncomeDF,
  130.         final double pensionBenefitsDF,
  131.         final double basicConsumptionDF)
  132.         throws java.lang.Exception
  133.     {
  134.         if (!org.drip.numerical.common.NumberUtil.IsValid (_age = age) ||
  135.             !org.drip.numerical.common.NumberUtil.IsValid (_horizon = horizon) ||
  136.             !org.drip.numerical.common.NumberUtil.IsValid (_afterTaxIncome = afterTaxIncome) ||
  137.             !org.drip.numerical.common.NumberUtil.IsValid (_workingAgeIncome = workingAgeIncome) ||
  138.             !org.drip.numerical.common.NumberUtil.IsValid (_pensionBenefits = pensionBenefits) ||
  139.             !org.drip.numerical.common.NumberUtil.IsValid (_basicConsumption = basicConsumption) ||
  140.             !org.drip.numerical.common.NumberUtil.IsValid (_workingAgeIncomeDF = workingAgeIncomeDF) ||
  141.             !org.drip.numerical.common.NumberUtil.IsValid (_pensionBenefitsDF = pensionBenefitsDF) ||
  142.             !org.drip.numerical.common.NumberUtil.IsValid (_basicConsumptionDF = basicConsumptionDF))
  143.         {
  144.             throw new java.lang.Exception ("NetLiabilityCashFlow Constructor => Invalid Inputs");
  145.         }

  146.         _isAlive = isAlive;
  147.         _isRetired = isRetired;
  148.     }

  149.     /**
  150.      * Retrieve the Investor Age
  151.      *
  152.      * @return The Investor Age
  153.      */

  154.     public double age()
  155.     {
  156.         return _age;
  157.     }

  158.     /**
  159.      * Retrieve the Retirement Indicator Flag
  160.      *
  161.      * @return The Retirement Indicator Flag
  162.      */

  163.     public boolean isRetired()
  164.     {
  165.         return _isRetired;
  166.     }

  167.     /**
  168.      * Retrieve the "Is Alive" Indicator Flag
  169.      *
  170.      * @return The "Is Alive" Indicator Flag
  171.      */

  172.     public boolean isAlive()
  173.     {
  174.         return _isAlive;
  175.     }

  176.     /**
  177.      * Retrieve the Snapshot's Investment Horizon
  178.      *
  179.      * @return The Snapshot's Investment Horizon
  180.      */

  181.     public double horizon()
  182.     {
  183.         return _horizon;
  184.     }

  185.     /**
  186.      * Retrieve the Basic After-Tax Income
  187.      *
  188.      * @return The Basic After-Tax Income
  189.      */

  190.     public double afterTaxIncome()
  191.     {
  192.         return _afterTaxIncome;
  193.     }

  194.     /**
  195.      * Retrieve the Investor Working Age Income
  196.      *
  197.      * @return The Investor Working Age Income
  198.      */

  199.     public double workingAgeIncome()
  200.     {
  201.         return _workingAgeIncome;
  202.     }

  203.     /**
  204.      * Retrieve the Investor Pension Benefits
  205.      *
  206.      * @return The Investor Pension Benefits
  207.      */

  208.     public double pensionBenefits()
  209.     {
  210.         return _pensionBenefits;
  211.     }

  212.     /**
  213.      * Retrieve the Investor Basic Consumption
  214.      *
  215.      * @return The Investor Basic Consumption
  216.      */

  217.     public double basicConsumption()
  218.     {
  219.         return _basicConsumption;
  220.     }

  221.     /**
  222.      * Retrieve the Investor Working Age Income Discount Factor
  223.      *
  224.      * @return The Investor Working Age Income Discount Factor
  225.      */

  226.     public double workingAgeIncomeDF()
  227.     {
  228.         return _workingAgeIncomeDF;
  229.     }

  230.     /**
  231.      * Retrieve the Investor Pension Benefits Discount Factor
  232.      *
  233.      * @return The Investor Pension Benefits Discount Factor
  234.      */

  235.     public double pensionBenefitsDF()
  236.     {
  237.         return _pensionBenefitsDF;
  238.     }

  239.     /**
  240.      * Retrieve the Investor Basic Consumption Discount Factor
  241.      *
  242.      * @return The Investor Basic Consumption Discount Factor
  243.      */

  244.     public double basicConsumptionDF()
  245.     {
  246.         return _basicConsumptionDF;
  247.     }
  248. }