PowerImpactContinuous.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>PowerImpactContinuous</i> contains the Trading Trajectory generated by the Almgren (2003) Power Impact
  79.  * Scheme under the Criterion of No-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. F., 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.  *          Almgren, R. (2003): Optimal Execution with Nonlinear Impact Functions and Trading-Enhanced Risk
  92.  *              <i>Applied Mathematical Finance</i> <b>10 (1)</b> 1-18
  93.  *      </li>
  94.  *      <li>
  95.  *          Almgren, R., and N. Chriss (2003): Bidding Principles <i>Risk</i> 97-102
  96.  *      </li>
  97.  *      <li>
  98.  *          Bertsimas, D., and A. W. Lo (1998): Optimal Control of Execution Costs <i>Journal of Financial
  99.  *              Markets</i> <b>1</b> 1-50
  100.  *      </li>
  101.  *  </ul>
  102.  *
  103.  *  <br><br>
  104.  *  <ul>
  105.  *      <li><b>Module </b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/ProductCore.md">Product Core Module</a></li>
  106.  *      <li><b>Library</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/TransactionCostAnalyticsLibrary.md">Transaction Cost Analytics</a></li>
  107.  *      <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>
  108.  *      <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>
  109.  *  </ul>
  110.  *
  111.  * @author Lakshmi Krishnamurthy
  112.  */

  113. public class PowerImpactContinuous extends org.drip.execution.optimum.EfficientTradingTrajectoryContinuous {
  114.     private double _dblExecutionTimeUpperBound = java.lang.Double.NaN;
  115.     private double _dblHyperboloidBoundaryValue = java.lang.Double.NaN;

  116.     /**
  117.      * Construct the Standard PowerImpactContinuous Instance
  118.      *
  119.      * @param dblExecutionTime The Execution Time
  120.      * @param dblTransactionCostExpectation The Expected Transaction Cost
  121.      * @param dblTransactionCostVariance The Variance of the Transaction Cost
  122.      * @param dblCharacteristicTime The Optimal Trajectory's "Characteristic" Time
  123.      * @param dblExecutionTimeUpperBound The Optimal Trajectory's Execution Time Upper Bound (if it exists)
  124.      * @param dblHyperboloidBoundaryValue The Hyperboloid Boundary Value
  125.      * @param dblMarketPower The Dimension-less Relative Market Impact
  126.      * @param r1ToR1Holdings The Optimal Trajectory R^1 To R^1 Holdings Function
  127.      * @param r1ToR1TransactionCostExpectation The Transaction Cost Expectation Function
  128.      * @param r1ToR1TransactionCostVariance The Transaction Cost Variance Function
  129.      *
  130.      * @return The Standard PowerImpactContinuous Instance
  131.      */

  132.     public static PowerImpactContinuous Standard (
  133.         final double dblExecutionTime,
  134.         final double dblTransactionCostExpectation,
  135.         final double dblTransactionCostVariance,
  136.         final double dblCharacteristicTime,
  137.         final double dblExecutionTimeUpperBound,
  138.         final double dblHyperboloidBoundaryValue,
  139.         final double dblMarketPower,
  140.         final org.drip.function.definition.R1ToR1 r1ToR1Holdings,
  141.         final org.drip.function.definition.R1ToR1 r1ToR1TransactionCostExpectation,
  142.         final org.drip.function.definition.R1ToR1 r1ToR1TransactionCostVariance)
  143.     {
  144.         if (null == r1ToR1Holdings) return null;

  145.         try {
  146.             org.drip.function.definition.R1ToR1 r1ToR1TradeRate = new org.drip.function.definition.R1ToR1
  147.                 (null) {
  148.                 @Override public double evaluate (
  149.                     final double dblVariate)
  150.                     throws java.lang.Exception
  151.                 {
  152.                     return r1ToR1Holdings.derivative (dblVariate, 1);
  153.                 }
  154.             };

  155.             return new PowerImpactContinuous (dblExecutionTime, dblTransactionCostExpectation,
  156.                 dblTransactionCostVariance, dblCharacteristicTime, dblExecutionTimeUpperBound,
  157.                     dblHyperboloidBoundaryValue, dblMarketPower, r1ToR1Holdings, r1ToR1TradeRate,
  158.                         r1ToR1TransactionCostExpectation, r1ToR1TransactionCostVariance);
  159.         } catch (java.lang.Exception e) {
  160.             e.printStackTrace();
  161.         }

  162.         return null;
  163.     }

  164.     /**
  165.      * PowerImpactContinuous Constructor
  166.      *
  167.      * @param dblExecutionTime The Execution Time
  168.      * @param dblTransactionCostExpectation The Expected Transaction Cost
  169.      * @param dblTransactionCostVariance The Variance of the Transaction Cost
  170.      * @param dblCharacteristicTime The Optimal Trajectory's "Characteristic" Time
  171.      * @param dblExecutionTimeUpperBound The Optimal Trajectory's Execution Time Upper Bound (if it exists)
  172.      * @param dblHyperboloidBoundaryValue The Hyperboloid Boundary Value
  173.      * @param dblMarketPower The Dimension-less Relative Market Impact
  174.      * @param r1ToR1Holdings The Optimal Trajectory R^1 To R^1 Holdings Function
  175.      * @param r1ToR1TradeRate The Optimal Trajectory R^1 To R^1 Trade Rate Function
  176.      * @param r1ToR1TransactionCostExpectation The Transaction Cost Expectation Function
  177.      * @param r1ToR1TransactionCostVariance The Transaction Cost Variance Function
  178.      *
  179.      * @throws java.lang.Exception Thrown if the Inputs are Invalid
  180.      */

  181.     public PowerImpactContinuous (
  182.         final double dblExecutionTime,
  183.         final double dblTransactionCostExpectation,
  184.         final double dblTransactionCostVariance,
  185.         final double dblCharacteristicTime,
  186.         final double dblExecutionTimeUpperBound,
  187.         final double dblHyperboloidBoundaryValue,
  188.         final double dblMarketPower,
  189.         final org.drip.function.definition.R1ToR1 r1ToR1Holdings,
  190.         final org.drip.function.definition.R1ToR1 r1ToR1TradeRate,
  191.         final org.drip.function.definition.R1ToR1 r1ToR1TransactionCostExpectation,
  192.         final org.drip.function.definition.R1ToR1 r1ToR1TransactionCostVariance)
  193.         throws java.lang.Exception
  194.     {
  195.         super (dblExecutionTime, dblTransactionCostExpectation, dblTransactionCostVariance,
  196.             dblCharacteristicTime, dblMarketPower, r1ToR1Holdings, r1ToR1TradeRate,
  197.                 r1ToR1TransactionCostExpectation, r1ToR1TransactionCostVariance);

  198.         if (!org.drip.numerical.common.NumberUtil.IsValid (_dblHyperboloidBoundaryValue =
  199.             dblHyperboloidBoundaryValue))
  200.             throw new java.lang.Exception ("PowerImpactContinuous Constructor => Invalid Inputs");

  201.         _dblExecutionTimeUpperBound = dblExecutionTimeUpperBound;
  202.     }

  203.     /**
  204.      * Retrieve the Optimal Trajectory Execution Time Upper Bound (if it exists)
  205.      *
  206.      * @return The Optimal Trajectory Execution Time Upper Bound (if it exists)
  207.      */

  208.     public double executionTimeUpperBound()
  209.     {
  210.         return _dblExecutionTimeUpperBound;
  211.     }

  212.     /**
  213.      * Retrieve the Optimal Trajectory Hyperboloid Boundary Value
  214.      *
  215.      * @return The Optimal Trajectory Hyperboloid Boundary Value
  216.      */

  217.     public double hyperboloidBoundaryValue()
  218.     {
  219.         return _dblHyperboloidBoundaryValue;
  220.     }
  221. }