net.finmath.marketdata.model.AnalyticModelInterface Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of finmath-lib Show documentation
Show all versions of finmath-lib Show documentation
finmath lib is a Mathematical Finance Library in Java.
It provides algorithms and methodologies related to mathematical finance.
/*
* (c) Copyright Christian P. Fries, Germany. Contact: [email protected].
*
* Created on 28.11.2012
*/
package net.finmath.marketdata.model;
import java.util.Map;
import java.util.Set;
import net.finmath.marketdata.calibration.ParameterObjectInterface;
import net.finmath.marketdata.model.curves.CurveInterface;
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;
import net.finmath.modelling.Model;
/**
* A collection of objects representing analytic valuations, i.e., curves and volatility surfaces.
*
* @author Christian Fries
*/
public interface AnalyticModelInterface extends Model, Cloneable {
/**
* Get a curve by a given curve name.
*
* @param name The name of the curve.
* @return The curve with the corresponding name, given that it is part of this model, otherwise null is return.
*/
CurveInterface getCurve(String name);
/**
* Returns an unmodifiable map of all curves.
*
* @return Map of all curves.
*/
Map getCurves();
/**
* Add a reference to a given curve under a given name to this model. It is not necessary that the name given agrees with
* curve.getName()
. This method comes in handy, if you like to create curve mappings.
*
* @param name Name under which the curve is known in the model.
* @param curve The curve.
* @return A clone of this model, containing the curves of this model which are not known under the given name and the new curve under the given name.
*/
AnalyticModelInterface addCurve(String name, CurveInterface curve);
/**
* Create a new analytic model consisting of a clone of this one together with the given curves added.
*
* @param curves The set of curves to add.
* @return A new analytic model.
*/
AnalyticModelInterface addCurves(CurveInterface... curves);
/**
* Create a new analytic model consisting of a clone of this one together with the given curves added.
*
* @param curves The list of curves to add.
* @return A new analytic model.
*/
AnalyticModelInterface addCurves(Set curves);
@Deprecated
void setCurve(CurveInterface curve);
/**
* Returns a discount curve for a given name.
*
* @param discountCurveName The name of the requested curve.
* @return discount curve corresponding to discountCurveName or null if no discountCurve with this name exists in the model
*/
DiscountCurveInterface getDiscountCurve(String discountCurveName);
/**
* Returns a forward curve for a given name.
*
* @param forwardCurveName The name of the requested curve.
* @return forward curve corresponding to forwardCurveName or null if no forwardCurve with this name exists in the model
*/
ForwardCurveInterface getForwardCurve(String forwardCurveName);
VolatilitySurfaceInterface getVolatilitySurface(String name);
AnalyticModelInterface addVolatilitySurfaces(VolatilitySurfaceInterface... volatilitySurfaces);
/**
* Create a new analytic model consisting of a clone of this one together with the given volatility surfaces added.
*
* @param volatilitySurfaces The list of volatility surfaces to add.
* @return A new analytic model.
*/
AnalyticModelInterface addVolatilitySurfaces(Set volatilitySurfaces);
@Deprecated
void setVolatilitySurface(VolatilitySurfaceInterface volatilitySurface);
AnalyticModelInterface clone();
AnalyticModelInterface getCloneForParameter(Map curvesParameterPairs) throws CloneNotSupportedException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy