net.finmath.equities.models.FlatVolatilitySurface 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.
The newest version!
package net.finmath.equities.models;
import java.time.LocalDate;
import java.util.ArrayList;
import net.finmath.equities.marketdata.VolatilityPoint;
/**
* This class implements the volatility interfaces for a flat volatility surface.
*
* @author Andreas Grotz
*/
public class FlatVolatilitySurface implements VolatilitySurface, ShiftedVolatilitySurface {
private final double volatility;
private final double volShift;
public FlatVolatilitySurface(double volatility) {
this(volatility, 0.0);
}
public FlatVolatilitySurface(double volatility, double volShift) {
this.volatility = volatility;
this.volShift = volShift;
}
@Override
public ShiftedVolatilitySurface getShiftedSurface(double shift) {
assert volShift == 0.0 : "Surface is already shifted";
return new FlatVolatilitySurface(this.volatility, shift);
}
public double getShift() {
return volShift;
}
@Override
public double getVolatility(
double strike,
LocalDate expiryDate,
EquityForwardStructure currentForwardStructure)
{
return volatility + volShift;
}
@Override
public double getVolatility(double strike, double timeToMaturity, EquityForwardStructure currentForwardStructure) {
return volatility + volShift;
}
@Override
public double getLocalVolatility(
double strike,
LocalDate expiryDate,
EquityForwardStructure currentForwardStructure,
double strikeShift,
double timeShift)
{
return volatility + volShift;
}
@Override
public double getLocalVolatility(
double logStrike,
double timeToMaturity,
EquityForwardStructure currentForwardStructure,
double strikeShift,
double timeShift)
{
return volatility + volShift;
}
public void calibrate(
EquityForwardStructure forwardStructure,
ArrayList volaPoints)
{
assert false : "A flat surface cannot be calibrated";
}
}