/** * Copyright (C) 2011 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.analytics.financial.provider.calculator.issuer; import com.opengamma.analytics.financial.interestrate.InstrumentDerivativeVisitorAdapter; import com.opengamma.analytics.financial.interestrate.bond.definition.BondFixedSecurity; import com.opengamma.analytics.financial.interestrate.bond.definition.BondFixedTransaction; import com.opengamma.analytics.financial.interestrate.bond.provider.BondSecurityDiscountingMethod; import com.opengamma.analytics.financial.provider.description.interestrate.IssuerProviderInterface; import com.opengamma.util.ArgumentChecker; /** * Calculate convexity from the curves. */ public final class ConvexityFromCurvesCalculator extends InstrumentDerivativeVisitorAdapter<IssuerProviderInterface, Double> { /** * The calculator instance. */ private static final ConvexityFromCurvesCalculator s_instance = new ConvexityFromCurvesCalculator(); /** * Return the calculator instance. * @return The instance. */ public static ConvexityFromCurvesCalculator getInstance() { return s_instance; } /** * Private constructor. */ private ConvexityFromCurvesCalculator() { } /** The method used for bonds */ private static final BondSecurityDiscountingMethod METHOD_BOND_SECURITY = BondSecurityDiscountingMethod.getInstance(); @Override public Double visitBondFixedSecurity(final BondFixedSecurity bond, final IssuerProviderInterface issuer) { ArgumentChecker.notNull(bond, "bond"); ArgumentChecker.notNull(issuer, "Issuer provider"); return METHOD_BOND_SECURITY.convexityFromCurves(bond, issuer) / 100; } @Override public Double visitBondFixedTransaction(final BondFixedTransaction bond, final IssuerProviderInterface issuer) { ArgumentChecker.notNull(bond, "bond"); ArgumentChecker.notNull(issuer, "Issuer provider"); return METHOD_BOND_SECURITY.convexityFromCurves(bond.getBondTransaction(), issuer) / 100; } }