/** * Copyright (C) 2013 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.financial.analytics.model.equity.option; import java.util.Collections; import java.util.Set; import com.opengamma.OpenGammaRuntimeException; import com.opengamma.analytics.financial.equity.StaticReplicationDataBundle; import com.opengamma.analytics.financial.interestrate.InstrumentDerivative; import com.opengamma.analytics.financial.riskfactor.ValueVegaCalculator; import com.opengamma.engine.ComputationTarget; import com.opengamma.engine.ComputationTargetSpecification; import com.opengamma.engine.function.FunctionCompilationContext; import com.opengamma.engine.function.FunctionInputs; import com.opengamma.engine.value.ComputedValue; import com.opengamma.engine.value.ValueProperties; import com.opengamma.engine.value.ValuePropertyNames; import com.opengamma.engine.value.ValueRequirement; import com.opengamma.engine.value.ValueRequirementNames; import com.opengamma.engine.value.ValueSpecification; /** * Calculates the value vega of an equity index or equity option using the Black vega. */ public class EquityOptionBlackValueVegaFunction extends EquityOptionBlackFunction { /** Value vega calculator */ private static final ValueVegaCalculator CALCULATOR = ValueVegaCalculator.getInstance(); /** * Sets the value requirement name to {@link ValueRequirementNames#VALUE_VEGA} */ public EquityOptionBlackValueVegaFunction() { super(ValueRequirementNames.VALUE_VEGA); } @Override protected Set<ComputedValue> computeValues(final InstrumentDerivative derivative, final StaticReplicationDataBundle market, final FunctionInputs inputs, final Set<ValueRequirement> desiredValues, final ComputationTargetSpecification targetSpec, final ValueProperties resultProperties) { final ValueSpecification resultSpec = new ValueSpecification(getValueRequirementNames()[0], targetSpec, resultProperties); final Object vegaObject = inputs.getValue(ValueRequirementNames.VEGA); if (vegaObject == null) { throw new OpenGammaRuntimeException("Could not get vega"); } final double vega = (Double) vegaObject; final double valueVega = CALCULATOR.valueGreek(derivative, market, vega); return Collections.singleton(new ComputedValue(resultSpec, valueVega)); } @Override public Set<ValueRequirement> getRequirements(final FunctionCompilationContext context, final ComputationTarget target, final ValueRequirement desiredValue) { final Set<ValueRequirement> requirements = super.getRequirements(context, target, desiredValue); if (requirements == null) { return null; } final ValueProperties properties = desiredValue.getConstraints().copy() .withoutAny(ValuePropertyNames.CURRENCY) .get(); requirements.add(new ValueRequirement(ValueRequirementNames.VEGA, target.toSpecification(), properties)); return requirements; } }