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

net.finmath.singleswaprate.model.AnalyticModelWithVolatilityCubes Maven / Gradle / Ivy

package net.finmath.singleswaprate.model;

import java.time.LocalDate;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

import net.finmath.marketdata.model.AnalyticModelFromCurvesAndVols;
import net.finmath.marketdata.model.curves.Curve;
import net.finmath.marketdata.model.volatilities.VolatilitySurface;
import net.finmath.singleswaprate.model.volatilities.VolatilityCube;

/**
 * Implementation of {@link net.finmath.singleswaprate.model.VolatilityCubeModel} based on {@link net.finmath.marketdata.model.AnalyticModelFromCurvesAndVols}.
 *
 * @author Christian Fries
 * @author Roland Bachl
 *
 */
public class AnalyticModelWithVolatilityCubes extends AnalyticModelFromCurvesAndVols implements VolatilityCubeModel, Cloneable {

	/**
	 *
	 */
	private static final long serialVersionUID = 5548526355763266102L;
	private final Map volatilityCubeMap = new HashMap<>();

	/**
	 * Create an empty analytic model.
	 */
	public AnalyticModelWithVolatilityCubes() {
		super();
	}

	/**
	 * Create an empty analytic model for a specified date.
	 *
	 * @param referenceDate The reference date the curves of this model should match.
	 */
	public AnalyticModelWithVolatilityCubes(LocalDate referenceDate) {
		super(referenceDate);
	}

	/**
	 * Create an analytic model for the specified reference date, together with curves as well as volatility surfaces and cubes, each with their specific name.
	 *
	 * @param referenceDate The reference date that should be used for all curves and surfaces of this model.
	 * @param curvesMap A map containing all curves, together with their names they should have in the model.
	 * @param volatilitySurfaceMap A map containing all volatility surfaces, together with their names they should have in the model.
	 * @param volatilityCubeMap A map containing all volatility cubes, together with their names they should have in the model.
	 */
	public AnalyticModelWithVolatilityCubes(LocalDate referenceDate, Map curvesMap, Map volatilitySurfaceMap,
			Map volatilityCubeMap) {
		super(referenceDate, curvesMap, volatilitySurfaceMap);
		this.volatilityCubeMap.putAll(volatilityCubeMap);
	}

	@Override
	public VolatilityCube getVolatilityCube(String name){
		return volatilityCubeMap.get(name);
	}

	@Override
	public VolatilityCubeModel  addVolatilityCube(VolatilityCube volatilityCube){

		LocalDate cubeDate = volatilityCube.getReferenceDate();

		if(getReferenceDate() != null && cubeDate != null && ! getReferenceDate().equals(cubeDate)) {
			throw new IllegalArgumentException("Reference date of curve does not match reference date of model.");
		}

		AnalyticModelWithVolatilityCubes newModel = clone();
		newModel.volatilityCubeMap.put(volatilityCube.getName(), volatilityCube);

		return newModel;
	}

	@Override
	public VolatilityCubeModel  addVolatilityCube(String volatilityCubeName, VolatilityCube volatilityCube){

		LocalDate cubeDate = volatilityCube.getReferenceDate();

		if(getReferenceDate() != null && cubeDate != null && ! getReferenceDate().equals(cubeDate)) {
			throw new IllegalArgumentException("Reference date of curve does not match reference date of model.");
		}

		AnalyticModelWithVolatilityCubes newModel = clone();
		newModel.volatilityCubeMap.put(volatilityCubeName, volatilityCube);

		return newModel;
	}

	@Override
	public AnalyticModelWithVolatilityCubes clone() {
		return new AnalyticModelWithVolatilityCubes(getReferenceDate(), getCurves(), getVolatilitySurfaces(), getVolatilityCubes());
	}

	@Override
	public String toString() {
		return "EnhancedAnalyticModel: curves=" + getCurves().keySet() + ", volatilitySurfaces=" + getVolatilitySurfaces().keySet() +
				", volatilityCubes=" + volatilityCubeMap.keySet();
	}

	@Override
	public Set getVolatilityCubeNames() {
		return new HashSet<>(volatilityCubeMap.keySet());
	}

	@Override
	public Map getVolatilityCubes() {
		return Collections.unmodifiableMap(volatilityCubeMap);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy