net.finmath.montecarlo.hybridassetinterestrate.HybridAssetLIBORModelMonteCarloSimulationFromModels 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 03.04.2015
*/
package net.finmath.montecarlo.hybridassetinterestrate;
import java.time.LocalDateTime;
import java.util.Map;
import net.finmath.exception.CalculationException;
import net.finmath.marketdata.model.curves.DiscountCurve;
import net.finmath.montecarlo.BrownianMotion;
import net.finmath.montecarlo.assetderivativevaluation.AssetModelMonteCarloSimulationModel;
import net.finmath.montecarlo.interestrate.LIBORModelMonteCarloSimulationModel;
import net.finmath.montecarlo.interestrate.TermStructureModel;
import net.finmath.montecarlo.process.MonteCarloProcess;
import net.finmath.stochastic.RandomVariable;
import net.finmath.time.TimeDiscretization;
/**
* An Equity Hybrid LIBOR Market Model composed of an object implementing
* LIBORModelMonteCarloSimulationModel
providing the interest
* rate simulation and the numeraire and an object implementing
* AssetModelMonteCarloSimulationModel
providing the
* asset simulation.
*
* The interest rate model needs to be in spot measure.
*
* @author Christian Fries
* @version 1.0
*/
public class HybridAssetLIBORModelMonteCarloSimulationFromModels implements HybridAssetLIBORModelMonteCarloSimulation {
private LIBORModelMonteCarloSimulationModel liborSimulation;
private AssetModelMonteCarloSimulationModel assetSimulation;
private DiscountCurve discountCurve;
/**
* Create an Equity Hybrid LIBOR Market Model composed of an object implementing
* LIBORModelMonteCarloSimulationModel
providing the interest
* rate simulation and the numeraire and an object implementing
* AssetModelMonteCarloSimulationModel
providing the
* asset simulation.
*
* The interest rate model needs to be in spot measure.
*
* @param liborSimulation An object implementing LIBORModelMonteCarloSimulationModel
providing the interest rate simulation and the numeraire.
* @param assetSimulation An object implementing AssetModelMonteCarloSimulationModel
providing the asset simulation.
* @param discountCurve An optional object implementing DiscountCurveInterface
to adjust the numeraire for a deterministic discounting spread.
*/
public HybridAssetLIBORModelMonteCarloSimulationFromModels(
LIBORModelMonteCarloSimulationModel liborSimulation,
AssetModelMonteCarloSimulationModel assetSimulation,
DiscountCurve discountCurve) {
super();
this.liborSimulation = liborSimulation;
this.assetSimulation = assetSimulation;
this.discountCurve = discountCurve;
if(!liborSimulation.getTimeDiscretization().equals(assetSimulation.getTimeDiscretization())) {
throw new IllegalArgumentException("The interest rate simulation and the asset simulation need to share the same simulation time discretization.");
}
}
public HybridAssetLIBORModelMonteCarloSimulationFromModels(
LIBORModelMonteCarloSimulationModel liborSimulation,
AssetModelMonteCarloSimulationModel assetSimulation) {
this(liborSimulation, assetSimulation, null);
}
@Override
public int getNumberOfPaths() {
return liborSimulation.getNumberOfPaths();
}
@Override
public LocalDateTime getReferenceDate() {
return liborSimulation.getReferenceDate();
}
@Override
public TimeDiscretization getTimeDiscretization() {
return liborSimulation.getTimeDiscretization();
}
@Override
public int getNumberOfFactors() {
return liborSimulation.getNumberOfFactors();
}
@Override
public double getTime(int timeIndex) {
return liborSimulation.getTime(timeIndex);
}
@Override
public TimeDiscretization getLiborPeriodDiscretization() {
return liborSimulation.getLiborPeriodDiscretization();
}
@Override
public int getTimeIndex(double time) {
return liborSimulation.getTimeIndex(time);
}
@Override
public int getNumberOfLibors() {
return liborSimulation.getNumberOfLibors();
}
@Override
public RandomVariable getRandomVariableForConstant(double value) {
return liborSimulation.getRandomVariableForConstant(value);
}
@Override
public double getLiborPeriod(int timeIndex) {
return liborSimulation.getLiborPeriod(timeIndex);
}
@Override
public int getLiborPeriodIndex(double time) {
return liborSimulation.getLiborPeriodIndex(time);
}
@Override
public RandomVariable getMonteCarloWeights(int timeIndex) throws CalculationException {
return liborSimulation.getMonteCarloWeights(timeIndex);
}
@Override
public RandomVariable getLIBOR(int timeIndex, int liborIndex) throws CalculationException {
return liborSimulation.getLIBOR(timeIndex, liborIndex);
}
@Override
public RandomVariable getMonteCarloWeights(double time) throws CalculationException {
return liborSimulation.getMonteCarloWeights(time);
}
@Override
public RandomVariable getLIBOR(double time, double periodStart, double periodEnd) throws CalculationException {
return liborSimulation.getLIBOR(time, periodStart, periodEnd);
}
@Override
public HybridAssetLIBORModelMonteCarloSimulationFromModels getCloneWithModifiedData( Map dataModified) {
return null;
}
@Override
public RandomVariable[] getLIBORs(int timeIndex) throws CalculationException {
return liborSimulation.getLIBORs(timeIndex);
}
@Override
public RandomVariable getNumeraire(double time) throws CalculationException {
RandomVariable numeraire = liborSimulation.getNumeraire(time);
if(discountCurve != null) {
// This includes a control for zero bonds
double deterministicNumeraireAdjustment = numeraire.invert().getAverage() / discountCurve.getDiscountFactor(time);
numeraire = numeraire.mult(deterministicNumeraireAdjustment);
}
return numeraire;
}
@Override
public RandomVariable getNumeraire(int timeIndex) throws CalculationException {
return getNumeraire(getTime(timeIndex));
}
@Override
public BrownianMotion getBrownianMotion() {
return liborSimulation.getBrownianMotion();
}
@Override
public TermStructureModel getModel() {
return liborSimulation.getModel();
}
@Override
public MonteCarloProcess getProcess() {
return liborSimulation.getProcess();
}
/**
* @deprecated
* @see net.finmath.montecarlo.interestrate.LIBORModelMonteCarloSimulationModel#getCloneWithModifiedSeed(int)
*/
@Override
@Deprecated
public HybridAssetLIBORModelMonteCarloSimulationFromModels getCloneWithModifiedSeed(int seed) {
return null;
}
@Override
public int getNumberOfAssets() {
return assetSimulation.getNumberOfAssets();
}
@Override
public RandomVariable getAssetValue(int timeIndex, int assetIndex) throws CalculationException {
return assetSimulation.getAssetValue(timeIndex, assetIndex).mult(liborSimulation.getNumeraire(getTime(timeIndex))).div(assetSimulation.getNumeraire(timeIndex));
}
@Override
public RandomVariable getAssetValue(double time, int assetIndex) throws CalculationException {
int timeIndex = getTimeIndex(time);
// We round to the previous stock vaue (may generate loss of volatility and inconsistent forwards).
if(timeIndex < 0) {
timeIndex = -timeIndex-2;
}
return getAssetValue(timeIndex, assetIndex);
}
@Override
public Map getModelParameters() {
// TODO Add implementation
throw new UnsupportedOperationException();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy