NOK3M6MUSD3M6M.java

  1. package org.drip.sample.dual;

  2. import org.drip.analytics.date.*;
  3. import org.drip.analytics.support.CompositePeriodBuilder;
  4. import org.drip.function.r1tor1.QuadraticRationalShapeControl;
  5. import org.drip.market.definition.*;
  6. import org.drip.sample.forward.*;
  7. import org.drip.service.env.EnvManager;
  8. import org.drip.spline.basis.PolynomialFunctionSetParams;
  9. import org.drip.spline.params.*;
  10. import org.drip.spline.stretch.*;
  11. import org.drip.state.discount.*;
  12. import org.drip.state.forward.ForwardCurve;
  13. import org.drip.state.identifier.ForwardLabel;

  14. /*
  15.  * -*- mode: java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
  16.  */

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

  91. /**
  92.  * <i>NOK3M6MUSD3M6M</i> demonstrates the setup and construction of the USD 3M Forward Curve from
  93.  * NOK3M6MUSD3M6M CCBS, NOK 3M, NOK 6M, and USD 6M Quotes.
  94.  *
  95.  * <br><br>
  96.  *  <ul>
  97.  *      <li><b>Module </b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/ProductCore.md">Product Core Module</a></li>
  98.  *      <li><b>Library</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/FixedIncomeAnalyticsLibrary.md">Fixed Income Analytics</a></li>
  99.  *      <li><b>Project</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/sample/README.md">DROP API Construction and Usage</a></li>
  100.  *      <li><b>Package</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/sample/cross/README.md">G7 Standard Cross Currency Swap</a></li>
  101.  *  </ul>
  102.  * <br><br>
  103.  *
  104.  * @author Lakshmi Krishnamurthy
  105.  */

  106. public class NOK3M6MUSD3M6M {
  107.     private static final double _dblFXNOKUSD = 0.1676;

  108.     private static final int[] s_aiUSDOISDepositMaturityDays = new int[] {
  109.         1,
  110.         2,
  111.         3
  112.     };

  113.     private static final double[] s_adblUSDOISDepositQuote = new double[] {
  114.         0.0004, // 1D
  115.         0.0004, // 2D
  116.         0.0004  // 3D
  117.     };

  118.     private static final String[] s_astrUSDShortEndOISMaturityTenor = new String[] {
  119.         "1W",
  120.         "2W",
  121.         "3W",
  122.         "1M"
  123.     };

  124.     private static final double[] s_adblUSDShortEndOISQuote = new double[] {
  125.         0.00070,    //   1W
  126.         0.00069,    //   2W
  127.         0.00078,    //   3W
  128.         0.00074     //   1M
  129.     };

  130.     private static final String[] s_astrUSDOISFutureTenor = new String[] {
  131.         "1M",
  132.         "1M",
  133.         "1M",
  134.         "1M",
  135.         "1M"
  136.     };

  137.     private static final String[] s_astrUSDOISFutureMaturityTenor = new String[] {
  138.         "1M",
  139.         "2M",
  140.         "3M",
  141.         "4M",
  142.         "5M"
  143.     };

  144.     private static final double[] s_adblUSDOISFutureQuote = new double[] {
  145.          0.00046,    //   1M x 1M
  146.          0.00016,    //   2M x 1M
  147.         -0.00007,    //   3M x 1M
  148.         -0.00013,    //   4M x 1M
  149.         -0.00014     //   5M x 1M
  150.     };

  151.     private static final String[] s_astrUSDLongEndOISMaturityTenor = new String[] {
  152.         "15M",
  153.         "18M",
  154.         "21M",
  155.         "2Y",
  156.         "3Y",
  157.         "4Y",
  158.         "5Y",
  159.         "6Y",
  160.         "7Y",
  161.         "8Y",
  162.         "9Y",
  163.         "10Y",
  164.         "11Y",
  165.         "12Y",
  166.         "15Y",
  167.         "20Y",
  168.         "25Y",
  169.         "30Y"
  170.     };

  171.     private static final double[] s_adblUSDLongEndOISQuote = new double[] {
  172.         0.00002,    //  15M
  173.         0.00008,    //  18M
  174.         0.00021,    //  21M
  175.         0.00036,    //   2Y
  176.         0.00127,    //   3Y
  177.         0.00274,    //   4Y
  178.         0.00456,    //   5Y
  179.         0.00647,    //   6Y
  180.         0.00827,    //   7Y
  181.         0.00996,    //   8Y
  182.         0.01147,    //   9Y
  183.         0.01280,    //  10Y
  184.         0.01404,    //  11Y
  185.         0.01516,    //  12Y
  186.         0.01764,    //  15Y
  187.         0.01939,    //  20Y
  188.         0.02003,    //  25Y
  189.         0.02038     //  30Y
  190.     };

  191.     private static final int[] s_aiNOKOISDepositMaturityDays = new int[] {
  192.         1,
  193.         2,
  194.         3
  195.     };

  196.     private static final double[] s_adblNOKOISDepositQuote = new double[] {
  197.         0.0004, // 1D
  198.         0.0004, // 2D
  199.         0.0004  // 3D
  200.     };

  201.     private static final String[] s_astrNOKShortEndOISMaturityTenor = new String[] {
  202.         "1W",
  203.         "2W",
  204.         "3W",
  205.         "1M"
  206.     };

  207.     private static final double[] s_adblNOKShortEndOISQuote = new double[] {
  208.         0.00070,    //   1W
  209.         0.00069,    //   2W
  210.         0.00078,    //   3W
  211.         0.00074     //   1M
  212.     };

  213.     private static final String[] s_astrNOKOISFutureTenor = new String[] {
  214.         "1M",
  215.         "1M",
  216.         "1M",
  217.         "1M",
  218.         "1M"
  219.     };

  220.     private static final String[] s_astrNOKOISFutureMaturityTenor = new String[] {
  221.         "1M",
  222.         "2M",
  223.         "3M",
  224.         "4M",
  225.         "5M"
  226.     };

  227.     private static final double[] s_adblNOKOISFutureQuote = new double[] {
  228.          0.00046,    //   1M x 1M
  229.          0.00016,    //   2M x 1M
  230.         -0.00007,    //   3M x 1M
  231.         -0.00013,    //   4M x 1M
  232.         -0.00014     //   5M x 1M
  233.     };

  234.     private static final String[] s_astrNOKLongEndOISMaturityTenor = new String[] {
  235.         "15M",
  236.         "18M",
  237.         "21M",
  238.         "2Y",
  239.         "3Y",
  240.         "4Y",
  241.         "5Y",
  242.         "6Y",
  243.         "7Y",
  244.         "8Y",
  245.         "9Y",
  246.         "10Y",
  247.         "11Y",
  248.         "12Y",
  249.         "15Y",
  250.         "20Y",
  251.         "25Y",
  252.         "30Y"
  253.     };

  254.     private static final double[] s_adblNOKLongEndOISQuote = new double[] {
  255.         0.00002,    //  15M
  256.         0.00008,    //  18M
  257.         0.00021,    //  21M
  258.         0.00036,    //   2Y
  259.         0.00127,    //   3Y
  260.         0.00274,    //   4Y
  261.         0.00456,    //   5Y
  262.         0.00647,    //   6Y
  263.         0.00827,    //   7Y
  264.         0.00996,    //   8Y
  265.         0.01147,    //   9Y
  266.         0.01280,    //  10Y
  267.         0.01404,    //  11Y
  268.         0.01516,    //  12Y
  269.         0.01764,    //  15Y
  270.         0.01939,    //  20Y
  271.         0.02003,    //  25Y
  272.         0.02038     //  30Y
  273.     };

  274.     private static final String[] s_astrUSD6MDepositTenor = new String[] {
  275.         "1D",
  276.         "1W",
  277.         "2W",
  278.         "3W",
  279.         "1M",
  280.         "2M",
  281.         "3M",
  282.         "4M",
  283.         "5M"
  284.     };

  285.     private static final double[] s_adblUSD6MDepositQuote = new double[] {
  286.         0.003565,   // 1D
  287.         0.003858,   // 1W
  288.         0.003840,   // 2W
  289.         0.003922,   // 3W
  290.         0.003869,   // 1M
  291.         0.003698,   // 2M
  292.         0.003527,   // 3M
  293.         0.003342,   // 4M
  294.         0.003225    // 5M
  295.     };

  296.     private static final String[] s_astrUSD6MFRATenor = new String[] {
  297.          "0D",
  298.          "1M",
  299.          "2M",
  300.          "3M",
  301.          "4M",
  302.          "5M",
  303.          "6M",
  304.          "7M",
  305.          "8M",
  306.          "9M",
  307.         "10M",
  308.         "11M",
  309.         "12M",
  310.         "13M",
  311.         "14M",
  312.         "15M",
  313.         "16M",
  314.         "17M",
  315.         "18M"
  316.     };

  317.     private static final double[] s_adblUSD6MFRAQuote = new double[] {
  318.         0.003120,   //  0D
  319.         0.002930,   //  1M
  320.         0.002720,   //  2M
  321.         0.002600,   //  3M
  322.         0.002560,   //  4M
  323.         0.002520,   //  5M
  324.         0.002480,   //  6M
  325.         0.002540,   //  7M
  326.         0.002610,   //  8M
  327.         0.002670,   //  9M
  328.         0.002790,   // 10M
  329.         0.002910,   // 11M
  330.         0.003030,   // 12M
  331.         0.003180,   // 13M
  332.         0.003350,   // 14M
  333.         0.003520,   // 15M
  334.         0.003710,   // 16M
  335.         0.003890,   // 17M
  336.         0.004090    // 18M
  337.     };

  338.     private static final String[] s_astrUSD6MFixFloatTenor = new String[] {
  339.          "3Y",
  340.          "4Y",
  341.          "5Y",
  342.          "6Y",
  343.          "7Y",
  344.          "8Y",
  345.          "9Y",
  346.         "10Y",
  347.         "12Y",
  348.         "15Y",
  349.         "20Y",
  350.         "25Y",
  351.         "30Y",
  352.         "35Y",
  353.         "40Y",
  354.         "50Y",
  355.         "60Y"
  356.     };

  357.     private static final double[] s_adblUSD6MFixFloatQuote = new double[] {
  358.         0.004240,   //  3Y
  359.         0.005760,   //  4Y          
  360.         0.007620,   //  5Y
  361.         0.009540,   //  6Y
  362.         0.011350,   //  7Y
  363.         0.013030,   //  8Y
  364.         0.014520,   //  9Y
  365.         0.015840,   // 10Y
  366.         0.018090,   // 12Y
  367.         0.020370,   // 15Y
  368.         0.021870,   // 20Y
  369.         0.022340,   // 25Y
  370.         0.022560,   // 30Y
  371.         0.022950,   // 35Y
  372.         0.023480,   // 40Y
  373.         0.024210,   // 50Y
  374.         0.024630    // 60Y
  375.     };

  376.     private static final String[] s_astrUSD3MDepositTenor = new String[] {
  377.         "2W",
  378.         "3W",
  379.         "1M",
  380.         "2M"
  381.     };

  382.     private static final double[] s_adblUSD3MDepositQuote = new double[] {
  383.         0.001865,
  384.         0.001969,
  385.         0.001951,
  386.         0.001874
  387.     };

  388.     private static final String[] s_astrUSD3MFRATenor = new String[] {
  389.          "0D",
  390.          "1M",
  391.          "3M",
  392.          "6M",
  393.          "9M",
  394.         "12M",
  395.         "15M",
  396.         "18M",
  397.         "21M"
  398.     };

  399.     private static final double[] s_adblUSD3MFRAQuote = new double[] {
  400.         0.001790,
  401.         0.001775,
  402.         0.001274,
  403.         0.001222,
  404.         0.001269,
  405.         0.001565,
  406.         0.001961,
  407.         0.002556,
  408.         0.003101
  409.     };

  410.     private static final String[] s_astrUSD3MFixFloatTenor = new String[] {
  411.          "3Y",
  412.          "4Y",
  413.          "5Y",
  414.          "6Y",
  415.          "7Y",
  416.          "8Y",
  417.          "9Y",
  418.         "10Y",
  419.         "12Y",
  420.         "15Y",
  421.         "20Y",
  422.         "25Y",
  423.         "30Y"
  424.     };

  425.     private static final double[] s_adblUSD3MFixFloatQuote = new double[] {
  426.         0.002850,   //  3Y
  427.         0.004370,   //  4Y
  428.         0.006230,   //  5Y
  429.         0.008170,   //  6Y
  430.         0.010000,   //  7Y
  431.         0.011710,   //  8Y
  432.         0.013240,   //  9Y
  433.         0.014590,   // 10Y
  434.         0.016920,   // 12Y
  435.         0.019330,   // 15Y
  436.         0.020990,   // 20Y
  437.         0.021560,   // 25Y
  438.         0.021860    // 30Y
  439.     };

  440.     private static final String[] s_astrUSD3MSyntheticFloatFloatTenor = new String[] {
  441.         "35Y",
  442.         "40Y",
  443.         "50Y",
  444.         "60Y"
  445.     };

  446.     private static final double[] s_adblUSD3MSyntheticFloatFloatQuote = new double[] {
  447.         0.00065,
  448.         0.00060,
  449.         0.00054,
  450.         0.00050
  451.     };

  452.     private static final String[] s_astrNOK6MDepositTenor = new String[] {
  453.         "1D",
  454.         "1W",
  455.         "2W",
  456.         "3W",
  457.         "1M",
  458.         "2M",
  459.         "3M",
  460.         "4M",
  461.         "5M"
  462.     };

  463.     private static final double[] s_adblNOK6MDepositQuote = new double[] {
  464.         0.003565,   // 1D
  465.         0.003858,   // 1W
  466.         0.003840,   // 2W
  467.         0.003922,   // 3W
  468.         0.003869,   // 1M
  469.         0.003698,   // 2M
  470.         0.003527,   // 3M
  471.         0.003342,   // 4M
  472.         0.003225    // 5M
  473.     };

  474.     private static final String[] s_astrNOK6MFRATenor = new String[] {
  475.          "0D",
  476.          "1M",
  477.          "2M",
  478.          "3M",
  479.          "4M",
  480.          "5M",
  481.          "6M",
  482.          "7M",
  483.          "8M",
  484.          "9M",
  485.         "10M",
  486.         "11M",
  487.         "12M",
  488.         "13M",
  489.         "14M",
  490.         "15M",
  491.         "16M",
  492.         "17M",
  493.         "18M"
  494.     };

  495.     private static final double[] s_adblNOK6MFRAQuote = new double[] {
  496.         0.003120,   //  0D
  497.         0.002930,   //  1M
  498.         0.002720,   //  2M
  499.         0.002600,   //  3M
  500.         0.002560,   //  4M
  501.         0.002520,   //  5M
  502.         0.002480,   //  6M
  503.         0.002540,   //  7M
  504.         0.002610,   //  8M
  505.         0.002670,   //  9M
  506.         0.002790,   // 10M
  507.         0.002910,   // 11M
  508.         0.003030,   // 12M
  509.         0.003180,   // 13M
  510.         0.003350,   // 14M
  511.         0.003520,   // 15M
  512.         0.003710,   // 16M
  513.         0.003890,   // 17M
  514.         0.004090    // 18M
  515.     };

  516.     private static final String[] s_astrNOK6MFixFloatTenor = new String[] {
  517.          "3Y",
  518.          "4Y",
  519.          "5Y",
  520.          "6Y",
  521.          "7Y",
  522.          "8Y",
  523.          "9Y",
  524.         "10Y",
  525.         "12Y",
  526.         "15Y",
  527.         "20Y",
  528.         "25Y",
  529.         "30Y",
  530.         "35Y",
  531.         "40Y",
  532.         "50Y",
  533.         "60Y"
  534.     };

  535.     private static final double[] s_adblNOK6MFixFloatQuote = new double[] {
  536.         0.004240,   //  3Y
  537.         0.005760,   //  4Y          
  538.         0.007620,   //  5Y
  539.         0.009540,   //  6Y
  540.         0.011350,   //  7Y
  541.         0.013030,   //  8Y
  542.         0.014520,   //  9Y
  543.         0.015840,   // 10Y
  544.         0.018090,   // 12Y
  545.         0.020370,   // 15Y
  546.         0.021870,   // 20Y
  547.         0.022340,   // 25Y
  548.         0.022560,   // 30Y
  549.         0.022950,   // 35Y
  550.         0.023480,   // 40Y
  551.         0.024210,   // 50Y
  552.         0.024630    // 60Y
  553.     };

  554.     private static final String[] s_astrCCBSTenor = new String[] {
  555.         "1Y",
  556.         "2Y",
  557.         "3Y",
  558.         "4Y",
  559.         "5Y",
  560.         "7Y",
  561.         "10Y",
  562.         "15Y",
  563.         "20Y"
  564.     };

  565.     private static final double[] s_adblCCBSQuote = new double[] {
  566.         -0.000600, //  1Y
  567.         -0.000600, //  2Y
  568.         -0.000600, //  3Y
  569.         -0.000575, //  4Y
  570.         -0.000575, //  5Y
  571.         -0.000575, //  7Y
  572.         -0.000575, // 10Y
  573.         -0.000600, // 15Y
  574.         -0.000600  // 20Y
  575.     };

  576.     private static final double[] s_adblIRSQuote = new double[] {
  577.         0.0575, //  1Y
  578.         0.0575, //  2Y
  579.         0.0575, //  3Y
  580.         0.0575, //  4Y
  581.         0.0600, //  5Y
  582.         0.0600, //  7Y
  583.         0.0600, // 10Y
  584.         0.0600, // 15Y
  585.         0.0600  // 20Y
  586.     };

  587.     public static final void main (
  588.         final String[] astrArgs)
  589.         throws Exception
  590.     {
  591.         /*
  592.          * Initialize the Credit Analytics Library
  593.          */

  594.         EnvManager.InitEnv ("");

  595.         JulianDate dtValue = DateUtil.CreateFromYMD (
  596.             2012,
  597.             DateUtil.DECEMBER,
  598.             11
  599.         );

  600.         String strReferenceCurrency = "USD";
  601.         String strDerivedCurrency = "NOK";

  602.         SegmentCustomBuilderControl scbcCubic = new SegmentCustomBuilderControl (
  603.             MultiSegmentSequenceBuilder.BASIS_SPLINE_POLYNOMIAL,
  604.             new PolynomialFunctionSetParams (4),
  605.             SegmentInelasticDesignControl.Create (
  606.                 2,
  607.                 2
  608.             ),
  609.             new ResponseScalingShapeControl (
  610.                 true,
  611.                 new QuadraticRationalShapeControl (0.)
  612.             ),
  613.             null
  614.         );

  615.         FloaterIndex fiNOK = new OvernightIndex (
  616.             strDerivedCurrency + "OIS",
  617.             "OIS",
  618.             strDerivedCurrency,
  619.             "Act/360",
  620.             strDerivedCurrency,
  621.             "ON",
  622.             0,
  623.             CompositePeriodBuilder.ACCRUAL_COMPOUNDING_RULE_GEOMETRIC
  624.         );

  625.         MergedDiscountForwardCurve dcReference = OvernightIndexCurve.MakeDC (
  626.             strReferenceCurrency,
  627.             dtValue,
  628.             s_aiUSDOISDepositMaturityDays,
  629.             s_adblUSDOISDepositQuote,
  630.             s_astrUSDShortEndOISMaturityTenor,
  631.             s_adblUSDShortEndOISQuote,
  632.             s_astrUSDOISFutureTenor,
  633.             s_astrUSDOISFutureMaturityTenor,
  634.             s_adblUSDOISFutureQuote,
  635.             s_astrUSDLongEndOISMaturityTenor,
  636.             s_adblUSDLongEndOISQuote,
  637.             scbcCubic,
  638.             null
  639.         );

  640.         ForwardCurve fc6MReference = IBORCurve.CustomIBORBuilderSample (
  641.             dcReference,
  642.             null,
  643.             ForwardLabel.Create (
  644.                 strReferenceCurrency,
  645.                 "6M"
  646.             ),
  647.             scbcCubic,
  648.             s_astrUSD6MDepositTenor,
  649.             s_adblUSD6MDepositQuote,
  650.             "ForwardRate",
  651.             s_astrUSD6MFRATenor,
  652.             s_adblUSD6MFRAQuote,
  653.             "ParForwardRate",
  654.             s_astrUSD6MFixFloatTenor,
  655.             s_adblUSD6MFixFloatQuote,
  656.             "SwapRate",
  657.             null,
  658.             null,
  659.             "DerivedParBasisSpread",
  660.             null,
  661.             null,
  662.             "DerivedParBasisSpread",
  663.             "---- USD LIBOR 6M VANILLA CUBIC POLYNOMIAL FORWARD CURVE ---",
  664.             false
  665.         );

  666.         ForwardCurve fc3MReference = IBORCurve.CustomIBORBuilderSample (
  667.             dcReference,
  668.             fc6MReference,
  669.             ForwardLabel.Create (
  670.                 strReferenceCurrency,
  671.                 "3M"
  672.             ),
  673.             scbcCubic,
  674.             s_astrUSD3MDepositTenor,
  675.             s_adblUSD3MDepositQuote,
  676.             "ForwardRate",
  677.             s_astrUSD3MFRATenor,
  678.             s_adblUSD3MFRAQuote,
  679.             "ParForwardRate",
  680.             s_astrUSD3MFixFloatTenor,
  681.             s_adblUSD3MFixFloatQuote,
  682.             "SwapRate",
  683.             null,
  684.             null,
  685.             "DerivedParBasisSpread",
  686.             s_astrUSD3MSyntheticFloatFloatTenor,
  687.             s_adblUSD3MSyntheticFloatFloatQuote,
  688.             "DerivedParBasisSpread",
  689.             "---- VANILLA CUBIC POLYNOMIAL FORWARD CURVE ---",
  690.             false
  691.         );

  692.         MergedDiscountForwardCurve dcDerived = OvernightIndexCurve.MakeDC (
  693.             strDerivedCurrency,
  694.             dtValue,
  695.             s_aiNOKOISDepositMaturityDays,
  696.             s_adblNOKOISDepositQuote,
  697.             s_astrNOKShortEndOISMaturityTenor,
  698.             s_adblNOKShortEndOISQuote,
  699.             s_astrNOKOISFutureTenor,
  700.             s_astrNOKOISFutureMaturityTenor,
  701.             s_adblNOKOISFutureQuote,
  702.             s_astrNOKLongEndOISMaturityTenor,
  703.             s_adblNOKLongEndOISQuote,
  704.             scbcCubic,
  705.             fiNOK
  706.         );

  707.         ForwardCurve fc6MDerived = IBORCurve.CustomIBORBuilderSample (
  708.             dcDerived,
  709.             null,
  710.             ForwardLabel.Create (
  711.                 fiNOK,
  712.                 "6M"
  713.             ),
  714.             scbcCubic,
  715.             s_astrNOK6MDepositTenor,
  716.             s_adblNOK6MDepositQuote,
  717.             "ForwardRate",
  718.             s_astrNOK6MFRATenor,
  719.             s_adblNOK6MFRAQuote,
  720.             "ParForwardRate",
  721.             s_astrNOK6MFixFloatTenor,
  722.             s_adblNOK6MFixFloatQuote,
  723.             "SwapRate",
  724.             null,
  725.             null,
  726.             "DerivedParBasisSpread",
  727.             null,
  728.             null,
  729.             "DerivedParBasisSpread",
  730.             "---- NOK LIBOR 6M VANILLA CUBIC POLYNOMIAL FORWARD CURVE ---",
  731.             false
  732.         );

  733.         CCBSForwardCurve.ForwardCurveReferenceComponentBasis (
  734.             strReferenceCurrency,
  735.             strDerivedCurrency,
  736.             dtValue,
  737.             dcReference,
  738.             fc6MReference,
  739.             fc3MReference,
  740.             dcDerived,
  741.             fc6MDerived,
  742.             _dblFXNOKUSD,
  743.             scbcCubic,
  744.             s_astrCCBSTenor,
  745.             s_adblCCBSQuote,
  746.             true
  747.         );

  748.         CCBSForwardCurve.ForwardCurveReferenceComponentBasis (
  749.             strReferenceCurrency,
  750.             strDerivedCurrency,
  751.             dtValue,
  752.             dcReference,
  753.             fc6MReference,
  754.             fc3MReference,
  755.             dcDerived,
  756.             fc6MDerived,
  757.             _dblFXNOKUSD,
  758.             scbcCubic,
  759.             s_astrCCBSTenor,
  760.             s_adblCCBSQuote,
  761.             false
  762.         );

  763.         CCBSDiscountCurve.MakeDiscountCurve (
  764.             strReferenceCurrency,
  765.             strDerivedCurrency,
  766.             dtValue,
  767.             dcReference,
  768.             fc6MReference,
  769.             fc3MReference,
  770.             _dblFXNOKUSD,
  771.             scbcCubic,
  772.             s_astrCCBSTenor,
  773.             s_adblCCBSQuote,
  774.             s_adblIRSQuote,
  775.             true
  776.         );

  777.         CCBSDiscountCurve.MakeDiscountCurve (
  778.             strReferenceCurrency,
  779.             strDerivedCurrency,
  780.             dtValue,
  781.             dcReference,
  782.             fc6MReference,
  783.             fc3MReference,
  784.             _dblFXNOKUSD,
  785.             scbcCubic,
  786.             s_astrCCBSTenor,
  787.             s_adblCCBSQuote,
  788.             s_adblIRSQuote,
  789.             false
  790.         );

  791.         EnvManager.TerminateEnv();
  792.     }
  793. }