net.finmath.montecarlo.interestrate.models.covariance.LIBORVolatilityModelPiecewiseConstant 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 08.08.2005
*/
package net.finmath.montecarlo.interestrate.models.covariance;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import net.finmath.montecarlo.AbstractRandomVariableFactory;
import net.finmath.montecarlo.RandomVariableFactory;
import net.finmath.stochastic.RandomVariable;
import net.finmath.stochastic.Scalar;
import net.finmath.time.TimeDiscretization;
/**
* @author Christian Fries
* @version 1.0
*/
public class LIBORVolatilityModelPiecewiseConstant extends LIBORVolatilityModel {
private static final long serialVersionUID = 3258093488453501312L;
private final AbstractRandomVariableFactory randomVariableFactory;
private final TimeDiscretization simulationTimeDiscretization;
private final TimeDiscretization timeToMaturityDiscretization;
private Map> indexMap = new ConcurrentHashMap<>();
private RandomVariable[] volatility;
private final boolean isCalibrateable;
public LIBORVolatilityModelPiecewiseConstant(TimeDiscretization timeDiscretization, TimeDiscretization liborPeriodDiscretization, TimeDiscretization simulationTimeDiscretization, TimeDiscretization timeToMaturityDiscretization, RandomVariable[] volatility, boolean isCalibrateable) {
super(timeDiscretization, liborPeriodDiscretization);
this.randomVariableFactory = null;
/*
* Build index map
*/
double maxMaturity = liborPeriodDiscretization.getTime(liborPeriodDiscretization.getNumberOfTimes()-1);
int volatilityIndex = 0;
for(int simulationTime=0; simulationTime timeToMaturityIndexing = new HashMap<>();
for(int timeToMaturity=0; timeToMaturity maxMaturity) {
continue;
}
timeToMaturityIndexing.put(timeToMaturity,volatilityIndex++);
}
indexMap.put(simulationTime, timeToMaturityIndexing);
}
if(volatility.length == 1) {
this.volatility = new RandomVariable[volatilityIndex];
Arrays.fill(this.volatility, volatility[0]);
}
else if(volatility.length == volatilityIndex) {
this.volatility = volatility.clone();
}
else {
throw new IllegalArgumentException("Volatility length does not match number of free parameters.");
}
if(volatilityIndex != this.volatility.length) {
throw new IllegalArgumentException("volatility.length should equal simulationTimeDiscretization.getNumberOfTimes()*timeToMaturityDiscretization.getNumberOfTimes().");
}
this.simulationTimeDiscretization = simulationTimeDiscretization;
this.timeToMaturityDiscretization = timeToMaturityDiscretization;
this.isCalibrateable = isCalibrateable;
}
public LIBORVolatilityModelPiecewiseConstant(AbstractRandomVariableFactory randomVariableFactory, TimeDiscretization timeDiscretization, TimeDiscretization liborPeriodDiscretization, TimeDiscretization simulationTimeDiscretization, TimeDiscretization timeToMaturityDiscretization, double[][] volatility, boolean isCalibrateable) {
super(timeDiscretization, liborPeriodDiscretization);
this.randomVariableFactory = randomVariableFactory;
/*
* Build index map
*/
double maxMaturity = timeToMaturityDiscretization.getTime(timeToMaturityDiscretization.getNumberOfTimes()-1);
int volatilityIndex = 0;
for(int simulationTime=0; simulationTime timeToMaturityIndexing = new ConcurrentHashMap<>();
for(int timeToMaturity=0; timeToMaturity maxMaturity) {
continue;
}
timeToMaturityIndexing.put(timeToMaturity,volatilityIndex++);
}
indexMap.put(simulationTime, timeToMaturityIndexing);
}
// Flatten parameter matrix
this.volatility = new RandomVariable[volatilityIndex];
for(Integer simulationTime : indexMap.keySet()) {
for(Integer timeToMaturity : indexMap.get(simulationTime).keySet()) {
this.volatility[indexMap.get(simulationTime).get(timeToMaturity)] = randomVariableFactory.createRandomVariable(volatility[simulationTime][timeToMaturity]);
}
}
this.simulationTimeDiscretization = simulationTimeDiscretization;
this.timeToMaturityDiscretization = timeToMaturityDiscretization;
this.isCalibrateable = isCalibrateable;
}
public LIBORVolatilityModelPiecewiseConstant(AbstractRandomVariableFactory randomVariableFactory, TimeDiscretization timeDiscretization, TimeDiscretization liborPeriodDiscretization, TimeDiscretization simulationTimeDiscretization, TimeDiscretization timeToMaturityDiscretization, double[] volatility, boolean isCalibrateable) {
super(timeDiscretization, liborPeriodDiscretization);
this.randomVariableFactory = randomVariableFactory;
/*
* Build index map
*/
double maxMaturity = liborPeriodDiscretization.getTime(liborPeriodDiscretization.getNumberOfTimes()-1);
int volatilityIndex = 0;
for(int simulationTime=0; simulationTime timeToMaturityIndexing = new HashMap<>();
for(int timeToMaturity=0; timeToMaturity maxMaturity) {
continue;
}
timeToMaturityIndexing.put(timeToMaturity,volatilityIndex++);
}
indexMap.put(simulationTime, timeToMaturityIndexing);
}
if(volatility.length == 1) {
this.volatility = new RandomVariable[volatilityIndex];
Arrays.fill(this.volatility, randomVariableFactory.createRandomVariable(volatility[0]));
}
else if(volatility.length == volatilityIndex) {
this.volatility = new RandomVariable[volatilityIndex];
for(int i=0; i= simulationTimeDiscretization.getNumberOfTimes()) {
timeIndexSimulationTime--;
}
int timeIndexTimeToMaturity = timeToMaturityDiscretization.getTimeIndexNearestLessOrEqual(timeToMaturity);
if(timeIndexTimeToMaturity < 0) {
timeIndexTimeToMaturity = 0;
}
if(timeIndexTimeToMaturity >= timeToMaturityDiscretization.getNumberOfTimes()) {
timeIndexTimeToMaturity--;
}
return volatility[indexMap.get(timeIndexSimulationTime).get(timeIndexTimeToMaturity)];
}
}
@Override
public Object clone() {
return new LIBORVolatilityModelPiecewiseConstant(
super.getTimeDiscretization(),
super.getLiborPeriodDiscretization(),
this.simulationTimeDiscretization,
this.timeToMaturityDiscretization,
this.volatility.clone(),
this.isCalibrateable
);
}
/**
* @return the simulationTimeDiscretization
*/
public TimeDiscretization getSimulationTimeDiscretization() {
return simulationTimeDiscretization;
}
/**
* @return the timeToMaturityDiscretization
*/
public TimeDiscretization getTimeToMaturityDiscretization() {
return timeToMaturityDiscretization;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy