net.finmath.modelling.descriptor.VarianceGammaModelDescriptor Maven / Gradle / Ivy
package net.finmath.modelling.descriptor;
import java.time.LocalDate;
import net.finmath.marketdata.model.curves.DiscountCurve;
/**
* @author Alessandro Gnoatto
*
* @version 1.0
*/
public class VarianceGammaModelDescriptor implements AssetModelDescriptor {
private final LocalDate referenceDate;
private final Double initialValue;
private final DiscountCurve discountCurveForForwardRate;
private final DiscountCurve discountCurveForDiscountRate;
private final double sigma;
private final double theta;
private final double nu;
/**
* @param referenceDate The date corresponding to the floating point date t=0.
* @param initialValue \( S_{0} \) - spot - initial value of S
* @param discountCurveForForwardRate The curve specifying \( t \mapsto exp(- r^{\text{c}}(t) \cdot t) \) - with \( r^{\text{c}}(t) \) the risk free rate
* @param discountCurveForDiscountRate The curve specifying \( t \mapsto exp(- r^{\text{d}}(t) \cdot t) \) - with \( r^{\text{d}}(t) \) the discount rate
* @param sigma The parameter \( \sigma \).
* @param theta The parameter \( \theta \).
* @param nu The parameter \( \nu \).
*/
public VarianceGammaModelDescriptor(LocalDate referenceDate, Double initialValue,
DiscountCurve discountCurveForForwardRate, DiscountCurve discountCurveForDiscountRate, double sigma,
double theta, double nu) {
super();
this.referenceDate = referenceDate;
this.initialValue = initialValue;
this.discountCurveForForwardRate = discountCurveForForwardRate;
this.discountCurveForDiscountRate = discountCurveForDiscountRate;
this.sigma = sigma;
this.theta = theta;
this.nu = nu;
}
@Override
public Integer version() {
return 1;
}
@Override
public String name() {
return "Single asset Variance Gamma model";
}
/**
* @return the referenceDate
*/
public LocalDate getReferenceDate() {
return referenceDate;
}
/**
* @return the initialValue
*/
public Double getInitialValue() {
return initialValue;
}
/**
* @return the discountCurveForForwardRate
*/
public DiscountCurve getDiscountCurveForForwardRate() {
return discountCurveForForwardRate;
}
/**
* @return the discountCurveForDiscountRate
*/
public DiscountCurve getDiscountCurveForDiscountRate() {
return discountCurveForDiscountRate;
}
/**
* @return the sigma
*/
public double getSigma() {
return sigma;
}
/**
* @return the theta
*/
public double getTheta() {
return theta;
}
/**
* @return the nu
*/
public double getNu() {
return nu;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy