NonDimensionalCostCorrelated.java

  1. package org.drip.execution.hjb;

  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>NonDimensionalCostCorrelated</i> contains the Level, the Gradient, and the Jacobian of the HJB Non
  79.  * dimensional Cost Value Function to the Individual Correlated Market States. The References are:
  80.  *
  81.  * <br><br>
  82.  *  <ul>
  83.  *      <li>
  84.  *          Almgren, R. F., and N. Chriss (2000): Optimal Execution of Portfolio Transactions <i>Journal of
  85.  *              Risk</i> <b>3 (2)</b> 5-39
  86.  *      </li>
  87.  *      <li>
  88.  *          Almgren, R. F. (2009): Optimal Trading in a Dynamic Market
  89.  *              https://www.math.nyu.edu/financial_mathematics/content/02_financial/2009-2.pdf
  90.  *      </li>
  91.  *      <li>
  92.  *          Almgren, R. F. (2012): Optimal Trading with Stochastic Liquidity and Volatility <i>SIAM Journal
  93.  *          of Financial Mathematics</i> <b>3 (1)</b> 163-181
  94.  *      </li>
  95.  *      <li>
  96.  *          Geman, H., D. B. Madan, and M. Yor (2001): Time Changes for Levy Processes <i>Mathematical
  97.  *              Finance</i> <b>11 (1)</b> 79-96
  98.  *      </li>
  99.  *      <li>
  100.  *          Jones, C. M., G. Kaul, and M. L. Lipson (1994): Transactions, Volume, and Volatility <i>Review of
  101.  *              Financial Studies</i> <b>7 (4)</b> 631-651
  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/hjb/README.md">Hamilton Jacobin Bellman Based Optimal Evolution</a></li>
  111.  *  </ul>
  112.  *
  113.  * @author Lakshmi Krishnamurthy
  114.  */

  115. public class NonDimensionalCostCorrelated extends org.drip.execution.hjb.NonDimensionalCost {
  116.     private double _dblLiquidityGradient = java.lang.Double.NaN;
  117.     private double _dblLiquidityJacobian = java.lang.Double.NaN;
  118.     private double _dblVolatilityGradient = java.lang.Double.NaN;
  119.     private double _dblVolatilityJacobian = java.lang.Double.NaN;
  120.     private double _dblLiquidityVolatilityGradient = java.lang.Double.NaN;

  121.     /**
  122.      * Generate a Zero Sensitivity Correlated Non-dimensional Cost Instance
  123.      *
  124.      * @return The Zero Sensitivity Correlated Non-dimensional Cost Instance
  125.      */

  126.     public static final NonDimensionalCostCorrelated Zero()
  127.     {
  128.         try {
  129.             return new NonDimensionalCostCorrelated (0., 0., 0., 0., 0., 0., 0.);
  130.         } catch (java.lang.Exception e) {
  131.             e.printStackTrace();
  132.         }

  133.         return null;
  134.     }

  135.     /**
  136.      * NonDimensionalCostCorrelated Constructor
  137.      *
  138.      * @param dblRealization The Realized Non Dimensional Value
  139.      * @param dblNonDimensionalTradeRate The Non Dimensional Trade Rate
  140.      * @param dblLiquidityGradient The Realized Non Dimensional Value Liquidity Gradient
  141.      * @param dblLiquidityJacobian The Realized Non Dimensional Value Liquidity Jacobian
  142.      * @param dblVolatilityGradient The Realized Non Dimensional Value Volatility Gradient
  143.      * @param dblVolatilityJacobian The Realized Non Dimensional Value Volatility Jacobian
  144.      * @param dblLiquidityVolatilityGradient The Realized Non Dimensional Value Liquidity/Volatility Gradient
  145.      *
  146.      * @throws java.lang.Exception Thrown if the Inputs are Invalid
  147.      */

  148.     public NonDimensionalCostCorrelated (
  149.         final double dblRealization,
  150.         final double dblLiquidityGradient,
  151.         final double dblLiquidityJacobian,
  152.         final double dblVolatilityGradient,
  153.         final double dblVolatilityJacobian,
  154.         final double dblLiquidityVolatilityGradient,
  155.         final double dblNonDimensionalTradeRate)
  156.         throws java.lang.Exception
  157.     {
  158.         super (dblRealization, dblNonDimensionalTradeRate);

  159.         if (!org.drip.numerical.common.NumberUtil.IsValid (_dblLiquidityGradient = dblLiquidityGradient) ||
  160.             !org.drip.numerical.common.NumberUtil.IsValid (_dblLiquidityJacobian = dblLiquidityJacobian) ||
  161.                 !org.drip.numerical.common.NumberUtil.IsValid (_dblVolatilityGradient = dblVolatilityGradient) ||
  162.                     !org.drip.numerical.common.NumberUtil.IsValid (_dblVolatilityJacobian =
  163.                         dblVolatilityJacobian) || !org.drip.numerical.common.NumberUtil.IsValid
  164.                             (_dblLiquidityVolatilityGradient = dblLiquidityVolatilityGradient))
  165.             throw new java.lang.Exception ("NonDimensionalCostCorrelated Constructor => Invalid Inputs");
  166.     }

  167.     /**
  168.      * Retrieve the Non Dimensional Value Liquidity Gradient
  169.      *
  170.      * @return The Non Dimensional Value Liquidity Gradient
  171.      */

  172.     public double liquidityGradient()
  173.     {
  174.         return _dblLiquidityGradient;
  175.     }

  176.     /**
  177.      * Retrieve the Non Dimensional Value Liquidity Jacobian
  178.      *
  179.      * @return The Non Dimensional Value Liquidity Jacobian
  180.      */

  181.     public double liquidityJacobian()
  182.     {
  183.         return _dblLiquidityJacobian;
  184.     }

  185.     /**
  186.      * Retrieve the Non Dimensional Value Volatility Gradient
  187.      *
  188.      * @return The Non Dimensional Value Volatility Gradient
  189.      */

  190.     public double volatilityGradient()
  191.     {
  192.         return _dblVolatilityGradient;
  193.     }

  194.     /**
  195.      * Retrieve the Non Dimensional Value Volatility Jacobian
  196.      *
  197.      * @return The Non Dimensional Value Volatility Jacobian
  198.      */

  199.     public double volatilityJacobian()
  200.     {
  201.         return _dblVolatilityJacobian;
  202.     }

  203.     /**
  204.      * Retrieve the Non Dimensional Value Liquidity/Volatility Gradient
  205.      *
  206.      * @return The Non Dimensional Value Liquidity/Volatility Gradient
  207.      */

  208.     public double liquidityVolatilityGradient()
  209.     {
  210.         return _dblLiquidityVolatilityGradient;
  211.     }
  212. }