net.finmath.marketdata.model.AnalyticModel Maven / Gradle / Ivy
/*
* (c) Copyright Christian P. Fries, Germany. All rights reserved. Contact: [email protected].
*
* Created on 28.11.2012
*/
package net.finmath.marketdata.model;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import net.finmath.marketdata.calibration.ParameterObjectInterface;
import net.finmath.marketdata.model.curves.CurveInterface;
import net.finmath.marketdata.model.curves.DiscountCurveFromForwardCurve;
import net.finmath.marketdata.model.curves.DiscountCurveInterface;
import net.finmath.marketdata.model.curves.ForwardCurveInterface;
import net.finmath.marketdata.model.volatilities.AbstractVolatilitySurface;
import net.finmath.marketdata.model.volatilities.VolatilitySurfaceInterface;
/**
* Implements a collection of market data objects (e.g., discount curves, forward curve)
* which provide interpolation of market data or other derived quantities
* ("calibrated curves"). This can be seen as a model to be used in analytic pricing
* formulas - hence this class is termed AnalyticModel
.
*
* @author Christian Fries
*/
public class AnalyticModel implements AnalyticModelInterface, Cloneable {
private final Map curvesMap = new HashMap();
private final Map volatilitySufaceMap = new HashMap();
/**
* Create an empty analytic model.
*/
public AnalyticModel() {
}
/**
* Create an analytic model with the given curves.
*
* @param curves The vector of curves.
*/
public AnalyticModel(CurveInterface[] curves) {
for (CurveInterface curve : curves) curvesMap.put(curve.getName(), curve);
}
/**
* Create an analytic model with the given curves.
*
* @param curves A collection of curves.
*/
public AnalyticModel(Collection curves) {
for(CurveInterface curve : curves) curvesMap.put(curve.getName(), curve);
}
/* (non-Javadoc)
* @see net.finmath.marketdata.model.AnalyticModelInterface#getCurve(java.lang.String)
*/
@Override
public CurveInterface getCurve(String name)
{
return curvesMap.get(name);
}
public AnalyticModelInterface addCurve(String name, CurveInterface curve) {
AnalyticModel newModel = clone();
newModel.curvesMap.put(name, curve);
return newModel;
}
public AnalyticModelInterface addCurve(CurveInterface curve) {
AnalyticModel newModel = clone();
newModel.curvesMap.put(curve.getName(), curve);
return newModel;
}
@Override
public AnalyticModelInterface addCurves(CurveInterface... curves) {
AnalyticModel newModel = clone();
for(CurveInterface curve : curves) newModel.curvesMap.put(curve.getName(), curve);
return newModel;
}
@Override
public AnalyticModelInterface addCurves(Set curves) {
AnalyticModel newModel = clone();
for(CurveInterface curve : curves) newModel.curvesMap.put(curve.getName(), curve);
return newModel;
}
/**
* @deprecated This class will become immutable. Use addCurve instead.
*/
@Override
@Deprecated
public void setCurve(CurveInterface curve)
{
curvesMap.put(curve.getName(), curve);
}
/**
* Set some curves.
*
* @param curves Array of curves to set.
* @deprecated This class will become immutable. Use addCurve instead.
*/
@Deprecated
public void setCurves(CurveInterface[] curves) {
for(CurveInterface curve : curves) setCurve(curve);
}
@Override
public DiscountCurveInterface getDiscountCurve(String discountCurveName) {
DiscountCurveInterface discountCurve = null;
CurveInterface curveForDiscountingCurve = getCurve(discountCurveName);
if(DiscountCurveInterface.class.isInstance(curveForDiscountingCurve)) {
discountCurve = (DiscountCurveInterface)curveForDiscountingCurve;
}
else if(ForwardCurveInterface.class.isInstance(curveForDiscountingCurve)) {
// Check if the discount curve is a forward curve
ForwardCurveInterface forwardCurveForDiscounting = (ForwardCurveInterface) curveForDiscountingCurve;
discountCurve = new DiscountCurveFromForwardCurve(forwardCurveForDiscounting.getName());
}
return discountCurve;
}
@Override
public ForwardCurveInterface getForwardCurve(String forwardCurveName) {
ForwardCurveInterface forwardCurve = null;
CurveInterface curveForForwards = getCurve(forwardCurveName);
if(ForwardCurveInterface.class.isInstance(curveForForwards)) {
forwardCurve = (ForwardCurveInterface)curveForForwards;
}
return forwardCurve;
}
@Override
public VolatilitySurfaceInterface getVolatilitySurface(String name) {
return volatilitySufaceMap.get(name);
}
public AnalyticModelInterface addVolatilitySurface(VolatilitySurfaceInterface volatilitySurface)
{
AnalyticModel newModel = clone();
newModel.volatilitySufaceMap.put(volatilitySurface.getName(), volatilitySurface);
return newModel;
}
@Override
public AnalyticModelInterface addVolatilitySurfaces(VolatilitySurfaceInterface... volatilitySurfaces)
{
AnalyticModel newModel = clone();
for(VolatilitySurfaceInterface volatilitySurface : volatilitySurfaces) newModel.volatilitySufaceMap.put(volatilitySurface.getName(), volatilitySurface);
return newModel;
}
@Override
public AnalyticModelInterface addVolatilitySurfaces(Set volatilitySurfaces) {
AnalyticModel newModel = clone();
for(VolatilitySurfaceInterface volatilitySurface : volatilitySurfaces) newModel.volatilitySufaceMap.put(volatilitySurface.getName(), volatilitySurface);
return newModel;
}
/**
* @deprecated This class will become immutable. Use addVolatilitySurface instead.
*/
@Override
@Deprecated
public void setVolatilitySurface(VolatilitySurfaceInterface volatilitySurface)
{
volatilitySufaceMap.put(volatilitySurface.getName(), volatilitySurface);
}
private void set(Object marketDataObject) {
if(marketDataObject instanceof CurveInterface) setCurve((CurveInterface)marketDataObject);
else if(marketDataObject instanceof VolatilitySurfaceInterface) setVolatilitySurface((VolatilitySurfaceInterface)marketDataObject);
else throw new IllegalArgumentException("Provided object is not of supported type.");
}
@Override
public AnalyticModel clone()
{
AnalyticModel newModel = new AnalyticModel();
newModel.curvesMap.putAll(curvesMap);
newModel.volatilitySufaceMap.putAll(volatilitySufaceMap);
return newModel;
}
@Override
public AnalyticModelInterface getCloneForParameter(Map curveParameterPairs) throws CloneNotSupportedException {
// Build the modified clone of this model
AnalyticModel modelClone = clone();
// Add modified clones of curves to model clone
if(curveParameterPairs != null) {
for(Entry curveParameterPair : curveParameterPairs.entrySet()) {
ParameterObjectInterface newCurve = curveParameterPair.getKey().getCloneForParameter(curveParameterPair.getValue());
modelClone.set(newCurve);
}
}
return modelClone;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy