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

net.finmath.montecarlo.interestrate.modelplugins.LIBORCovarianceModelFromVolatilityAndCorrelation Maven / Gradle / Ivy

/*
 * (c) Copyright Christian P. Fries, Germany. All rights reserved. Contact: [email protected].
 *
 * Created on 15.12.2007
 */
package net.finmath.montecarlo.interestrate.modelplugins;

import java.util.Arrays;

import net.finmath.montecarlo.RandomVariable;
import net.finmath.stochastic.RandomVariableInterface;
import net.finmath.time.TimeDiscretizationInterface;

/**
 * A covariance model build from a volatility model implementing
 * LIBORVolatilityModel and a correlation model
 * implementing LIBORCorrelationModel.
 * 
 * 

* The model parameters are given by the concatenation of the * parameters of the LIBORVolatilityModel and * the parameters of the LIBORCorrelationModel, * in this ordering *

* * @author Christian Fries */ public class LIBORCovarianceModelFromVolatilityAndCorrelation extends AbstractLIBORCovarianceModelParametric { private final LIBORVolatilityModel volatilityModel; private final LIBORCorrelationModel correlationModel; public LIBORCovarianceModelFromVolatilityAndCorrelation(TimeDiscretizationInterface timeDiscretization, TimeDiscretizationInterface liborPeriodDiscretization, LIBORVolatilityModel volatilityModel, LIBORCorrelationModel correlationModel) { super(timeDiscretization, liborPeriodDiscretization, correlationModel.getNumberOfFactors()); this.volatilityModel = volatilityModel; this.correlationModel = correlationModel; } @Override public RandomVariableInterface[] getFactorLoading(int timeIndex, int component, RandomVariableInterface[] realizationAtTimeIndex) { RandomVariableInterface[] factorLoading = new RandomVariableInterface[correlationModel.getNumberOfFactors()]; RandomVariableInterface volatility = volatilityModel.getVolatility(timeIndex, component); for (int factorIndex = 0; factorIndex < factorLoading.length; factorIndex++) { factorLoading[factorIndex] = volatility.mult(correlationModel.getFactorLoading(timeIndex, factorIndex, component)); } return factorLoading; } @Override public RandomVariableInterface getFactorLoadingPseudoInverse(int timeIndex, int component, int factor, RandomVariableInterface[] realizationAtTimeIndex) { // Note that we assume that the correlation model getFactorLoading gives orthonormal vectors RandomVariableInterface factorLoadingPseudoInverse = volatilityModel.getVolatility(timeIndex, component).invert() .mult(correlationModel.getFactorLoading(timeIndex, factor, component)); // @todo numberOfComponents should be stored as a member?! int numberOfComponents = getLiborPeriodDiscretization().getNumberOfTimeSteps(); double factorWeight = 0.0; for(int componentIndex=0; componentIndex




© 2015 - 2025 Weber Informatics LLC | Privacy Policy