net.finmath.climate.models.dice.submodels.EvolutionOfCapital Maven / Gradle / Ivy
package net.finmath.climate.models.dice.submodels;
import java.util.function.BiFunction;
import java.util.function.Function;
import net.finmath.time.TimeDiscretization;
/**
* the evolution of the capital (economy)
* \(
* K(t_{i+1}) = (1-delta) K(t_{i}) + investment
* \)
*
* @author Christian Fries
*/
public class EvolutionOfCapital implements Function> {
private final TimeDiscretization timeDiscretization;
private final double capitalDeprecation;
public EvolutionOfCapital(TimeDiscretization timeDiscretization, double capitalDeprecation) {
super();
this.timeDiscretization = timeDiscretization;
this.capitalDeprecation = capitalDeprecation;
}
public EvolutionOfCapital(TimeDiscretization timeDiscretization) {
// capital deprecation per 1 year
this(timeDiscretization, -Math.log(1-0.1));
}
@Override
public BiFunction apply(Integer timeIndex) {
double timeStep = timeDiscretization.getTimeStep(timeIndex);
return (Double capital, Double investment) -> capital * Math.exp(-capitalDeprecation * timeStep) + investment * timeStep;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy