FloatFloatSwapConvention.java
- package org.drip.market.otc;
- /*
- * -*- mode: java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
- */
- /*!
- * Copyright (C) 2020 Lakshmi Krishnamurthy
- * Copyright (C) 2019 Lakshmi Krishnamurthy
- * Copyright (C) 2018 Lakshmi Krishnamurthy
- * Copyright (C) 2017 Lakshmi Krishnamurthy
- * Copyright (C) 2016 Lakshmi Krishnamurthy
- * Copyright (C) 2015 Lakshmi Krishnamurthy
- *
- * This file is part of DROP, an open-source library targeting analytics/risk, transaction cost analytics,
- * asset liability management analytics, capital, exposure, and margin analytics, valuation adjustment
- * analytics, and portfolio construction analytics within and across fixed income, credit, commodity,
- * equity, FX, and structured products. It also includes auxiliary libraries for algorithm support,
- * numerical analysis, numerical optimization, spline builder, model validation, statistical learning,
- * and computational support.
- *
- * https://lakshmidrip.github.io/DROP/
- *
- * DROP is composed of three modules:
- *
- * - DROP Product Core - https://lakshmidrip.github.io/DROP-Product-Core/
- * - DROP Portfolio Core - https://lakshmidrip.github.io/DROP-Portfolio-Core/
- * - DROP Computational Core - https://lakshmidrip.github.io/DROP-Computational-Core/
- *
- * DROP Product Core implements libraries for the following:
- * - Fixed Income Analytics
- * - Loan Analytics
- * - Transaction Cost Analytics
- *
- * DROP Portfolio Core implements libraries for the following:
- * - Asset Allocation Analytics
- * - Asset Liability Management Analytics
- * - Capital Estimation Analytics
- * - Exposure Analytics
- * - Margin Analytics
- * - XVA Analytics
- *
- * DROP Computational Core implements libraries for the following:
- * - Algorithm Support
- * - Computation Support
- * - Function Analysis
- * - Model Validation
- * - Numerical Analysis
- * - Numerical Optimizer
- * - Spline Builder
- * - Statistical Learning
- *
- * Documentation for DROP is Spread Over:
- *
- * - Main => https://lakshmidrip.github.io/DROP/
- * - Wiki => https://github.com/lakshmiDRIP/DROP/wiki
- * - GitHub => https://github.com/lakshmiDRIP/DROP
- * - Repo Layout Taxonomy => https://github.com/lakshmiDRIP/DROP/blob/master/Taxonomy.md
- * - Javadoc => https://lakshmidrip.github.io/DROP/Javadoc/index.html
- * - Technical Specifications => https://github.com/lakshmiDRIP/DROP/tree/master/Docs/Internal
- * - Release Versions => https://lakshmidrip.github.io/DROP/version.html
- * - Community Credits => https://lakshmidrip.github.io/DROP/credits.html
- * - Issues Catalog => https://github.com/lakshmiDRIP/DROP/issues
- * - JUnit => https://lakshmidrip.github.io/DROP/junit/index.html
- * - Jacoco => https://lakshmidrip.github.io/DROP/jacoco/index.html
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- *
- * You may obtain a copy of the License at
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- *
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- /**
- * <i>FloatFloatSwapConvention</i> contains the Details of the IBOR Float-Float Component of an OTC contact.
- *
- * <br><br>
- * <ul>
- * <li><b>Module </b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/ProductCore.md">Product Core Module</a></li>
- * <li><b>Library</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/FixedIncomeAnalyticsLibrary.md">Fixed Income Analytics Library</a></li>
- * <li><b>Project</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/market">Static Market Fields - the Definitions, the OTC/Exchange Traded Products, and Treasury Settings</a></li>
- * <li><b>Package</b> = <a href = "https://github.com/lakshmiDRIP/DROP/tree/master/src/main/java/org/drip/market/otc">OTC Dual Stream Option Container</a></li>
- * </ul>
- *
- * @author Lakshmi Krishnamurthy
- */
- public class FloatFloatSwapConvention {
- private int _iSpotLag = -1;
- private boolean _bIsComponentPair = false;
- private java.lang.String _strCurrency = "";
- private boolean _bBasisOnDerivedStream = true;
- private boolean _bBasisOnDerivedComponent = true;
- private java.lang.String _strReferenceTenor = "";
- private boolean _bIsDerivedCompoundedToReference = true;
- private org.drip.product.rates.FixFloatComponent fixFloatComponent (
- final org.drip.analytics.date.JulianDate dtEffective,
- final java.lang.String strFloaterTenor,
- final java.lang.String strMaturityTenor,
- final double dblFixedCoupon,
- final double dblBasis,
- final double dblNotional)
- {
- org.drip.market.otc.FixedFloatSwapConvention ffConv =
- org.drip.market.otc.IBORFixedFloatContainer.ConventionFromJurisdiction (_strCurrency);
- if (null == ffConv) return null;
- org.drip.market.otc.FixedStreamConvention fixedConv = ffConv.fixedStreamConvention();
- org.drip.product.rates.Stream streamFixed = fixedConv.createStream (dtEffective, strMaturityTenor,
- dblFixedCoupon + (_bBasisOnDerivedStream ? 0. : dblBasis), dblNotional);
- org.drip.state.identifier.ForwardLabel forwardLabel = org.drip.state.identifier.ForwardLabel.Create
- (org.drip.market.definition.IBORIndexContainer.IndexFromJurisdiction (_strCurrency),
- strFloaterTenor);
- java.lang.String strFloaterTenorComposite = _bIsDerivedCompoundedToReference ?
- fixedConv.compositePeriodTenor() : strFloaterTenor;
- try {
- org.drip.param.period.ComposableFloatingUnitSetting cfus = new
- org.drip.param.period.ComposableFloatingUnitSetting (strFloaterTenor,
- org.drip.analytics.support.CompositePeriodBuilder.EDGE_DATE_SEQUENCE_REGULAR, null,
- forwardLabel,
- org.drip.analytics.support.CompositePeriodBuilder.REFERENCE_PERIOD_IN_ADVANCE,
- _bBasisOnDerivedStream ? dblBasis : 0.);
- org.drip.param.period.CompositePeriodSetting cps = new
- org.drip.param.period.CompositePeriodSetting
- (org.drip.analytics.support.Helper.TenorToFreq (strFloaterTenorComposite),
- strFloaterTenorComposite, _strCurrency, null, -1. * dblNotional, null, null, null,
- null);
- java.util.List<java.lang.Integer> lsEdgeDate =
- org.drip.analytics.support.CompositePeriodBuilder.RegularEdgeDates (dtEffective,
- strFloaterTenorComposite, strMaturityTenor, null);
- org.drip.product.rates.Stream streamFloater = new org.drip.product.rates.Stream
- (org.drip.analytics.support.CompositePeriodBuilder.FloatingCompositeUnit (lsEdgeDate, cps,
- cfus));
- org.drip.product.rates.FixFloatComponent ffc = new org.drip.product.rates.FixFloatComponent
- (streamFixed, streamFloater, null);
- ffc.setPrimaryCode ("IRS::" + ffc.forwardLabel().get ("DERIVED").fullyQualifiedName() + "." +
- strMaturityTenor);
- return ffc;
- } catch (java.lang.Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- /**
- * FloatFloatSwapConvention Constructor
- *
- * @param strCurrency The Currency
- * @param strReferenceTenor The Reference Tenor
- * @param bBasisOnDerivedStream TRUE - Apply the Basis to the Derived Stream
- * @param bBasisOnDerivedComponent TRUE - Apply the Basis to the Derived Component
- * @param bIsDerivedCompoundedToReference TRUE - The Derived Periods are Compounded onto the Reference
- * @param bIsComponentPair TRUE - The Float-Float Swap is a Component Pair of 2 Fix-Float Swaps
- * @param iSpotLag Spot Lag
- *
- * @throws java.lang.Exception Thrown if the Inputs are Invalid
- */
- public FloatFloatSwapConvention (
- final java.lang.String strCurrency,
- final java.lang.String strReferenceTenor,
- final boolean bBasisOnDerivedStream,
- final boolean bBasisOnDerivedComponent,
- final boolean bIsDerivedCompoundedToReference,
- final boolean bIsComponentPair,
- final int iSpotLag)
- throws java.lang.Exception
- {
- if (null == (_strCurrency = strCurrency) || _strCurrency.isEmpty() || null == (_strReferenceTenor =
- strReferenceTenor) || _strReferenceTenor.isEmpty() || 0 > (_iSpotLag = iSpotLag))
- throw new java.lang.Exception ("FloatFloatSwapConvention ctr: Invalid Inputs");
- _bIsComponentPair = bIsComponentPair;
- _bBasisOnDerivedStream = bBasisOnDerivedStream;
- _bBasisOnDerivedComponent = bBasisOnDerivedComponent;
- _bIsDerivedCompoundedToReference = bIsDerivedCompoundedToReference;
- }
- /**
- * Retrieve the Currency
- *
- * @return The Currency
- */
- public java.lang.String currency()
- {
- return _strCurrency;
- }
- /**
- * Retrieve the Reference Tenor
- *
- * @return The Reference Tenor
- */
- public java.lang.String referenceTenor()
- {
- return _strReferenceTenor;
- }
- /**
- * Retrieve the Flag indicating whether the Basis is to be applied to the Derived or the Reference Stream
- *
- * @return TRUE - The Basis is applied to the Derived Stream
- */
- public boolean basisOnDerivedStream()
- {
- return _bBasisOnDerivedStream;
- }
- /**
- * Retrieve the Flag indicating whether the Basis is to be applied to the Derived or the Reference
- * Component
- *
- * @return TRUE - The Basis is applied to the Derived Component
- */
- public boolean basisOnDerivedComponent()
- {
- return _bBasisOnDerivedComponent;
- }
- /**
- * Retrieve the Flag indicating whether the Derived Periods are to be compounded onto the Reference
- * Period
- *
- * @return TRUE - The Derived Periods are Compounded onto the Reference
- */
- public boolean derivedCompoundedToReference()
- {
- return _bIsDerivedCompoundedToReference;
- }
- /**
- * Retrieve the Flag indicating whether the Float-Float Swap is a Component Pair of 2 Fix-Float Swaps
- *
- * @return TRUE - The Float-Float Swap is a Component Pair of 2 Fix-Float Swaps
- */
- public boolean componentPair()
- {
- return _bIsComponentPair;
- }
- /**
- * Retrieve the Spot Lag
- *
- * @return The Spot Lag
- */
- public int spotLag()
- {
- return _iSpotLag;
- }
- /**
- * Create an Instance of the Float-Float Component
- *
- * @param dtSpot Spot Date
- * @param strDerivedTenor The Derived Tenor
- * @param strMaturityTenor The Maturity Tenor
- * @param dblBasis Basis
- * @param dblNotional Notional
- *
- * @return Instance of the Float-Float Component
- */
- public org.drip.product.rates.FloatFloatComponent createFloatFloatComponent (
- final org.drip.analytics.date.JulianDate dtSpot,
- final java.lang.String strDerivedTenor,
- final java.lang.String strMaturityTenor,
- final double dblBasis,
- final double dblNotional)
- {
- if (_bIsComponentPair || null == dtSpot) return null;
- org.drip.state.identifier.ForwardLabel forwardLabelReference =
- org.drip.state.identifier.ForwardLabel.Create
- (org.drip.market.definition.IBORIndexContainer.IndexFromJurisdiction (_strCurrency),
- _strReferenceTenor);
- if (null == forwardLabelReference) return null;
- org.drip.analytics.date.JulianDate dtEffective = dtSpot.addBusDays (_iSpotLag,
- forwardLabelReference.floaterIndex().calendar());
- org.drip.state.identifier.ForwardLabel forwardLabelDerived =
- org.drip.state.identifier.ForwardLabel.Create
- (org.drip.market.definition.IBORIndexContainer.IndexFromJurisdiction (_strCurrency),
- strDerivedTenor);
- if (null == forwardLabelDerived) return null;
- java.lang.String strDerivedTenorComposite = _bIsDerivedCompoundedToReference ? _strReferenceTenor :
- strDerivedTenor;
- try {
- org.drip.param.period.ComposableFloatingUnitSetting cfusReference = new
- org.drip.param.period.ComposableFloatingUnitSetting (_strReferenceTenor,
- org.drip.analytics.support.CompositePeriodBuilder.EDGE_DATE_SEQUENCE_REGULAR, null,
- forwardLabelReference,
- org.drip.analytics.support.CompositePeriodBuilder.REFERENCE_PERIOD_IN_ADVANCE,
- !_bBasisOnDerivedStream ? dblBasis : 0.);
- org.drip.param.period.CompositePeriodSetting cpsReference = new
- org.drip.param.period.CompositePeriodSetting
- (org.drip.analytics.support.Helper.TenorToFreq (_strReferenceTenor),
- _strReferenceTenor, _strCurrency, null, dblNotional, null, null, null, null);
- java.util.List<java.lang.Integer> lsReferenceEdgeDate =
- org.drip.analytics.support.CompositePeriodBuilder.RegularEdgeDates (dtEffective,
- _strReferenceTenor, strMaturityTenor, null);
- org.drip.product.rates.Stream streamReference = new org.drip.product.rates.Stream
- (org.drip.analytics.support.CompositePeriodBuilder.FloatingCompositeUnit
- (lsReferenceEdgeDate, cpsReference, cfusReference));
- org.drip.param.period.ComposableFloatingUnitSetting cfusDerived = new
- org.drip.param.period.ComposableFloatingUnitSetting (strDerivedTenor,
- org.drip.analytics.support.CompositePeriodBuilder.EDGE_DATE_SEQUENCE_REGULAR, null,
- forwardLabelDerived,
- org.drip.analytics.support.CompositePeriodBuilder.REFERENCE_PERIOD_IN_ADVANCE,
- _bBasisOnDerivedStream ? dblBasis : 0.);
- org.drip.param.period.CompositePeriodSetting cpsDerived = new
- org.drip.param.period.CompositePeriodSetting
- (org.drip.analytics.support.Helper.TenorToFreq (strDerivedTenorComposite),
- strDerivedTenorComposite, _strCurrency, null, -1. * dblNotional, null, null, null,
- null);
- java.util.List<java.lang.Integer> lsDerivedEdgeDate =
- org.drip.analytics.support.CompositePeriodBuilder.RegularEdgeDates (dtEffective,
- strDerivedTenor, strMaturityTenor, null);
- org.drip.product.rates.Stream streamDerived = new org.drip.product.rates.Stream
- (org.drip.analytics.support.CompositePeriodBuilder.FloatingCompositeUnit (lsDerivedEdgeDate,
- cpsDerived, cfusDerived));
- return new org.drip.product.rates.FloatFloatComponent (streamReference, streamDerived, null);
- } catch (java.lang.Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- /**
- * Create an Instance of the Fix-Float Component Pair
- *
- * @param dtSpot Spot Date
- * @param strDerivedTenor The Derived Tenor
- * @param strMaturityTenor The Maturity Tenor
- * @param dblReferenceFixedCoupon Fixed Coupon Rate for the Reference Component
- * @param dblDerivedFixedCoupon Fixed Coupon Rate for the Derived Component
- * @param dblBasis Basis
- * @param dblNotional Notional
- *
- * @return Instance of the Fix-Float Component Pair
- */
- public org.drip.product.fx.ComponentPair createFixFloatComponentPair (
- final org.drip.analytics.date.JulianDate dtSpot,
- final java.lang.String strDerivedTenor,
- final java.lang.String strMaturityTenor,
- final double dblReferenceFixedCoupon,
- final double dblDerivedFixedCoupon,
- final double dblBasis,
- final double dblNotional)
- {
- if (!_bIsComponentPair || null == dtSpot) return null;
- org.drip.market.definition.IBORIndex floaterIndex =
- org.drip.market.definition.IBORIndexContainer.IndexFromJurisdiction (_strCurrency);
- if (null == floaterIndex) return null;
- org.drip.analytics.date.JulianDate dtEffective = dtSpot.addBusDays (_iSpotLag,
- floaterIndex.calendar());
- org.drip.product.rates.FixFloatComponent ffcReference = fixFloatComponent (dtEffective,
- _strReferenceTenor, strMaturityTenor, dblReferenceFixedCoupon, !_bBasisOnDerivedComponent ?
- dblBasis : 0., dblNotional);
- org.drip.product.rates.FixFloatComponent ffcDerived = fixFloatComponent (dtEffective,
- strDerivedTenor, strMaturityTenor, dblDerivedFixedCoupon, _bBasisOnDerivedComponent ? dblBasis :
- 0., -1. * dblNotional);
- try {
- return new org.drip.product.fx.ComponentPair (_strCurrency + "::" + _strReferenceTenor + "/" +
- strDerivedTenor + "_" + strMaturityTenor, ffcReference, ffcDerived, null);
- } catch (java.lang.Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- }