net.finmath.climate.models.dice.submodels.EvolutionOfProductivity 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.climate.models.dice.submodels;
import java.util.function.Function;
import net.finmath.time.TimeDiscretization;
/**
* The evolution of the productivity (economy)
* \(
* A(t_{i+1}) = A(t_{i}) / (1 - ga * \exp(- deltaA * t))
* \)
*
* @author Christian Fries
*/
public class EvolutionOfProductivity implements Function> {
private final TimeDiscretization timeDiscretization;
private final double productivityGrowthRateInitial; // ga: Initial TFP rate
private final double productivityGrowthRateDecayRate; // deltaA: TFP increase rate
/**
* The evolution of the productivity (economy)
* \(
* A(t_{i+1}) = A(t_{i}) / (1 - ga * \exp(- deltaA * t))^{\frac{\delta t}{5}}
* \)
*
* @param timeDiscretization The time discretization.
* @param productivityGrowthRateInitial The initial productivity growth rate ga per 1Y.
* @param productivityGrowthRateDecayRate The productivity growth decay rate per 1Y.
*/
public EvolutionOfProductivity(TimeDiscretization timeDiscretization, double productivityGrowthRateInitial, double productivityGrowthRateDecayRate) {
super();
this.timeDiscretization = timeDiscretization;
this.productivityGrowthRateInitial = productivityGrowthRateInitial;
this.productivityGrowthRateDecayRate = productivityGrowthRateDecayRate;
}
public EvolutionOfProductivity(TimeDiscretization timeDiscretization) {
// Parameters from original model: initial productivity growth 0.076 per 1 year, decaying with 0.005 per 1 year.
this(timeDiscretization, 0.076, 0.005);
}
@Override
public Function apply(Integer timeIndex) {
double time = timeDiscretization.getTime(timeIndex);
double timeStep = timeDiscretization.getTimeStep(timeIndex);
return (Double productivity) -> {
double productivityGrowthRate = productivityGrowthRateInitial * Math.exp(-productivityGrowthRateDecayRate * time);
return productivity / (Math.exp(Math.log(1 - (productivityGrowthRate))*timeStep/5.0));
};
}
}