Class StreamParameterization
Handles configuration of GHG intensity, initial charge, recharge rates, recovery rates, and other stream-specific values.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaccumulateRecharge(EngineNumber population, EngineNumber intensity) Accumulate recharge parameters.voidclearLastSpecifiedValue(String stream) Clear the last specified value in this parameterization.Get the applied recharge amount for cumulative calculations.Get the applied retirement amount for cumulative calculations.Get the energy intensity.Get the greenhouse gas intensity.booleanGet the replacement mode for this step's retire commands.Get the induction rate percentage for recycling.Get the induction rate percentage for recycling for a specific stage.getInitialCharge(String stream) Get the initial charge for a stream.getLastSpecifiedValue(String streamName) Get the last specified value for a stream.Get the recharge base population for cumulative calculations.Get the recharge intensity.Get the recharge population percentage.Get the recovery rate percentage.Get the recovery rate percentage for a specific stage.booleanGet whether retire has been calculated this step.Get the retirement base population for cumulative calculations.Get the retirement rate percentage.Get the yield rate percentage for recycling.Get the yield rate percentage for recycling for a specific stage.booleanhasLastSpecifiedValue(String streamName) Check if a stream has a last specified value.booleanhasStreamBeenEnabled(String streamName) Check if a stream has ever been enabled (set to non-zero value).booleanGet whether recycling has been calculated this step.booleanCheck if sales intent has been freshly set in the current processing cycle.voidmarkStreamAsEnabled(String streamName) Mark a stream as having been enabled (set to non-zero value).voidReset state at the beginning of a timestep.voidSet the applied recharge amount for cumulative calculations.voidSet the applied retirement amount for cumulative calculations.voidsetEnergyIntensity(EngineNumber newValue) Set the energy intensity.voidsetGhgIntensity(EngineNumber newValue) Set the greenhouse gas intensity.voidsetHasReplacementThisStep(boolean value) Set the replacement mode for this step's retire commands.voidsetInductionRate(EngineNumber newValue) Set the induction rate percentage for recycling.voidsetInductionRate(EngineNumber newValue, RecoverOperation.RecoveryStage stage) Set the induction rate percentage for recycling for a specific stage.voidsetInitialCharge(String stream, EngineNumber newValue) Set the initial charge for a stream.voidsetLastSpecifiedValue(String streamName, EngineNumber value) Set the last specified value for a stream.voidSet the recharge base population for cumulative calculations.voidsetRechargeIntensity(EngineNumber newValue) Set the recharge intensity.voidsetRechargePopulation(EngineNumber newValue) Set the recharge population percentage.voidsetRecoveryRate(EngineNumber newValue) Set the recovery rate percentage.voidsetRecoveryRate(EngineNumber newValue, RecoverOperation.RecoveryStage stage) Set the recovery rate percentage for a specific stage.voidsetRecyclingCalculatedThisStep(boolean calculated) Set whether recycling has been calculated this step.voidsetRetireCalculatedThisStep(boolean calculated) Set whether retire has been calculated this step.voidSet the retirement base population for cumulative calculations.voidsetRetirementRate(EngineNumber newValue) Set the retirement rate percentage.voidsetSalesIntentFreshlySet(boolean freshlySet) Set the flag indicating whether sales intent has been freshly set.voidsetYieldRate(EngineNumber newValue) Set the yield rate percentage for recycling.voidsetYieldRate(EngineNumber newValue, RecoverOperation.RecoveryStage stage) Set the yield rate percentage for recycling for a specific stage.
-
Constructor Details
-
StreamParameterization
public StreamParameterization()Create a new stream parameterization instance.
-
-
Method Details
-
setGhgIntensity
Set the greenhouse gas intensity.- Parameters:
newValue- The new GHG intensity value
-
getGhgIntensity
Get the greenhouse gas intensity.- Returns:
- The current GHG intensity value
-
setEnergyIntensity
Set the energy intensity.- Parameters:
newValue- The new energy intensity value
-
getEnergyIntensity
Get the energy intensity.- Returns:
- The current energy intensity value
-
setInitialCharge
Set the initial charge for a stream.- Parameters:
stream- The stream identifier ('domestic' or 'import')newValue- The new initial charge value
-
getInitialCharge
Get the initial charge for a stream.- Parameters:
stream- The stream identifier ('domestic' or 'import')- Returns:
- The initial charge value for the stream
-
setRechargePopulation
Set the recharge population percentage.- Parameters:
newValue- The new recharge population value
-
getRechargePopulation
Get the recharge population percentage.- Returns:
- The current recharge population value
-
setRechargeIntensity
Set the recharge intensity.- Parameters:
newValue- The new recharge intensity value
-
getRechargeIntensity
Get the recharge intensity.- Returns:
- The current recharge intensity value
-
setRecoveryRate
Set the recovery rate percentage.- Parameters:
newValue- The new recovery rate value
-
setRecoveryRate
Set the recovery rate percentage for a specific stage.- Parameters:
newValue- The new recovery rate valuestage- The recovery stage (EOL or RECHARGE)
-
getRecoveryRate
Get the recovery rate percentage.- Returns:
- The current recovery rate value
-
getRecoveryRate
Get the recovery rate percentage for a specific stage.- Parameters:
stage- The recovery stage (EOL or RECHARGE)- Returns:
- The current recovery rate value
-
setYieldRate
Set the yield rate percentage for recycling.- Parameters:
newValue- The new yield rate value
-
setYieldRate
Set the yield rate percentage for recycling for a specific stage.- Parameters:
newValue- The new yield rate valuestage- The recovery stage (EOL or RECHARGE)
-
getYieldRate
Get the yield rate percentage for recycling.- Returns:
- The current yield rate value
-
getYieldRate
Get the yield rate percentage for recycling for a specific stage.- Parameters:
stage- The recovery stage (EOL or RECHARGE)- Returns:
- The current yield rate value
-
setInductionRate
Set the induction rate percentage for recycling.- Parameters:
newValue- The new induction rate value
-
setInductionRate
Set the induction rate percentage for recycling for a specific stage.- Parameters:
newValue- The new induction rate valuestage- The recovery stage (EOL or RECHARGE)
-
getInductionRate
Get the induction rate percentage for recycling.- Returns:
- The current induction rate value
-
getInductionRate
Get the induction rate percentage for recycling for a specific stage.- Parameters:
stage- The recovery stage (EOL or RECHARGE)- Returns:
- The current induction rate value
-
setRetirementRate
Set the retirement rate percentage.This method accumulates retirement rates across multiple retire commands in the same year to support cumulative retirement behavior. If the resulting retirement rate is negative, it is clamped to zero (no retirement).
- Parameters:
newValue- The new retirement rate value to add
-
getRetirementRate
Get the retirement rate percentage.- Returns:
- The current retirement rate value
-
getRetirementBasePopulation
Get the retirement base population for cumulative calculations.- Returns:
- The base population, or empty if not yet captured this step
-
setRetirementBasePopulation
Set the retirement base population for cumulative calculations.- Parameters:
value- The base population value
-
getAppliedRetirementAmount
Get the applied retirement amount for cumulative calculations.- Returns:
- The total amount already retired this step
-
setAppliedRetirementAmount
Set the applied retirement amount for cumulative calculations.- Parameters:
value- The total amount retired this step
-
getHasReplacementThisStep
public boolean getHasReplacementThisStep()Get the replacement mode for this step's retire commands.- Returns:
- true if with replacement, false if without replacement
-
setHasReplacementThisStep
public void setHasReplacementThisStep(boolean value) Set the replacement mode for this step's retire commands.- Parameters:
value- true for with replacement, false for without replacement
-
getRetireCalculatedThisStep
public boolean getRetireCalculatedThisStep()Get whether retire has been calculated this step.- Returns:
- true if retire was calculated, false otherwise
-
setRetireCalculatedThisStep
public void setRetireCalculatedThisStep(boolean calculated) Set whether retire has been calculated this step.- Parameters:
calculated- true if retire was calculated, false otherwise
-
getRechargeBasePopulation
Get the recharge base population for cumulative calculations.- Returns:
- The base population, or empty if not yet captured this step
-
setRechargeBasePopulation
Set the recharge base population for cumulative calculations.- Parameters:
value- The base population value
-
getAppliedRechargeAmount
Get the applied recharge amount for cumulative calculations.- Returns:
- The total amount already recharged this step in kg
-
setAppliedRechargeAmount
Set the applied recharge amount for cumulative calculations.- Parameters:
value- The total amount recharged this step in kg
-
isRecyclingCalculatedThisStep
public boolean isRecyclingCalculatedThisStep()Get whether recycling has been calculated this step.- Returns:
- true if recycling was calculated, false otherwise
-
setRecyclingCalculatedThisStep
public void setRecyclingCalculatedThisStep(boolean calculated) Set whether recycling has been calculated this step.- Parameters:
calculated- true if recycling was calculated, false otherwise
-
accumulateRecharge
Accumulate recharge parameters. Sets when not previously set, accumulates otherwise.Multiple calls accumulate rates (addition) and intensities (weighted-average). Population rates are added, intensities are weighted-averaged using absolute values for weights to handle negative adjustments correctly.
Weighted average formula: (|rate1| × intensity1 + |rate2| × intensity2) / (|rate1| + |rate2|)
- Parameters:
population- The recharge population rate to addintensity- The recharge intensity for this rate
-
setLastSpecifiedValue
Set the last specified value for a stream.This tracks the value and units last used when setting streams to preserve user intent across carry-over years.
- Parameters:
streamName- The name of the streamvalue- The last specified value with units
-
getLastSpecifiedValue
Get the last specified value for a stream.- Parameters:
streamName- The name of the stream- Returns:
- The last specified value with units, or null if not set
-
hasLastSpecifiedValue
Check if a stream has a last specified value.- Parameters:
streamName- The name of the stream- Returns:
- true if the stream has a last specified value, false otherwise
-
markStreamAsEnabled
Mark a stream as having been enabled (set to non-zero value).- Parameters:
streamName- The name of the stream to mark as enabled
-
hasStreamBeenEnabled
Check if a stream has ever been enabled (set to non-zero value).- Parameters:
streamName- The name of the stream to check- Returns:
- true if the stream has been enabled, false otherwise
-
isSalesIntentFreshlySet
public boolean isSalesIntentFreshlySet()Check if sales intent has been freshly set in the current processing cycle.- Returns:
- true if sales intent was freshly set, false otherwise
-
setSalesIntentFreshlySet
public void setSalesIntentFreshlySet(boolean freshlySet) Set the flag indicating whether sales intent has been freshly set.- Parameters:
freshlySet- true if sales intent was freshly set, false otherwise
-
resetStateAtTimestep
public void resetStateAtTimestep()Reset state at the beginning of a timestep.This method resets recovery rate to 0% and induction rate to 100% between steps since recycling programs may cease and should not be expected to continue unchanged, but default induction behavior should return to induced demand (100%).
-
clearLastSpecifiedValue
Clear the last specified value in this parameterization.The last specified value tracks the user specified target for a stream such that commands changing those values respect user directives like maintaining units-based tracking with implicit recharge. This method clears that directive so that, for example, a set command can override a prior given value. This, for example, allows the user to switch from units-based to volume-based tracking.
This will clear the stream and those dependent upon it. Therefore, clearing sales will also clear substreams domestic and import. Similarly, clearing domestic will clear sales but not import.
- Parameters:
stream- The name of the stream like "sales" or "import" in which to clear.
-