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

net.finmath.montecarlo.interestrate.models.covariance.ShortRateVolatilityModel Maven / Gradle / Ivy

/*
 * (c) Copyright Christian P. Fries, Germany. Contact: [email protected].
 *
 * Created on 24.01.2016
 */

package net.finmath.montecarlo.interestrate.models.covariance;

import java.io.Serializable;

import net.finmath.stochastic.RandomVariable;
import net.finmath.time.TimeDiscretization;

/**
 * Interface for piecewise constant short rate volatility models with
 * piecewise constant instantaneous short rate volatility \( t \mapsto \sigma(t) \)
 * and piecewise constant short rate mean reversion speed \( t \mapsto a(t) \).
 *
 * @author Christian Fries
 * @version 1.0
 */
public interface ShortRateVolatilityModel extends Serializable {

	/**
	 * Returns the time discretization \( \{ t_{i} \} \) associated
	 * with the piecewise constant functions.
	 *
	 * @return the time discretization \( \{ t_{i} \} \)
	 */
	TimeDiscretization getTimeDiscretization();

	/**
	 * Returns the value of \( \sigma(t) \) for \( t_{i} \leq t < t_{i+1} \).
	 *
	 * @param timeIndex The index \( i \).
	 * @return the value of \( \sigma(t) \) for \( t_{i} \leq t < t_{i+1} \)
	 */
	RandomVariable getVolatility(int timeIndex);

	/**
	 * Returns the value of \( a(t) \) for \( t_{i} \leq t < t_{i+1} \).
	 *
	 * @param timeIndex The index \( i \).
	 * @return the value of \( a(t) \) for \( t_{i} \leq t < t_{i+1} \)
	 */
	RandomVariable getMeanReversion(int timeIndex);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy