AlmgrenChrissDriftDiscrete.java

  1. package org.drip.execution.optimum;

  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>AlmgrenChrissDriftDiscrete</i> contains the Trading Trajectory generated by the Almgren and Chriss
  79.  * (2000) Scheme under the Criterion of Non-zero Drift. The References are:
  80.  *
  81.  * <br><br>
  82.  *  <ul>
  83.  *      <li>
  84.  *          Almgren, R., and N. Chriss (1999): Value under Liquidation <i>Risk</i> <b>12 (12)</b>
  85.  *      </li>
  86.  *      <li>
  87.  *          Almgren, R., and N. Chriss (2000): Optimal Execution of Portfolio Transactions <i>Journal of
  88.  *              Risk</i> <b>3 (2)</b> 5-39
  89.  *      </li>
  90.  *      <li>
  91.  *          Bertsimas, D., and A. W. Lo (1998): Optimal Control of Execution Costs <i>Journal of Financial
  92.  *              Markets</i> <b>1</b> 1-50
  93.  *      </li>
  94.  *      <li>
  95.  *          Chan, L. K. C., and J. Lakonishak (1995): The Behavior of Stock Prices around Institutional
  96.  *              Trades <i>Journal of Finance</i> <b>50</b> 1147-1174
  97.  *      </li>
  98.  *      <li>
  99.  *          Keim, D. B., and A. Madhavan (1997): Transaction Costs and Investment Style: An Inter-exchange
  100.  *              Analysis of Institutional Equity Trades <i>Journal of Financial Economics</i> <b>46</b>
  101.  *              265-292
  102.  *      </li>
  103.  *  </ul>
  104.  *
  105.  *  <br><br>
  106.  *  <ul>
  107.  *      <li><b>Module </b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/ProductCore.md">Product Core Module</a></li>
  108.  *      <li><b>Library</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/TransactionCostAnalyticsLibrary.md">Transaction Cost Analytics</a></li>
  109.  *      <li><b>Project</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/execution/README.md">Optimal Impact/Capture Based Trading Trajectories - Deterministic, Stochastic, Static, and Dynamic</a></li>
  110.  *      <li><b>Package</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/execution/optimum/README.md">Almgren-Chriss Efficient Trading Trajectories</a></li>
  111.  *  </ul>
  112.  *
  113.  * @author Lakshmi Krishnamurthy
  114.  */

  115. public class AlmgrenChrissDriftDiscrete extends org.drip.execution.optimum.AlmgrenChrissDiscrete {
  116.     private double[] _adblHoldingsDriftAdjustment = null;
  117.     private double[] _adblTradeListDriftAdjustment = null;
  118.     private double _dblResidualHolding = java.lang.Double.NaN;
  119.     private double _dblDriftGainUpperBound = java.lang.Double.NaN;

  120.     /**
  121.      * AlmgrenChrissDriftDiscrete Constructor
  122.      *
  123.      * @param adblExecutionTimeNode Array containing the Trajectory Time Nodes
  124.      * @param adblHoldings Array containing the Holdings
  125.      * @param adblTradeList Array containing the Trade List
  126.      * @param adblHoldingsDriftAdjustment Array containing the Holdings Drift Adjustment
  127.      * @param adblTradeListDriftAdjustment Array containing the Trade List Drift Adjustment
  128.      * @param dblKappaTilda AC2000 Kappa-Tilda
  129.      * @param dblKappa AC2000 Kappa
  130.      * @param dblResidualHolding The Residual Holdings induced by the Drift
  131.      * @param dblDriftGainUpperBound The Upper Bound of the Gain induced by Drift
  132.      * @param dblTransactionCostExpectation The Expected Transaction Cost
  133.      * @param dblTransactionCostVariance The Variance of the Transaction Cost
  134.      * @param dblMarketPower Estimate of the Relative Market Impact Power
  135.      *
  136.      * @throws java.lang.Exception Thrown if the Inputs are Invalid
  137.      */

  138.     public AlmgrenChrissDriftDiscrete (
  139.         final double[] adblExecutionTimeNode,
  140.         final double[] adblHoldings,
  141.         final double[] adblTradeList,
  142.         final double[] adblHoldingsDriftAdjustment,
  143.         final double[] adblTradeListDriftAdjustment,
  144.         final double dblKappaTilda,
  145.         final double dblKappa,
  146.         final double dblResidualHolding,
  147.         final double dblDriftGainUpperBound,
  148.         final double dblTransactionCostExpectation,
  149.         final double dblTransactionCostVariance,
  150.         final double dblMarketPower)
  151.         throws java.lang.Exception
  152.     {
  153.         super (adblExecutionTimeNode, adblHoldings, adblTradeList, dblKappaTilda, dblKappa,
  154.             dblTransactionCostExpectation, dblTransactionCostVariance, dblMarketPower);

  155.         if (null == (_adblHoldingsDriftAdjustment = adblHoldingsDriftAdjustment) || null ==
  156.             (_adblTradeListDriftAdjustment = adblTradeListDriftAdjustment) ||
  157.                 !org.drip.numerical.common.NumberUtil.IsValid (_dblResidualHolding = dblResidualHolding) ||
  158.                     !org.drip.numerical.common.NumberUtil.IsValid (_dblDriftGainUpperBound =
  159.                         dblDriftGainUpperBound))
  160.             throw new java.lang.Exception ("AlmgrenChrissDriftDiscrete Constructor => Invalid Inputs");

  161.         int iNumNode = _adblHoldingsDriftAdjustment.length;

  162.         if (0 == iNumNode || iNumNode != _adblTradeListDriftAdjustment.length + 1)
  163.             throw new java.lang.Exception ("AlmgrenChrissDriftDiscrete Constructor => Invalid Inputs");

  164.         for (int i = 0; i < iNumNode; ++i) {
  165.             if (!org.drip.numerical.common.NumberUtil.IsValid (_adblHoldingsDriftAdjustment[i]))
  166.                 throw new java.lang.Exception ("AlmgrenChrissDriftDiscrete Constructor => Invalid Inputs");

  167.             if (0 != i) {
  168.                 if (!org.drip.numerical.common.NumberUtil.IsValid (_adblTradeListDriftAdjustment[i - 1]))
  169.                     throw new java.lang.Exception
  170.                         ("AlmgrenChrissDriftDiscrete Constructor => Invalid Inputs");
  171.             }
  172.         }
  173.     }

  174.     /**
  175.      * Retrieve the Array of the Holdings Drift Adjustment
  176.      *
  177.      * @return The Array of the Holdings Drift Adjustment
  178.      */

  179.     public double[] holdingsDriftAdjustment()
  180.     {
  181.         return _adblHoldingsDriftAdjustment;
  182.     }

  183.     /**
  184.      * Retrieve the Array of the Trade List Drift Adjustment
  185.      *
  186.      * @return The Array of the Trade List Drift Adjustment
  187.      */

  188.     public double[] tradeListDriftAdjustment()
  189.     {
  190.         return _adblTradeListDriftAdjustment;
  191.     }

  192.     /**
  193.      * Retrieve the Residual Holdings induced by the Drift
  194.      *
  195.      * @return The Residual Holdings induced by the Drift
  196.      */

  197.     public double residualHolding()
  198.     {
  199.         return _dblResidualHolding;
  200.     }

  201.     /**
  202.      * Retrieve the Gain Upper Bound induced by the Drift
  203.      *
  204.      * @return The Gain Upper Bound induced by the Drift
  205.      */

  206.     public double driftGainUpperBound()
  207.     {
  208.         return _dblDriftGainUpperBound;
  209.     }
  210. }