Skip to content

Commit

Permalink
separate RAs and rangeActions limits
Browse files Browse the repository at this point in the history
Signed-off-by: belthlemar <[email protected]>
  • Loading branch information
MartinBelthle committed Apr 25, 2024
1 parent 9d1b68f commit d411e9d
Showing 1 changed file with 32 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import com.powsybl.openrao.commons.RandomizedString;
import com.powsybl.openrao.data.cracapi.*;
import com.powsybl.openrao.data.cracapi.cnec.FlowCnec;
import com.powsybl.openrao.data.cracapi.networkaction.NetworkAction;
import com.powsybl.openrao.data.cracapi.rangeaction.PstRangeAction;
import com.powsybl.openrao.data.cracapi.rangeaction.RangeAction;
import com.powsybl.openrao.data.cracapi.rangeaction.StandardRangeAction;
Expand Down Expand Up @@ -819,23 +820,25 @@ private static Map<State, Map<RangeAction<?>, Double>> buildSetPointResultsMap(C
* Checks if raUsageLimits are at risk if we choose to re-optimize a range action.
* Returns True if it's at risk, False otherwise.
*/
private static boolean shouldRemoveRaDueToUsageLimits(String operator, RaUsageLimits raUsageLimits, Set<RemedialAction<?>> potentiallyActivatableRas) {
long potentiallyActivatableTsos = Integer.MAX_VALUE;
long potentiallyActivatableRasForTheTso = Integer.MAX_VALUE;
if (operator != null) {
potentiallyActivatableRasForTheTso = potentiallyActivatableRas.stream()
.filter(ra -> operator.equals(ra.getOperator()))
.count();
potentiallyActivatableTsos = potentiallyActivatableRas.stream()
.map(RemedialAction::getOperator)
.filter(Objects::nonNull)
.distinct()
.count();
}
int limitingValueForTheTso = Math.min(raUsageLimits.getMaxPstPerTso().getOrDefault(operator, Integer.MAX_VALUE), raUsageLimits.getMaxRaPerTso().getOrDefault(operator, Integer.MAX_VALUE));
return raUsageLimits.getMaxRa() < potentiallyActivatableRas.size()
|| limitingValueForTheTso < potentiallyActivatableRasForTheTso
|| raUsageLimits.getMaxTso() < potentiallyActivatableTsos;
private static boolean shouldRemoveRaDueToUsageLimits(String operator, RaUsageLimits raUsageLimits, Set<RangeAction<?>> activatableRangeActions, Set<NetworkAction> activatedNetworkActions) {
if (operator == null) {
return raUsageLimits.getMaxRa() < activatableRangeActions.size() + activatedNetworkActions.size();
}

Set<RemedialAction<?>> activatableRemedialActions = new HashSet<>(activatableRangeActions);
activatableRemedialActions.addAll(activatedNetworkActions);

long activatableRangeActionsForTheTso = activatableRangeActions.stream().filter(ra -> operator.equals(ra.getOperator())).count();
long activatableRemedialActionsForTheTso = activatableRemedialActions.stream().filter(ra -> operator.equals(ra.getOperator())).count();
long activatableTsos = activatableRemedialActions.stream().map(RemedialAction::getOperator).filter(Objects::nonNull).distinct().count();

int limitingRangeActionValueForTheTso = raUsageLimits.getMaxPstPerTso().getOrDefault(operator, Integer.MAX_VALUE);
int limitingRemedialActionValueForTheTso = raUsageLimits.getMaxRaPerTso().getOrDefault(operator, Integer.MAX_VALUE);

return raUsageLimits.getMaxRa() < activatableRangeActions.size() + activatedNetworkActions.size()
|| limitingRangeActionValueForTheTso < activatableRangeActionsForTheTso
|| limitingRemedialActionValueForTheTso < activatableRemedialActionsForTheTso
|| raUsageLimits.getMaxTso() < activatableTsos;
}

/**
Expand All @@ -845,16 +848,19 @@ private static boolean shouldRemoveRaDueToUsageLimits(String operator, RaUsageLi
*/
private static Set<RangeAction<?>> getRangeActionsToRemove(Crac crac, State preventiveState, Map<State, Map<RangeAction<?>, Double>> setPointResults, Map<State, OptimizationResult> contingencyResults) {
Set<RangeAction<?>> rangeActionsToRemove = new HashSet<>();
setPointResults.forEach((state, spMap) -> spMap.forEach((ra, setPoint) -> {
double referenceSetPoint = setPointResults.get(preventiveState).get(ra);
if (!state.isPreventive() && setPoint.equals(referenceSetPoint) && crac.getRaUsageLimitsPerInstant().containsKey(state.getInstant())) {
Set<RemedialAction<?>> potentiallyActivatableRas = new HashSet<>(crac.getPotentiallyAvailableRangeActions(state));
potentiallyActivatableRas.addAll(contingencyResults.get(state).getActivatedNetworkActions());
if (shouldRemoveRaDueToUsageLimits(ra.getOperator(), crac.getRaUsageLimits(state.getInstant()), potentiallyActivatableRas)) {
rangeActionsToRemove.add(ra);
}
setPointResults.forEach((state, spMap) -> {
if (!state.isPreventive()) {
Set<RangeAction<?>> activatableRangeActions = crac.getPotentiallyAvailableRangeActions(state);
Set<NetworkAction> activatedNetworkActions = contingencyResults.get(state).getActivatedNetworkActions();
spMap.forEach((ra, setPoint) -> {
if (setPoint.equals(setPointResults.get(preventiveState).get(ra))
&& crac.getRaUsageLimitsPerInstant().containsKey(state.getInstant())
&& shouldRemoveRaDueToUsageLimits(ra.getOperator(), crac.getRaUsageLimits(state.getInstant()), activatableRangeActions, activatedNetworkActions)) {
rangeActionsToRemove.add(ra);
}
});
}
}));
});
return rangeActionsToRemove;
}

Expand Down

0 comments on commit d411e9d

Please sign in to comment.