LongFloatClassicalMinusTimeline.java

  1. package org.drip.sample.mporstream;

  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import java.util.Map;

  5. import org.drip.analytics.date.DateUtil;
  6. import org.drip.analytics.date.JulianDate;
  7. import org.drip.exposure.csatimeline.AndersenPykhtinSokolLag;
  8. import org.drip.exposure.csatimeline.LastFlowDates;
  9. import org.drip.exposure.evolver.EntityDynamicsContainer;
  10. import org.drip.exposure.evolver.LatentStateDynamicsContainer;
  11. import org.drip.exposure.evolver.LatentStateVertexContainer;
  12. import org.drip.exposure.evolver.PrimarySecurity;
  13. import org.drip.exposure.evolver.PrimarySecurityDynamicsContainer;
  14. import org.drip.exposure.evolver.TerminalLatentState;
  15. import org.drip.exposure.generator.FloatStreamMPoR;
  16. import org.drip.exposure.mpor.PathVariationMarginTrajectoryEstimator;
  17. import org.drip.exposure.mpor.VariationMarginTradeVertexExposure;
  18. import org.drip.exposure.universe.LatentStateWeiner;
  19. import org.drip.exposure.universe.MarketPath;
  20. import org.drip.exposure.universe.MarketVertex;
  21. import org.drip.exposure.universe.MarketVertexGenerator;
  22. import org.drip.market.otc.FixedFloatSwapConvention;
  23. import org.drip.market.otc.IBORFixedFloatContainer;
  24. import org.drip.measure.crng.RandomNumberGenerator;
  25. import org.drip.measure.discrete.CorrelatedPathVertexDimension;
  26. import org.drip.measure.dynamics.DiffusionEvaluatorLinear;
  27. import org.drip.measure.dynamics.DiffusionEvaluatorLogarithmic;
  28. import org.drip.measure.dynamics.HazardJumpEvaluator;
  29. import org.drip.measure.process.DiffusionEvolver;
  30. import org.drip.measure.process.JumpDiffusionEvolver;
  31. import org.drip.numerical.common.FormatUtil;
  32. import org.drip.numerical.linearalgebra.Matrix;
  33. import org.drip.product.rates.FixFloatComponent;
  34. import org.drip.service.env.EnvManager;
  35. import org.drip.state.identifier.CSALabel;
  36. import org.drip.state.identifier.EntityFundingLabel;
  37. import org.drip.state.identifier.EntityHazardLabel;
  38. import org.drip.state.identifier.EntityRecoveryLabel;
  39. import org.drip.state.identifier.ForwardLabel;
  40. import org.drip.state.identifier.LatentStateLabel;
  41. import org.drip.state.identifier.OvernightLabel;

  42. /*
  43.  * -*- mode: java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
  44.  */

  45. /*!
  46.  * Copyright (C) 2018 Lakshmi Krishnamurthy
  47.  *
  48.  *  This file is part of DRIP, a free-software/open-source library for buy/side financial/trading model
  49.  *      libraries targeting analysts and developers
  50.  *      https://lakshmidrip.github.io/DRIP/
  51.  *  
  52.  *  DRIP is composed of four main libraries:
  53.  *  
  54.  *  - DRIP Fixed Income - https://lakshmidrip.github.io/DRIP-Fixed-Income/
  55.  *  - DRIP Asset Allocation - https://lakshmidrip.github.io/DRIP-Asset-Allocation/
  56.  *  - DRIP Numerical Optimizer - https://lakshmidrip.github.io/DRIP-Numerical-Optimizer/
  57.  *  - DRIP Statistical Learning - https://lakshmidrip.github.io/DRIP-Statistical-Learning/
  58.  *
  59.  *  - DRIP Fixed Income: Library for Instrument/Trading Conventions, Treasury Futures/Options,
  60.  *      Funding/Forward/Overnight Curves, Multi-Curve Construction/Valuation, Collateral Valuation and XVA
  61.  *      Metric Generation, Calibration and Hedge Attributions, Statistical Curve Construction, Bond RV
  62.  *      Metrics, Stochastic Evolution and Option Pricing, Interest Rate Dynamics and Option Pricing, LMM
  63.  *      Extensions/Calibrations/Greeks, Algorithmic Differentiation, and Asset Backed Models and Analytics.
  64.  *
  65.  *  - DRIP Asset Allocation: Library for model libraries for MPT framework, Black Litterman Strategy
  66.  *      Incorporator, Holdings Constraint, and Transaction Costs.
  67.  *
  68.  *  - DRIP Numerical Optimizer: Library for Numerical Optimization and Spline Functionality.
  69.  *
  70.  *  - DRIP Statistical Learning: Library for Statistical Evaluation and Machine Learning.
  71.  *
  72.  *  Licensed under the Apache License, Version 2.0 (the "License");
  73.  *      you may not use this file except in compliance with the License.
  74.  *  
  75.  *  You may obtain a copy of the License at
  76.  *      http://www.apache.org/licenses/LICENSE-2.0
  77.  *  
  78.  *  Unless required by applicable law or agreed to in writing, software
  79.  *      distributed under the License is distributed on an "AS IS" BASIS,
  80.  *      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  81.  *  
  82.  *  See the License for the specific language governing permissions and
  83.  *      limitations under the License.
  84.  */

  85. /**
  86.  * LongFloatClassicalMinusTimeline displays the MPoR-related Exposure Metrics Suite for the given Long Float
  87.  *  Coupon Stream on a Daily Grid using the "Classical-" CSA Timeline of Andersen, Pykhtin, and Sokol (2017).
  88.  *  The References are:
  89.  *  
  90.  *  - Andersen, L. B. G., M. Pykhtin, and A. Sokol (2017): Re-thinking Margin Period of Risk,
  91.  *      https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2902737, eSSRN.
  92.  *  
  93.  *  - Andersen, L. B. G., M. Pykhtin, and A. Sokol (2017): Credit Exposure in the Presence of Initial Margin,
  94.  *      https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2806156, eSSRN.
  95.  *  
  96.  *  - Albanese, C., and L. Andersen (2014): Accounting for OTC Derivatives: Funding Adjustments and the
  97.  *      Re-Hypothecation Option, eSSRN, https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2482955.
  98.  *  
  99.  *  - Burgard, C., and M. Kjaer (2017): Derivatives Funding, Netting, and Accounting, eSSRN,
  100.  *      https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2534011.
  101.  *
  102.  *  - Piterbarg, V. (2010): Funding Beyond Discounting: Collateral Agreements and Derivatives Pricing, Risk
  103.  *      21 (2) 97-102.
  104.  *
  105.  * @author Lakshmi Krishnamurthy
  106.  */

  107. public class LongFloatClassicalMinusTimeline
  108. {

  109.     private static final FixFloatComponent OTCIRS (
  110.         final JulianDate spotDate,
  111.         final String currency,
  112.         final String maturityTenor,
  113.         final double coupon)
  114.     {
  115.         FixedFloatSwapConvention ffConv = IBORFixedFloatContainer.ConventionFromJurisdiction (
  116.             currency,
  117.             "ALL",
  118.             maturityTenor,
  119.             "MAIN"
  120.         );

  121.         return ffConv.createFixFloatComponent (
  122.             spotDate,
  123.             maturityTenor,
  124.             coupon,
  125.             0.,
  126.             1.
  127.         );
  128.     }

  129.     private static final PrimarySecurity OvernightReplicator (
  130.         final String currency,
  131.         final List<LatentStateLabel> latentStateLabelList)
  132.         throws Exception
  133.     {
  134.         double overnightReplicatorDrift = 0.0025;
  135.         double overnightReplicatorVolatility = 0.001;
  136.         double overnightReplicatorRepo = 0.0;

  137.         LatentStateLabel overnightLabel = OvernightLabel.Create (currency);

  138.         latentStateLabelList.add (overnightLabel);

  139.         return new PrimarySecurity (
  140.             currency + "_OVERNIGHT",
  141.             overnightLabel,
  142.             new DiffusionEvolver (
  143.                 DiffusionEvaluatorLogarithmic.Standard (
  144.                     overnightReplicatorDrift,
  145.                     overnightReplicatorVolatility
  146.                 )
  147.             ),
  148.             overnightReplicatorRepo
  149.         );
  150.     }

  151.     private static final PrimarySecurity CSAReplicator (
  152.         final String currency,
  153.         final List<LatentStateLabel> latentStateLabelList)
  154.         throws Exception
  155.     {
  156.         double csaReplicatorDrift = 0.01;
  157.         double csaReplicatorVolatility = 0.002;
  158.         double csaReplicatorRepo = 0.005;

  159.         LatentStateLabel csaLabel = CSALabel.ISDA (currency);

  160.         latentStateLabelList.add (csaLabel);

  161.         return new PrimarySecurity (
  162.             currency + "_CSA",
  163.             csaLabel,
  164.             new DiffusionEvolver (
  165.                 DiffusionEvaluatorLogarithmic.Standard (
  166.                     csaReplicatorDrift,
  167.                     csaReplicatorVolatility
  168.                 )
  169.             ),
  170.             csaReplicatorRepo
  171.         );
  172.     }

  173.     private static final PrimarySecurity DealerSeniorFundingReplicator (
  174.         final String currency,
  175.         final String dealer,
  176.         final List<LatentStateLabel> latentStateLabelList)
  177.         throws Exception
  178.     {
  179.         double dealerSeniorFundingReplicatorDrift = 0.03;
  180.         double dealerSeniorFundingReplicatorVolatility = 0.002;
  181.         double dealerSeniorFundingReplicatorRepo = 0.028;

  182.         LatentStateLabel dealerSeniorFundingLabel = EntityFundingLabel.Senior (
  183.             dealer,
  184.             currency
  185.         );

  186.         latentStateLabelList.add (dealerSeniorFundingLabel);

  187.         return new PrimarySecurity (
  188.             dealer + "_" + currency + "_SENIOR_ZERO",
  189.             dealerSeniorFundingLabel,
  190.             new JumpDiffusionEvolver (
  191.                 DiffusionEvaluatorLogarithmic.Standard (
  192.                     dealerSeniorFundingReplicatorDrift,
  193.                     dealerSeniorFundingReplicatorVolatility
  194.                 ),
  195.                 HazardJumpEvaluator.Standard (
  196.                     0.3,
  197.                     0.45
  198.                 )
  199.             ),
  200.             dealerSeniorFundingReplicatorRepo
  201.         );
  202.     }

  203.     private static final PrimarySecurity DealerSubordinateFundingReplicator (
  204.         final String currency,
  205.         final String dealer,
  206.         final List<LatentStateLabel> latentStateLabelList)
  207.         throws Exception
  208.     {
  209.         double dealerSubordinateFundingReplicatorDrift = 0.045;
  210.         double dealerSubordinateFundingReplicatorVolatility = 0.002;
  211.         double dealerSubordinateFundingReplicatorRepo = 0.028;

  212.         LatentStateLabel dealerSubordinateFundingLabel = EntityFundingLabel.Subordinate (
  213.             dealer,
  214.             currency
  215.         );

  216.         latentStateLabelList.add (dealerSubordinateFundingLabel);

  217.         return new PrimarySecurity (
  218.             dealer + "_" + currency + "_SUBORDINATE_ZERO",
  219.             dealerSubordinateFundingLabel,
  220.             new JumpDiffusionEvolver (
  221.                 DiffusionEvaluatorLogarithmic.Standard (
  222.                     dealerSubordinateFundingReplicatorDrift,
  223.                     dealerSubordinateFundingReplicatorVolatility
  224.                 ),
  225.                 HazardJumpEvaluator.Standard (
  226.                     0.3,
  227.                     0.25
  228.                 )
  229.             ),
  230.             dealerSubordinateFundingReplicatorRepo
  231.         );
  232.     }

  233.     private static final PrimarySecurity ClientFundingReplicator (
  234.         final String currency,
  235.         final String client,
  236.         final List<LatentStateLabel> latentStateLabelList)
  237.         throws Exception
  238.     {
  239.         double clientFundingReplicatorDrift = 0.03;
  240.         double clientFundingReplicatorVolatility = 0.003;
  241.         double clientFundingReplicatorRepo = 0.028;

  242.         LatentStateLabel clientFundingLabel = EntityFundingLabel.Senior (
  243.             client,
  244.             currency
  245.         );

  246.         latentStateLabelList.add (clientFundingLabel);

  247.         return new PrimarySecurity (
  248.             client + "_" + currency + "_SENIOR_ZERO",
  249.             clientFundingLabel,
  250.             new JumpDiffusionEvolver (
  251.                 DiffusionEvaluatorLogarithmic.Standard (
  252.                     clientFundingReplicatorDrift,
  253.                     clientFundingReplicatorVolatility
  254.                 ),
  255.                 HazardJumpEvaluator.Standard (
  256.                     0.5,
  257.                     0.30
  258.                 )
  259.             ),
  260.             clientFundingReplicatorRepo
  261.         );
  262.     }

  263.     private static final TerminalLatentState DealerHazard (
  264.         final String currency,
  265.         final String dealer,
  266.         final List<LatentStateLabel> latentStateLabelList)
  267.         throws Exception
  268.     {
  269.         double dealerHazardDrift = 0.0002;
  270.         double dealerHazardVolatility = 0.02;

  271.         LatentStateLabel dealerHazardLabel = EntityHazardLabel.Standard (
  272.             dealer,
  273.             currency
  274.         );

  275.         latentStateLabelList.add (dealerHazardLabel);

  276.         return new TerminalLatentState (
  277.             dealerHazardLabel,
  278.             new DiffusionEvolver (
  279.                 DiffusionEvaluatorLogarithmic.Standard (
  280.                     dealerHazardDrift,
  281.                     dealerHazardVolatility
  282.                 )
  283.             )
  284.         );
  285.     }

  286.     private static final TerminalLatentState DealerRecovery (
  287.         final String currency,
  288.         final String dealer,
  289.         final List<LatentStateLabel> latentStateLabelList)
  290.         throws Exception
  291.     {
  292.         double dealerRecoveryDrift = 0.0002;
  293.         double dealerRecoveryVolatility = 0.02;

  294.         LatentStateLabel dealerRecoveryLabel = EntityRecoveryLabel.Senior (
  295.             dealer,
  296.             currency
  297.         );

  298.         latentStateLabelList.add (dealerRecoveryLabel);

  299.         return new TerminalLatentState (
  300.             dealerRecoveryLabel,
  301.             new DiffusionEvolver (
  302.                 DiffusionEvaluatorLogarithmic.Standard (
  303.                     dealerRecoveryDrift,
  304.                     dealerRecoveryVolatility
  305.                 )
  306.             )
  307.         );
  308.     }

  309.     private static final TerminalLatentState ClientHazard (
  310.         final String currency,
  311.         final String client,
  312.         final List<LatentStateLabel> latentStateLabelList)
  313.         throws Exception
  314.     {
  315.         double clientHazardDrift = 0.0002;
  316.         double clientHazardVolatility = 0.02;

  317.         LatentStateLabel clientHazardLabel = EntityHazardLabel.Standard (
  318.             client,
  319.             currency
  320.         );

  321.         latentStateLabelList.add (clientHazardLabel);

  322.         return new TerminalLatentState (
  323.             clientHazardLabel,
  324.             new DiffusionEvolver (
  325.                 DiffusionEvaluatorLogarithmic.Standard (
  326.                     clientHazardDrift,
  327.                     clientHazardVolatility
  328.                 )
  329.             )
  330.         );
  331.     }

  332.     private static final TerminalLatentState ClientRecovery (
  333.         final String currency,
  334.         final String client,
  335.         final List<LatentStateLabel> latentStateLabelList)
  336.         throws Exception
  337.     {
  338.         double clientRecoveryDrift = 0.0002;
  339.         double clientRecoveryVolatility = 0.02;

  340.         LatentStateLabel clientRecoveryLabel = EntityRecoveryLabel.Senior (
  341.             client,
  342.             currency
  343.         );

  344.         latentStateLabelList.add (clientRecoveryLabel);

  345.         return new TerminalLatentState (
  346.             clientRecoveryLabel,
  347.             new DiffusionEvolver (
  348.                 DiffusionEvaluatorLogarithmic.Standard (
  349.                     clientRecoveryDrift,
  350.                     clientRecoveryVolatility
  351.                 )
  352.             )
  353.         );
  354.     }

  355.     private static final EntityDynamicsContainer EntityEvolver (
  356.         final String currency,
  357.         final String dealer,
  358.         final String client,
  359.         final List<LatentStateLabel> latentStateLabelList)
  360.         throws Exception
  361.     {
  362.         return new EntityDynamicsContainer (
  363.             DealerHazard (
  364.                 currency,
  365.                 dealer,
  366.                 latentStateLabelList
  367.             ),
  368.             DealerRecovery (
  369.                 currency,
  370.                 dealer,
  371.                 latentStateLabelList
  372.             ),
  373.             null,
  374.             ClientHazard (
  375.                 currency,
  376.                 client,
  377.                 latentStateLabelList
  378.             ),
  379.             ClientRecovery (
  380.                 currency,
  381.                 client,
  382.                 latentStateLabelList
  383.             )
  384.         );
  385.     }

  386.     private static final PrimarySecurityDynamicsContainer PrimarySecurityEvolver (
  387.         final String currency,
  388.         final String dealer,
  389.         final String client,
  390.         final List<LatentStateLabel> latentStateLabelList)
  391.         throws Exception
  392.     {
  393.         return new PrimarySecurityDynamicsContainer (
  394.             null,
  395.             OvernightReplicator (
  396.                 currency,
  397.                 latentStateLabelList
  398.             ),
  399.             CSAReplicator (
  400.                 currency,
  401.                 latentStateLabelList
  402.             ),
  403.             DealerSeniorFundingReplicator (
  404.                 currency,
  405.                 dealer,
  406.                 latentStateLabelList
  407.             ),
  408.             DealerSubordinateFundingReplicator (
  409.                 currency,
  410.                 dealer,
  411.                 latentStateLabelList
  412.             ),
  413.             ClientFundingReplicator (
  414.                 currency,
  415.                 client,
  416.                 latentStateLabelList
  417.             )
  418.         );
  419.     }

  420.     private static final LatentStateDynamicsContainer LatentStateEvolver (
  421.         final ForwardLabel forwardLabel,
  422.         final List<LatentStateLabel> latentStateLabelList)
  423.         throws Exception
  424.     {
  425.         double forwardNumeraireDrift = 0.0;
  426.         double forwardNumeraireVolatility = 0.25;

  427.         latentStateLabelList.add (forwardLabel);

  428.         LatentStateDynamicsContainer latentStateDynamicsContainer = new LatentStateDynamicsContainer();

  429.         latentStateDynamicsContainer.addForward (
  430.             new TerminalLatentState (
  431.                 forwardLabel,
  432.                 new DiffusionEvolver (
  433.                     DiffusionEvaluatorLinear.Standard (
  434.                         forwardNumeraireDrift,
  435.                         forwardNumeraireVolatility
  436.                     )
  437.                 )
  438.             )
  439.         );

  440.         return latentStateDynamicsContainer;
  441.     }

  442.     private static final MarketVertexGenerator ConstructMarketVertexGenerator (
  443.         final JulianDate spotDate,
  444.         final String exposureSamplingTenor,
  445.         final int exposureSamplingNodeCount,
  446.         final String currency,
  447.         final String dealer,
  448.         final String client,
  449.         final ForwardLabel forwardLabel,
  450.         final List<LatentStateLabel> latentStateLabelList)
  451.         throws Exception
  452.     {
  453.         JulianDate terminationDate = spotDate;
  454.         int[] eventVertexArray = new int[exposureSamplingNodeCount];

  455.         for (int i = 0; i < exposureSamplingNodeCount; ++i)
  456.         {
  457.             terminationDate = terminationDate.addTenor (exposureSamplingTenor);

  458.             eventVertexArray[i] = terminationDate.julian();
  459.         }

  460.         return new MarketVertexGenerator (
  461.             spotDate.julian(),
  462.             eventVertexArray,
  463.             EntityEvolver (
  464.                 currency,
  465.                 dealer,
  466.                 client,
  467.                 latentStateLabelList
  468.             ),
  469.             PrimarySecurityEvolver (
  470.                 currency,
  471.                 dealer,
  472.                 client,
  473.                 latentStateLabelList
  474.             ),
  475.             LatentStateEvolver (
  476.                 forwardLabel,
  477.                 latentStateLabelList
  478.             )
  479.         );
  480.     }

  481.     public static final void main (
  482.         final String[] args)
  483.         throws Exception
  484.     {
  485.         EnvManager.InitEnv ("");

  486.         JulianDate spotDate = DateUtil.CreateFromYMD (
  487.             2018,
  488.             DateUtil.APRIL,
  489.             19
  490.         );

  491.         int pathCount = 1000;
  492.         String exposurePeriodTenor = "1D";
  493.         int exposurePeriodCount = 390;
  494.         int vertexGenerationPeriodCount = exposurePeriodCount + 10;
  495.         String currency = "USD";
  496.         String dealer = "NOM";
  497.         String client = "SSGA";
  498.         double[][] correlationMatrix = new double[][] {
  499.             {1.00, 0.00, 0.20, 0.15, 0.05, 0.00, 0.00, 0.00, 0.00, 0.00}, // #0  DEALER HAZARD
  500.             {0.00, 1.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00}, // #1  DEALER SENIOR RECOVERY
  501.             {0.20, 0.00, 1.00, 0.13, 0.25, 0.00, 0.00, 0.00, 0.00, 0.00}, // #2  CLIENT HAZARD
  502.             {0.15, 0.00, 0.13, 1.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00}, // #3  CLIENT RECOVERY
  503.             {0.05, 0.00, 0.25, 0.00, 1.00, 0.00, 0.00, 0.00, 0.00, 0.00}, // #4  OVERNIGHT REPLICATOR
  504.             {0.00, 0.00, 0.00, 0.00, 0.00, 1.00, 0.00, 0.00, 0.00, 0.00}, // #5  CSA REPLICATOR
  505.             {0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 1.00, 0.00, 0.00, 0.00}, // #6  DEALER SENIOR FUNDING REPLICATOR
  506.             {0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 1.00, 0.00, 0.00}, // #7  DEALER SUBORDINATE FUNDING REPLICATOR
  507.             {0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 1.00, 0.00}, // #8  CLIENT FUNDING REPLICATOR
  508.             {0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 1.00}, // #9  FORWARD NUMERAIRE
  509.         };
  510.         String fixFloatMaturityTenor = "1Y";
  511.         double fixFloatCoupon = 0.03;
  512.         double fixFloatNotional = -1.e+06;

  513.         ForwardLabel forwardLabel = ForwardLabel.Create (
  514.             currency,
  515.             "3M"
  516.         );

  517.         List<LatentStateLabel> latentStateLabelList = new ArrayList<LatentStateLabel>();

  518.         MarketVertexGenerator marketVertexGenerator = ConstructMarketVertexGenerator (
  519.             spotDate,
  520.             exposurePeriodTenor,
  521.             vertexGenerationPeriodCount,
  522.             currency,
  523.             dealer,
  524.             client,
  525.             forwardLabel,
  526.             latentStateLabelList
  527.         );

  528.         LatentStateVertexContainer latentStateVertexContainer = new LatentStateVertexContainer();

  529.         latentStateVertexContainer.add (
  530.             forwardLabel,
  531.             0.02
  532.         );

  533.         MarketVertex initialMarketVertex = MarketVertex.Epochal (
  534.             spotDate,
  535.             1.000,              // dblOvernightNumeraireInitial
  536.             1.000,              // dblCSANumeraire
  537.             0.015,              // dblBankHazardRate
  538.             0.400,              // dblBankRecoveryRate
  539.             0.015 / (1 - 0.40), // dblBankFundingSpread
  540.             0.030,              // dblCounterPartyHazardRate
  541.             0.300,              // dblCounterPartyRecoveryRate
  542.             0.030 / (1 - 0.30), // dblCounterPartyFundingSpread
  543.             latentStateVertexContainer
  544.         );

  545.         AndersenPykhtinSokolLag andersenPykhtinSokolLag = AndersenPykhtinSokolLag.ClassicalMinus();

  546.         FixFloatComponent fixFloatComponent = OTCIRS (
  547.             spotDate,
  548.             currency,
  549.             fixFloatMaturityTenor,
  550.             fixFloatCoupon
  551.         );

  552.         FloatStreamMPoR floatCouponStream = new FloatStreamMPoR (
  553.             fixFloatComponent.derivedStream(),
  554.             fixFloatNotional
  555.         );

  556.         CorrelatedPathVertexDimension correlatedPathVertexDimension = new CorrelatedPathVertexDimension (
  557.             new RandomNumberGenerator(),
  558.             correlationMatrix,
  559.             vertexGenerationPeriodCount,
  560.             1,
  561.             true,
  562.             null
  563.         );

  564.         JulianDate exposureDate = spotDate;
  565.         int[] exposureDateArray = new int[exposurePeriodCount + 1];
  566.         int[] variationMarginGapEndDateArray = new int[exposurePeriodCount + 1];
  567.         int[] variationMarginGapStartDateArray = new int[exposurePeriodCount + 1];
  568.         double[] tradePaymentGapArray = new double[exposurePeriodCount + 1];
  569.         double[] variationMarginGapArray = new double[exposurePeriodCount + 1];
  570.         double[] clientTradePaymentGapArray = new double[exposurePeriodCount + 1];
  571.         double[] collateralizedExposureArray = new double[exposurePeriodCount + 1];
  572.         double[] variationMarginPostingArray = new double[exposurePeriodCount + 1];
  573.         double[] variationMarginEstimateArray = new double[exposurePeriodCount + 1];
  574.         double[] clientDealerTradePaymentGapArray = new double[exposurePeriodCount + 1];
  575.         double[] collateralizedPositiveExposureArray = new double[exposurePeriodCount + 1];
  576.         int[] clientTradePaymentGapEndDateArray = new int[exposurePeriodCount + 1];
  577.         int[] clientTradePaymentGapStartDateArray = new int[exposurePeriodCount + 1];
  578.         int[] clientDealerTradePaymentGapEndDateArray = new int[exposurePeriodCount + 1];
  579.         int[] clientDealerTradePaymentGapStartDateArray = new int[exposurePeriodCount + 1];

  580.         for (int i = 0; i <= exposurePeriodCount; ++i)
  581.         {
  582.             tradePaymentGapArray[i] = 0.;
  583.             variationMarginGapArray[i] = 0.;
  584.             clientTradePaymentGapArray[i] = 0.;
  585.             collateralizedExposureArray[i] = 0.;
  586.             variationMarginPostingArray[i] = 0.;
  587.             variationMarginEstimateArray[i] = 0.;
  588.             clientDealerTradePaymentGapArray[i] = 0.;
  589.             collateralizedPositiveExposureArray[i] = 0.;

  590.             exposureDateArray[i] = exposureDate.julian();

  591.             exposureDate = exposureDate.addTenor (exposurePeriodTenor);
  592.         }

  593.         for (int pathIndex = 0; pathIndex < pathCount; ++pathIndex)
  594.         {
  595.             MarketPath marketPath = new MarketPath (
  596.                 marketVertexGenerator.marketVertex (
  597.                     initialMarketVertex,
  598.                     LatentStateWeiner.FromUnitRandom (
  599.                         latentStateLabelList,
  600.                         Matrix.Transpose (correlatedPathVertexDimension.straightPathVertexRd().flatform())
  601.                     )
  602.                 )
  603.             );

  604.             PathVariationMarginTrajectoryEstimator marginTradeFlowTrajectory =
  605.                 PathVariationMarginTrajectoryEstimator.Standard (
  606.                     exposureDateArray,
  607.                     currency,
  608.                     floatCouponStream,
  609.                     marketPath,
  610.                     andersenPykhtinSokolLag
  611.                 );

  612.             Map<Integer, VariationMarginTradeVertexExposure> mapMarginTradeFlowEntry =
  613.                 marginTradeFlowTrajectory.trajectory();

  614.             for (int i = 0; i <= exposurePeriodCount; ++i)
  615.             {
  616.                 VariationMarginTradeVertexExposure marginTradeFlowEntry = mapMarginTradeFlowEntry.get (exposureDateArray[i]);

  617.                 LastFlowDates lastFlowDates = marginTradeFlowEntry.lastFlowDates();

  618.                 tradePaymentGapArray[i] += marginTradeFlowEntry.tradePaymentGap();

  619.                 clientTradePaymentGapArray[i] += marginTradeFlowEntry.clientTradePaymentGap();

  620.                 clientDealerTradePaymentGapArray[i] += marginTradeFlowEntry.clientDealerTradePaymentGap();

  621.                 collateralizedExposureArray[i] += marginTradeFlowEntry.collateralizedExposure();

  622.                 collateralizedPositiveExposureArray[i] += marginTradeFlowEntry.collateralizedPositiveExposure();

  623.                 variationMarginEstimateArray[i] += marginTradeFlowEntry.variationMarginEstimate();

  624.                 variationMarginPostingArray[i] += marginTradeFlowEntry.variationMarginPosting();

  625.                 variationMarginGapArray[i] += marginTradeFlowEntry.variationMarginGap();

  626.                 variationMarginGapStartDateArray[i] = lastFlowDates.clientVariationMarginPosting().julian();

  627.                 variationMarginGapEndDateArray[i] = lastFlowDates.dealerVariationMarginPosting().julian();

  628.                 clientTradePaymentGapStartDateArray[i] = lastFlowDates.clientTradePayment().julian();

  629.                 clientTradePaymentGapEndDateArray[i] = lastFlowDates.dealerTradePayment().julian();

  630.                 clientDealerTradePaymentGapStartDateArray[i] = lastFlowDates.dealerTradePayment().julian();

  631.                 clientDealerTradePaymentGapEndDateArray[i] = lastFlowDates.variationMarginPeriodEnd().julian();
  632.             }
  633.         }

  634.         System.out.println();

  635.         System.out.println ("\t|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------||");

  636.         System.out.println ("\t|                                                                            FIXED STREAM MARGIN/TRADE FLOW EXPOSURES AND DATES                                                                               ||");

  637.         System.out.println ("\t|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------||");

  638.         System.out.println ("\t|                                                                                                                                                                                                             ||");

  639.         System.out.println ("\t|  L -> R:                                                                                                                                                                                                    ||");

  640.         System.out.println ("\t|                                                                                                                                                                                                             ||");

  641.         System.out.println ("\t|    - Exposure Date                                                                                                                                                                                          ||");

  642.         System.out.println ("\t|    - Variation Margin Gap Start Date                                                                                                                                                                        ||");

  643.         System.out.println ("\t|    - Variation Margin Gap End Date                                                                                                                                                                          ||");

  644.         System.out.println ("\t|    - Variation Margin Estimate                                                                                                                                                                              ||");

  645.         System.out.println ("\t|    - Variation Margin Posting                                                                                                                                                                               ||");

  646.         System.out.println ("\t|    - Variation Margin Gap                                                                                                                                                                                   ||");

  647.         System.out.println ("\t|    - Client Trade Payment Gap Start Date                                                                                                                                                                    ||");

  648.         System.out.println ("\t|    - Client Trade Payment Gap End Date                                                                                                                                                                      ||");

  649.         System.out.println ("\t|    - Client Trade Payment Gap                                                                                                                                                                               ||");

  650.         System.out.println ("\t|    - Net Trade Payment Gap Start Date                                                                                                                                                                       ||");

  651.         System.out.println ("\t|    - Net Trade Payment Gap End Date                                                                                                                                                                         ||");

  652.         System.out.println ("\t|    - Net Trade Payment Gap                                                                                                                                                                                  ||");

  653.         System.out.println ("\t|    - Trade Payment Gap                                                                                                                                                                                      ||");

  654.         System.out.println ("\t|    - Exposure                                                                                                                                                                                               ||");

  655.         System.out.println ("\t|    - Positive Exposure                                                                                                                                                                                      ||");

  656.         System.out.println ("\t|                                                                                                                                                                                                             ||");

  657.         System.out.println ("\t|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------||");

  658.         for (int i = 0; i <= exposurePeriodCount; ++i)
  659.         {
  660.             System.out.println (
  661.                 "\t| [" +
  662.                 new JulianDate (exposureDateArray[i]) + "] => [" +
  663.                 new JulianDate (variationMarginGapStartDateArray[i]) + " -> " +
  664.                 new JulianDate (variationMarginGapEndDateArray[i]) + "] | " +
  665.                 FormatUtil.FormatDouble (variationMarginEstimateArray[i] / pathCount, 5, 2, 1) + " | " +
  666.                 FormatUtil.FormatDouble (variationMarginPostingArray[i] / pathCount, 5, 2, 1) + " | " +
  667.                 FormatUtil.FormatDouble (variationMarginGapArray[i] / pathCount, 5, 2, 1) + " | [" +
  668.                 new JulianDate (clientTradePaymentGapStartDateArray[i]) + " -> " +
  669.                 new JulianDate (clientTradePaymentGapEndDateArray[i]) + "] | " +
  670.                 FormatUtil.FormatDouble (clientTradePaymentGapArray[i] / pathCount, 5, 2, 1) + " | [" +
  671.                 new JulianDate (clientDealerTradePaymentGapStartDateArray[i]) + " -> " +
  672.                 new JulianDate (clientDealerTradePaymentGapEndDateArray[i]) + "] | " +
  673.                 FormatUtil.FormatDouble (clientDealerTradePaymentGapArray[i] / pathCount, 5, 2, 1) + " | " +
  674.                 FormatUtil.FormatDouble (tradePaymentGapArray[i] / pathCount, 5, 2, 1) + " | " +
  675.                 FormatUtil.FormatDouble (collateralizedExposureArray[i] / pathCount, 5, 2, 1) + " | " +
  676.                 FormatUtil.FormatDouble (collateralizedPositiveExposureArray[i] / pathCount, 5, 2, 1) + " ||"
  677.             );
  678.         }

  679.         System.out.println ("\t|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------||");

  680.         EnvManager.TerminateEnv();
  681.     }
  682. }