net.finmath.climate.models.dice.submodels.ForcingFunction Maven / Gradle / Ivy
package net.finmath.climate.models.dice.submodels;
import java.util.function.BiFunction;
/**
* The function that maps CarbonConcentration (in GtC) and external forcing (in W/m^2) to forcing (in W/m^2).
*
* @author Christian Fries
*/
public class ForcingFunction implements BiFunction {
// Parameters of the orignal model
private final double carbonConcentrationBase = 588;
private final double forcingPerCarbonDoubling = 3.6813;
@Override
public Double apply(CarbonConcentration3DScalar carbonConcentration, Double forcingExternal) {
return forcingPerCarbonDoubling * Math.log(carbonConcentration.getExpectedCarbonConcentrationInAtmosphere() / carbonConcentrationBase ) / Math.log(2) + forcingExternal;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy