All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.opengamma.strata.pricer.cms.SabrExtrapolationReplicationCmsTradePricer Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2016 - present by OpenGamma Inc. and the OpenGamma group of companies
 *
 * Please see distribution for license.
 */
package com.opengamma.strata.pricer.cms;

import com.opengamma.strata.basics.currency.CurrencyAmount;
import com.opengamma.strata.basics.currency.MultiCurrencyAmount;
import com.opengamma.strata.basics.currency.Payment;
import com.opengamma.strata.collect.ArgChecker;
import com.opengamma.strata.market.explain.ExplainMap;
import com.opengamma.strata.market.sensitivity.PointSensitivities;
import com.opengamma.strata.market.sensitivity.PointSensitivityBuilder;
import com.opengamma.strata.pricer.DiscountingPaymentPricer;
import com.opengamma.strata.pricer.rate.RatesProvider;
import com.opengamma.strata.pricer.swaption.SabrSwaptionVolatilities;
import com.opengamma.strata.product.cms.CmsLeg;
import com.opengamma.strata.product.cms.ResolvedCms;
import com.opengamma.strata.product.cms.ResolvedCmsTrade;

/**
 * Pricer for CMS trade by swaption replication on a SABR formula with extrapolation.
 * 

* This function provides the ability to price {@link ResolvedCmsTrade}. */ public class SabrExtrapolationReplicationCmsTradePricer { /** * Pricer for {@link ResolvedCms}. */ private final SabrExtrapolationReplicationCmsProductPricer productPricer; /** * Pricer for {@link Payment}. */ private final DiscountingPaymentPricer paymentPricer; /** * Creates an instance using the default payment pricer. * * @param cmsProductPricer the pricer for {@link CmsLeg} */ public SabrExtrapolationReplicationCmsTradePricer( SabrExtrapolationReplicationCmsProductPricer cmsProductPricer) { this(cmsProductPricer, DiscountingPaymentPricer.DEFAULT); } /** * Creates an instance. * * @param cmsProductPricer the pricer for {@link ResolvedCms} * @param paymentPricer the pricer for {@link Payment} */ public SabrExtrapolationReplicationCmsTradePricer( SabrExtrapolationReplicationCmsProductPricer cmsProductPricer, DiscountingPaymentPricer paymentPricer) { this.productPricer = ArgChecker.notNull(cmsProductPricer, "cmsProductPricer"); this.paymentPricer = ArgChecker.notNull(paymentPricer, "paymentPricer"); } //------------------------------------------------------------------------- /** * Calculates the present value of the CMS trade. *

* The present value of the trade is the value on the valuation date. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the present value */ public MultiCurrencyAmount presentValue( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { MultiCurrencyAmount pvCms = productPricer.presentValue(trade.getProduct(), ratesProvider, swaptionVolatilities); if (!trade.getPremium().isPresent()) { return pvCms; } CurrencyAmount pvPremium = paymentPricer.presentValue(trade.getPremium().get(), ratesProvider); return pvCms.plus(pvPremium); } //------------------------------------------------------------------------- /** * Explains the present value of the CMS trade. *

* This returns explanatory information about the calculation. * * @param cms the CMS product * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the explain PV map */ public ExplainMap explainPresentValue( ResolvedCms cms, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { return productPricer.explainPresentValue(cms, ratesProvider, swaptionVolatilities); } //------------------------------------------------------------------------- /** * Calculates the present value curve sensitivity of the CMS trade. *

* The present value sensitivity of the trade is the sensitivity of the present value to the underlying curves. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the present value sensitivity */ public PointSensitivities presentValueSensitivityRates( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { PointSensitivityBuilder pvSensiCms = productPricer.presentValueSensitivityRates(trade.getProduct(), ratesProvider, swaptionVolatilities); if (!trade.getPremium().isPresent()) { return pvSensiCms.build(); } PointSensitivityBuilder pvSensiPremium = paymentPricer.presentValueSensitivity(trade.getPremium().get(), ratesProvider); return pvSensiCms.combinedWith(pvSensiPremium).build(); } /** * Calculates the present value sensitivity to the SABR model parameters. *

* The present value sensitivity of the trade is the sensitivity of the present value to the SABR model parameters, * alpha, beta, rho and nu. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the present value sensitivity */ public PointSensitivities presentValueSensitivityModelParamsSabr( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { return productPricer.presentValueSensitivityModelParamsSabr( trade.getProduct(), ratesProvider, swaptionVolatilities).build(); } /** * Calculates the present value sensitivity to the strike value. *

* The present value sensitivity of the trade is the sensitivity of the present value to the strike value. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the present value sensitivity */ public double presentValueSensitivityStrike( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { return productPricer.presentValueSensitivityStrike(trade.getProduct(), ratesProvider, swaptionVolatilities); } //------------------------------------------------------------------------- /** * Calculates the currency exposure of the trade. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the currency exposure */ public MultiCurrencyAmount currencyExposure( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { MultiCurrencyAmount ceCms = productPricer.currencyExposure(trade.getProduct(), ratesProvider, swaptionVolatilities); if (!trade.getPremium().isPresent()) { return ceCms; } CurrencyAmount pvPremium = paymentPricer.presentValue(trade.getPremium().get(), ratesProvider); return ceCms.plus(pvPremium); } /** * Calculates the current cash of the trade. * * @param trade the CMS trade * @param ratesProvider the rates provider * @param swaptionVolatilities the swaption volatilities * @return the current cash */ public MultiCurrencyAmount currentCash( ResolvedCmsTrade trade, RatesProvider ratesProvider, SabrSwaptionVolatilities swaptionVolatilities) { MultiCurrencyAmount ccCms = productPricer.currentCash(trade.getProduct(), ratesProvider, swaptionVolatilities); if (!trade.getPremium().isPresent()) { return ccCms; } Payment premium = trade.getPremium().get(); if (premium.getDate().equals(ratesProvider.getValuationDate())) { ccCms = ccCms.plus(premium.getCurrency(), premium.getAmount()); } return ccCms; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy