From ad6f6f39e5dca35c99c60145b127d95907c2f8a2 Mon Sep 17 00:00:00 2001 From: Mathieu Deharbe <148252167+mathieu-deharbe@users.noreply.github.com> Date: Wed, 28 Aug 2024 10:44:12 +0200 Subject: [PATCH 01/23] draft Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 49 ++++++++++++++++--- .../equipmentfield/GeneratorField.java | 12 +++-- .../modifications/ModificationUtils.java | 11 ++++- 3 files changed, 61 insertions(+), 11 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index 079dd8a12..f03ddc388 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -10,6 +10,9 @@ import com.powsybl.iidm.network.Battery; import com.powsybl.iidm.network.extensions.ActivePowerControl; import com.powsybl.iidm.network.extensions.ActivePowerControlAdder; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; +import org.gridsuite.modification.server.modifications.ModificationUtils; /** * @author Seddik Yengui @@ -37,13 +40,45 @@ public static Double getReferenceValue(Battery battery, String batteryField) { public static void setNewValue(Battery battery, String batteryField, Double newValue) { BatteryField field = BatteryField.valueOf(batteryField); switch (field) { - case MINIMUM_ACTIVE_POWER -> battery.setMinP(newValue); - case MAXIMUM_ACTIVE_POWER -> battery.setMaxP(newValue); - case ACTIVE_POWER_SET_POINT -> battery.setTargetP(newValue); - case REACTIVE_POWER_SET_POINT -> battery.setTargetQ(newValue); - case DROOP -> battery.newExtension(ActivePowerControlAdder.class) - .withDroop(newValue) - .add(); + case MINIMUM_ACTIVE_POWER -> + ModificationUtils.getInstance().applyElementaryModifications( + battery::setMinP, + battery::getMinP, + new AttributeModification<>(newValue, OperationType.SET)); + case MAXIMUM_ACTIVE_POWER -> + ModificationUtils.getInstance().applyElementaryModifications( + battery::setMaxP, + battery::getMaxP, + new AttributeModification<>(newValue, OperationType.SET)); + case ACTIVE_POWER_SET_POINT -> + ModificationUtils.getInstance().applyElementaryModifications( + battery::setTargetP, + battery::getTargetP, + new AttributeModification<>(newValue, OperationType.SET)); + case REACTIVE_POWER_SET_POINT -> + ModificationUtils.getInstance().applyElementaryModifications( + battery::setTargetQ, + battery::getTargetQ, + new AttributeModification<>(newValue, OperationType.SET)); + case DROOP -> { + ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); + ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); + ModificationUtils.getInstance().modifyActivePowerControlAttributes( + activePowerControl, + activePowerControlAdder, + null, + new AttributeModification<>(newValue.floatValue(), OperationType.SET), + null, + null); + /* Correction basique juste au cas où je ne fais pas le méga refacto : + if (battery.getExtension(ActivePowerControl.class) != null) { + battery.getExtension(ActivePowerControl.class).setDroop(newValue); + } else { + battery.newExtension(ActivePowerControlAdder.class) + .withDroop(newValue) + .add(); + }*/ + } } } } diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 7c864cbfd..ca804556d 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -129,9 +129,15 @@ public static void setNewValue(Generator generator, String generatorField, Doubl .add(); } } - case DROOP -> generator.newExtension(ActivePowerControlAdder.class) - .withDroop(newValue) - .add(); + case DROOP -> { + if (generator.getExtension(ActivePowerControl.class) != null) { + generator.getExtension(ActivePowerControl.class).setDroop(newValue); + } else { + generator.newExtension(ActivePowerControlAdder.class) + .withDroop(newValue) + .add(); + } + } case TRANSIENT_REACTANCE -> generator.newExtension(GeneratorShortCircuitAdder.class) .withDirectTransX(newValue) .withStepUpTransformerX(generatorShortCircuit == null ? Double.NaN : generatorShortCircuit.getStepUpTransformerX()) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index 95ff24a67..6061d3934 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -450,6 +450,15 @@ public static Predicate distinctByKey( return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null; } + public void applyElementaryModifications(Consumer setter, Supplier getter, + AttributeModification modification) { + if (modification != null) { + T oldValue = getter.get(); + T newValue = modification.applyModification(oldValue); + setter.accept(newValue); + } + } + public ReportNode applyElementaryModificationsAndReturnReport(Consumer setter, Supplier getter, AttributeModification modification, String fieldName) { if (modification != null) { @@ -1032,7 +1041,7 @@ public ReportNode modifyActivePowerControlAttributes(ActivePowerControl activ } ReportNode subReportNodeSetpoints2 = subReporterSetpoints; - if (subReporterSetpoints == null && !reports.isEmpty()) { + if (subReporterSetpoints == null && !reports.isEmpty() && subReportNode != null) { // tmp test : essayer de décorréler l'application des logs subReportNodeSetpoints2 = subReportNode.newReportNode().withMessageTemplate(SETPOINTS, SETPOINTS).add(); subReportNodeSetpoints2.newReportNode() .withMessageTemplate(SETPOINTS, SETPOINTS) From 3b27dfb8d6ac9c603c061cf9279effc06bc32dca Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Thu, 29 Aug 2024 10:00:03 +0200 Subject: [PATCH 02/23] draft refacto check and apply functions Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 47 +++---- .../equipmentfield/GeneratorField.java | 129 +++++++++--------- .../modifications/BatteryModification.java | 2 +- .../modifications/ByFormulaModification.java | 2 +- .../modifications/GeneratorModification.java | 99 +++++++++----- .../modifications/ModificationUtils.java | 53 ++++--- 6 files changed, 180 insertions(+), 152 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index f03ddc388..a92705d84 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -14,6 +14,8 @@ import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.modifications.ModificationUtils; +import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; + /** * @author Seddik Yengui */ @@ -40,26 +42,22 @@ public static Double getReferenceValue(Battery battery, String batteryField) { public static void setNewValue(Battery battery, String batteryField, Double newValue) { BatteryField field = BatteryField.valueOf(batteryField); switch (field) { - case MINIMUM_ACTIVE_POWER -> - ModificationUtils.getInstance().applyElementaryModifications( - battery::setMinP, - battery::getMinP, - new AttributeModification<>(newValue, OperationType.SET)); - case MAXIMUM_ACTIVE_POWER -> - ModificationUtils.getInstance().applyElementaryModifications( - battery::setMaxP, - battery::getMaxP, - new AttributeModification<>(newValue, OperationType.SET)); - case ACTIVE_POWER_SET_POINT -> - ModificationUtils.getInstance().applyElementaryModifications( - battery::setTargetP, - battery::getTargetP, - new AttributeModification<>(newValue, OperationType.SET)); - case REACTIVE_POWER_SET_POINT -> - ModificationUtils.getInstance().applyElementaryModifications( - battery::setTargetQ, - battery::getTargetQ, - new AttributeModification<>(newValue, OperationType.SET)); + case MINIMUM_ACTIVE_POWER -> battery.setMinP(newValue); + case MAXIMUM_ACTIVE_POWER -> battery.setMaxP(newValue); + case ACTIVE_POWER_SET_POINT -> { + ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( + new AttributeModification<>(newValue, OperationType.SET), + null, + null, + battery.getMinP(), + battery.getMaxP(), + battery.getTargetP(), + MODIFY_GENERATOR_ERROR, + "Battery '" + battery.getId() + "' : " + ); + battery.setTargetP(newValue); + } + case REACTIVE_POWER_SET_POINT -> battery.setTargetQ(newValue); case DROOP -> { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); @@ -68,16 +66,7 @@ public static void setNewValue(Battery battery, String batteryField, Double newV activePowerControlAdder, null, new AttributeModification<>(newValue.floatValue(), OperationType.SET), - null, null); - /* Correction basique juste au cas où je ne fais pas le méga refacto : - if (battery.getExtension(ActivePowerControl.class) != null) { - battery.getExtension(ActivePowerControl.class).setDroop(newValue); - } else { - battery.newExtension(ActivePowerControlAdder.class) - .withDroop(newValue) - .add(); - }*/ } } } diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index ca804556d..43c4fcbe7 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -15,7 +15,12 @@ import com.powsybl.iidm.network.extensions.GeneratorShortCircuit; import com.powsybl.iidm.network.extensions.GeneratorShortCircuitAdder; import com.powsybl.iidm.network.extensions.GeneratorStartup; -import com.powsybl.iidm.network.extensions.GeneratorStartupAdder; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; +import org.gridsuite.modification.server.modifications.ModificationUtils; + +import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; +import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorStartUpAttributes; /** * @author Seddik Yengui @@ -63,80 +68,72 @@ public static Double getReferenceValue(Generator generator, String generatorFiel public static void setNewValue(Generator generator, String generatorField, Double newValue) { if (!Double.isNaN(newValue)) { - GeneratorStartup generatorStartup = generator.getExtension(GeneratorStartup.class); GeneratorShortCircuit generatorShortCircuit = generator.getExtension(GeneratorShortCircuit.class); GeneratorField field = GeneratorField.valueOf(generatorField); switch (field) { case MAXIMUM_ACTIVE_POWER -> generator.setMaxP(newValue); case MINIMUM_ACTIVE_POWER -> generator.setMinP(newValue); - case ACTIVE_POWER_SET_POINT -> generator.setTargetP(newValue); + case ACTIVE_POWER_SET_POINT -> { + ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( + new AttributeModification<>(newValue, OperationType.SET), + null, + null, + generator.getMinP(), + generator.getMaxP(), + generator.getTargetP(), + MODIFY_GENERATOR_ERROR, + "Generator '" + generator.getId() + "' : " + ); + generator.setTargetP(newValue); + } case RATED_NOMINAL_POWER -> generator.setRatedS(newValue); case REACTIVE_POWER_SET_POINT -> generator.setTargetQ(newValue); case VOLTAGE_SET_POINT -> generator.setTargetV(newValue); - case PLANNED_ACTIVE_POWER_SET_POINT -> { - if (generatorStartup == null) { - generator.newExtension(GeneratorStartupAdder.class) - .withPlannedActivePowerSetpoint(newValue) - .add(); - } else { - generator.newExtension(GeneratorStartupAdder.class) - .withMarginalCost(generatorStartup.getMarginalCost()) - .withPlannedActivePowerSetpoint(newValue) - .withPlannedOutageRate(generatorStartup.getPlannedOutageRate()) - .withForcedOutageRate(generatorStartup.getForcedOutageRate()) - .add(); - } - } - case MARGINAL_COST -> { - if (generatorStartup == null) { - generator.newExtension(GeneratorStartupAdder.class) - .withMarginalCost(newValue) - .add(); - } else { - generator.newExtension(GeneratorStartupAdder.class) - .withMarginalCost(newValue) - .withPlannedActivePowerSetpoint(generatorStartup.getPlannedActivePowerSetpoint()) - .withPlannedOutageRate(generatorStartup.getPlannedOutageRate()) - .withForcedOutageRate(generatorStartup.getForcedOutageRate()) - .add(); - } - } - case PLANNED_OUTAGE_RATE -> { - if (generatorStartup == null) { - generator.newExtension(GeneratorStartupAdder.class) - .withPlannedOutageRate(newValue) - .add(); - } else { - generator.newExtension(GeneratorStartupAdder.class) - .withMarginalCost(generatorStartup.getMarginalCost()) - .withPlannedActivePowerSetpoint(generatorStartup.getPlannedActivePowerSetpoint()) - .withPlannedOutageRate(newValue) - .withForcedOutageRate(generatorStartup.getForcedOutageRate()) - .add(); - } - } - case FORCED_OUTAGE_RATE -> { - if (generatorStartup == null) { - generator.newExtension(GeneratorStartupAdder.class) - .withForcedOutageRate(newValue) - .add(); - } else { - generator.newExtension(GeneratorStartupAdder.class) - .withMarginalCost(generatorStartup.getMarginalCost()) - .withPlannedActivePowerSetpoint(generatorStartup.getPlannedActivePowerSetpoint()) - .withPlannedOutageRate(generatorStartup.getForcedOutageRate()) - .withForcedOutageRate(newValue) - .add(); - } - } + case PLANNED_ACTIVE_POWER_SET_POINT -> + modifyGeneratorStartUpAttributes( + new AttributeModification<>(newValue, OperationType.SET), + null, + null, + null, + generator, + null, + null); + case MARGINAL_COST -> + modifyGeneratorStartUpAttributes( + null, + new AttributeModification<>(newValue, OperationType.SET), + null, + null, + generator, + null, + null); + case PLANNED_OUTAGE_RATE -> + modifyGeneratorStartUpAttributes( + null, + null, + new AttributeModification<>(newValue, OperationType.SET), + null, + generator, + null, + null); + case FORCED_OUTAGE_RATE -> + modifyGeneratorStartUpAttributes( + null, + null, + null, + new AttributeModification<>(newValue, OperationType.SET), + generator, + null, + null); case DROOP -> { - if (generator.getExtension(ActivePowerControl.class) != null) { - generator.getExtension(ActivePowerControl.class).setDroop(newValue); - } else { - generator.newExtension(ActivePowerControlAdder.class) - .withDroop(newValue) - .add(); - } + ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); + ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); + ModificationUtils.getInstance().modifyActivePowerControlAttributes( + activePowerControl, + activePowerControlAdder, + null, + new AttributeModification<>(newValue.floatValue(), OperationType.SET), + null); } case TRANSIENT_REACTANCE -> generator.newExtension(GeneratorShortCircuitAdder.class) .withDirectTransX(newValue) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java b/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java index 01d4137d5..ab1c1ef04 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java @@ -172,7 +172,7 @@ private ReportNode modifyBatteryActivePowerControlAttributes(BatteryModification Battery battery, ReportNode subReportNode, ReportNode subReportNodeSetpoints) { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); - return ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); + return ModificationUtils.getInstance().modifyActivePowerControlAttributesAndLog(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); } private ReportNode modifyBatteryConnectivityAttributes(BatteryModificationInfos modificationInfos, diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java index 22460eeb4..774ce6373 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java @@ -287,7 +287,7 @@ private void applyFormula(Identifiable identifiable, .withUntypedValue(KEY_VALUE, newValue) .withSeverity(TypedValue.TRACE_SEVERITY) .build()); - } catch (Exception e) { + } catch (Exception e) { // ATTENTION : ce catch attrape bien mes throw mais sans utiliser les messages donc c'est un peu gâché; En faire un spécifique pour les NetworkModificationException ? notEditableEquipments.add(identifiable.getId()); equipmentNotModifiedCount += 1; reports.add(ReportNode.newRootReportNode() diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index 2418ea599..c3edf9a29 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -94,7 +94,7 @@ private void modifyGenerator(Generator generator, GeneratorModificationInfos mod modifyGeneratorLimitsAttributes(modificationInfos, generator, subReportNode); modifyGeneratorSetpointsAttributes(modificationInfos, generator, subReportNode); modifyGeneratorShortCircuitAttributes(modificationInfos, generator, subReportNode); - modifyGeneratorStartUpAttributes(modificationInfos, generator, subReportNode); + modifyGeneratorStartUpAttributesAndLog(modificationInfos, generator, subReportNode); modifyGeneratorConnectivityAttributes(modificationInfos, generator, subReportNode); PropertiesUtils.applyProperties(generator, subReportNode, modificationInfos.getProperties(), "GeneratorProperties"); } @@ -212,36 +212,60 @@ private ReportNode modifyGeneratorActivePowerControlAttributes(GeneratorModifica Generator generator, ReportNode subReportNode, ReportNode subReportNodeSetpoints) { ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); - return ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); + return ModificationUtils.getInstance().modifyActivePowerControlAttributesAndLog(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); } - private void modifyGeneratorStartUpAttributes(GeneratorModificationInfos modificationInfos, Generator generator, - ReportNode subReportNode) { + private void modifyGeneratorStartUpAttributesAndLog(GeneratorModificationInfos modificationInfos, Generator generator, + ReportNode subReportNode) { List reports = new ArrayList<>(); - GeneratorStartup generatorStartup = generator.getExtension(GeneratorStartup.class); + modifyGeneratorStartUpAttributes(modificationInfos.getPlannedActivePowerSetPoint(), + modificationInfos.getMarginalCost(), + modificationInfos.getPlannedOutageRate(), + modificationInfos.getForcedOutageRate(), + generator, + subReportNode, + reports); + } + + public static void modifyGeneratorStartUpAttributes(AttributeModification plannedActivePowerSetPoint, + AttributeModification marginalCost, + AttributeModification plannedOutageRate, + AttributeModification forcedOutageRate, + Generator generator, + ReportNode subReportNode, + List reports) { GeneratorStartupAdder generatorStartupAdder = generator.newExtension(GeneratorStartupAdder.class); - boolean plannedActivePowerSetPointUpdated = addPlannedActivePowerSetPoint(modificationInfos, generatorStartupAdder, generatorStartup, reports); - boolean marginalCostUpdated = addMarginalCost(modificationInfos, generatorStartupAdder, generatorStartup, reports); - boolean plannedOutageRateUpdated = addPlannedOutageRate(modificationInfos, generatorStartupAdder, generatorStartup, reports); - boolean forcedOutageRateUpdated = addForcedOutageRate(modificationInfos, generatorStartupAdder, generatorStartup, reports); + GeneratorStartup generatorStartup = generator.getExtension(GeneratorStartup.class); + boolean plannedActivePowerSetPointUpdated = addPlannedActivePowerSetPoint(plannedActivePowerSetPoint, + generatorStartupAdder, + generatorStartup, + reports); + boolean marginalCostUpdated = addMarginalCost(marginalCost, generatorStartupAdder, generatorStartup, reports); + boolean plannedOutageRateUpdated = addPlannedOutageRate(plannedOutageRate, generatorStartupAdder, generatorStartup, reports); + boolean forcedOutageRateUpdated = addForcedOutageRate(forcedOutageRate, generatorStartupAdder, generatorStartup, reports); if (plannedActivePowerSetPointUpdated || marginalCostUpdated || plannedOutageRateUpdated || forcedOutageRateUpdated) { generatorStartupAdder.add(); - ModificationUtils.getInstance().reportModifications(subReportNode, reports, "startUpAttributesModified", "Start up", Map.of()); + if (subReportNode != null) { + ModificationUtils.getInstance().reportModifications(subReportNode, reports, "startUpAttributesModified", "Start up", Map.of()); + } } } - private boolean addForcedOutageRate(GeneratorModificationInfos modificationInfos, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { + + private static boolean addForcedOutageRate(AttributeModification forcedOutageRate, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { Double oldForcedOutageRate = generatorStartup != null ? generatorStartup.getForcedOutageRate() : Double.NaN; - if (modificationInfos.getForcedOutageRate() != null) { + if (forcedOutageRate != null) { generatorStartupAdder - .withForcedOutageRate(modificationInfos.getForcedOutageRate().getValue()); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldForcedOutageRate, - modificationInfos.getForcedOutageRate().getValue(), - "Forced outage rate")); + .withForcedOutageRate(forcedOutageRate.getValue()); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(oldForcedOutageRate, + forcedOutageRate.getValue(), + "Forced outage rate")); + } return true; } else { generatorStartupAdder @@ -250,14 +274,16 @@ private boolean addForcedOutageRate(GeneratorModificationInfos modificationInfos return false; } - private boolean addPlannedOutageRate(GeneratorModificationInfos modificationInfos, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { + private static boolean addPlannedOutageRate(AttributeModification plannedOutageRate, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { Double oldPlannedOutageRate = generatorStartup != null ? generatorStartup.getPlannedOutageRate() : Double.NaN; - if (modificationInfos.getPlannedOutageRate() != null) { + if (plannedOutageRate != null) { generatorStartupAdder - .withPlannedOutageRate(modificationInfos.getPlannedOutageRate().getValue()); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldPlannedOutageRate, - modificationInfos.getPlannedOutageRate().getValue(), - "Planning outage rate")); + .withPlannedOutageRate(plannedOutageRate.getValue()); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(oldPlannedOutageRate, + plannedOutageRate.getValue(), + "Planning outage rate")); + } return true; } else { generatorStartupAdder @@ -266,14 +292,16 @@ private boolean addPlannedOutageRate(GeneratorModificationInfos modificationInfo return false; } - private boolean addMarginalCost(GeneratorModificationInfos modificationInfos, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { + private static boolean addMarginalCost(AttributeModification marginalCost, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { Double oldMarginalCost = generatorStartup != null ? generatorStartup.getMarginalCost() : Double.NaN; - if (modificationInfos.getMarginalCost() != null) { + if (marginalCost != null) { generatorStartupAdder - .withMarginalCost(modificationInfos.getMarginalCost().getValue()); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldMarginalCost, - modificationInfos.getMarginalCost().getValue(), - "Marginal cost")); + .withMarginalCost(marginalCost.getValue()); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(oldMarginalCost, + marginalCost.getValue(), + "Marginal cost")); + } return true; } else { generatorStartupAdder @@ -282,14 +310,17 @@ private boolean addMarginalCost(GeneratorModificationInfos modificationInfos, Ge return false; } - private boolean addPlannedActivePowerSetPoint(GeneratorModificationInfos modificationInfos, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { + private static boolean addPlannedActivePowerSetPoint(AttributeModification plannedActivePowerSetPoint, GeneratorStartupAdder generatorStartupAdder, + GeneratorStartup generatorStartup, List reports) { Double oldPlannedActivePowerSetPoint = generatorStartup != null ? generatorStartup.getPlannedActivePowerSetpoint() : Double.NaN; - if (modificationInfos.getPlannedActivePowerSetPoint() != null) { + if (plannedActivePowerSetPoint != null) { generatorStartupAdder - .withPlannedActivePowerSetpoint(modificationInfos.getPlannedActivePowerSetPoint().getValue()); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldPlannedActivePowerSetPoint, - modificationInfos.getPlannedActivePowerSetPoint().getValue(), - "Planning active power set point")); + .withPlannedActivePowerSetpoint(plannedActivePowerSetPoint.getValue()); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(oldPlannedActivePowerSetPoint, + plannedActivePowerSetPoint.getValue(), + "Planning active power set point")); + } return true; } else { generatorStartupAdder diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index 6061d3934..2b6d90df4 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -450,15 +450,6 @@ public static Predicate distinctByKey( return t -> seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null; } - public void applyElementaryModifications(Consumer setter, Supplier getter, - AttributeModification modification) { - if (modification != null) { - T oldValue = getter.get(); - T newValue = modification.applyModification(oldValue); - setter.accept(newValue); - } - } - public ReportNode applyElementaryModificationsAndReturnReport(Consumer setter, Supplier getter, AttributeModification modification, String fieldName) { if (modification != null) { @@ -1001,12 +992,16 @@ private void modifyExistingActivePowerControl(ActivePowerControl activePowerC Optional.ofNullable(participateInfo).ifPresent(info -> { activePowerControl.setParticipate(info.getValue()); - reports.add(buildModificationReport(oldParticipate, info.getValue(), "Participate")); + if (reports != null) { + reports.add(buildModificationReport(oldParticipate, info.getValue(), "Participate")); + } }); Optional.ofNullable(droopInfo).ifPresent(info -> { activePowerControl.setDroop(info.getValue()); - reports.add(buildModificationReport(oldDroop, info.getValue(), "Droop")); + if (reports != null) { + reports.add(buildModificationReport(oldDroop, info.getValue(), "Droop")); + } }); } @@ -1016,32 +1011,48 @@ private void createNewActivePowerControl(ActivePowerControlAdder adder, List reports) { boolean participate = participateInfo != null ? participateInfo.getValue() : false; adder.withParticipate(participate); - if (participateInfo != null) { + if (participateInfo != null && reports != null) { reports.add(buildModificationReport(null, participate, "Participate")); } double droop = droopInfo != null ? droopInfo.getValue() : Double.NaN; adder.withDroop(droop); - if (droopInfo != null) { + if (droopInfo != null && reports != null) { reports.add(buildModificationReport(Double.NaN, droop, "Droop")); } adder.add(); } - public ReportNode modifyActivePowerControlAttributes(ActivePowerControl activePowerControl, - ActivePowerControlAdder activePowerControlAdder, - AttributeModification participateInfo, - AttributeModification droopInfo, - ReportNode subReportNode, - ReportNode subReporterSetpoints) { - List reports = new ArrayList<>(); + + /** + * @param reports Data changes will be added to this list. The array may be null but no modification report will be created + */ + public void modifyActivePowerControlAttributes(ActivePowerControl activePowerControl, + ActivePowerControlAdder activePowerControlAdder, + AttributeModification participateInfo, + AttributeModification droopInfo, + List reports) { if (activePowerControl != null) { modifyExistingActivePowerControl(activePowerControl, participateInfo, droopInfo, reports); } else { createNewActivePowerControl(activePowerControlAdder, participateInfo, droopInfo, reports); } + } + + public ReportNode modifyActivePowerControlAttributesAndLog(ActivePowerControl activePowerControl, + ActivePowerControlAdder activePowerControlAdder, + AttributeModification participateInfo, + AttributeModification droopInfo, + ReportNode subReportNode, + ReportNode subReporterSetpoints) { + List reports = new ArrayList<>(); + modifyActivePowerControlAttributes(activePowerControl, + activePowerControlAdder, + participateInfo, + droopInfo, + reports); ReportNode subReportNodeSetpoints2 = subReporterSetpoints; - if (subReporterSetpoints == null && !reports.isEmpty() && subReportNode != null) { // tmp test : essayer de décorréler l'application des logs + if (subReporterSetpoints == null && !reports.isEmpty()) { subReportNodeSetpoints2 = subReportNode.newReportNode().withMessageTemplate(SETPOINTS, SETPOINTS).add(); subReportNodeSetpoints2.newReportNode() .withMessageTemplate(SETPOINTS, SETPOINTS) From 1986a26a7cc7afc486947a7ca49009a7007e74c8 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Thu, 29 Aug 2024 11:18:29 +0200 Subject: [PATCH 03/23] indent and correct TU Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 22 +++++++++---------- .../modifications/GeneratorModification.java | 1 - .../modifications/ModificationUtils.java | 1 - .../GeneratorByFormulaModificationTest.java | 4 ++-- 4 files changed, 13 insertions(+), 15 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index a92705d84..e8d27f76d 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -45,17 +45,17 @@ public static void setNewValue(Battery battery, String batteryField, Double newV case MINIMUM_ACTIVE_POWER -> battery.setMinP(newValue); case MAXIMUM_ACTIVE_POWER -> battery.setMaxP(newValue); case ACTIVE_POWER_SET_POINT -> { - ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( - new AttributeModification<>(newValue, OperationType.SET), - null, - null, - battery.getMinP(), - battery.getMaxP(), - battery.getTargetP(), - MODIFY_GENERATOR_ERROR, - "Battery '" + battery.getId() + "' : " - ); - battery.setTargetP(newValue); + ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( + new AttributeModification<>(newValue, OperationType.SET), + null, + null, + battery.getMinP(), + battery.getMaxP(), + battery.getTargetP(), + MODIFY_GENERATOR_ERROR, + "Battery '" + battery.getId() + "' : " + ); + battery.setTargetP(newValue); } case REACTIVE_POWER_SET_POINT -> battery.setTargetQ(newValue); case DROOP -> { diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index c3edf9a29..93f148210 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -255,7 +255,6 @@ public static void modifyGeneratorStartUpAttributes(AttributeModification forcedOutageRate, GeneratorStartupAdder generatorStartupAdder, GeneratorStartup generatorStartup, List reports) { Double oldForcedOutageRate = generatorStartup != null ? generatorStartup.getForcedOutageRate() : Double.NaN; if (forcedOutageRate != null) { diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index 2b6d90df4..4ed92356b 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -1022,7 +1022,6 @@ private void createNewActivePowerControl(ActivePowerControlAdder adder, adder.add(); } - /** * @param reports Data changes will be added to this list. The array may be null but no modification report will be created */ diff --git a/src/test/java/org/gridsuite/modification/server/modifications/GeneratorByFormulaModificationTest.java b/src/test/java/org/gridsuite/modification/server/modifications/GeneratorByFormulaModificationTest.java index 9c3a4d38a..ae5b98b1b 100644 --- a/src/test/java/org/gridsuite/modification/server/modifications/GeneratorByFormulaModificationTest.java +++ b/src/test/java/org/gridsuite/modification/server/modifications/GeneratorByFormulaModificationTest.java @@ -299,7 +299,7 @@ protected void assertAfterNetworkModificationCreation() { assertNotNull(generatorStartup1); assertEquals(50, generator1.getTargetP(), 0); assertEquals(15, generatorStartup1.getMarginalCost(), 0); - assertEquals(55, generatorStartup1.getPlannedOutageRate(), 0); + assertEquals(2.5, generatorStartup1.getPlannedOutageRate(), 0); assertEquals(1100, generatorStartup1.getForcedOutageRate(), 0); assertEquals(50, generatorStartup1.getPlannedActivePowerSetpoint(), 0); assertEquals(502, generator1.getMaxP(), 0); @@ -310,7 +310,7 @@ protected void assertAfterNetworkModificationCreation() { assertNotNull(generatorStartup2); assertEquals(100, generator2.getTargetP(), 0); assertEquals(15, generatorStartup2.getMarginalCost(), 0); - assertEquals(55, generatorStartup2.getPlannedOutageRate(), 0); + assertEquals(2.5, generatorStartup2.getPlannedOutageRate(), 0); assertEquals(1100, generatorStartup2.getForcedOutageRate(), 0); assertEquals(50, generatorStartup2.getPlannedActivePowerSetpoint(), 0); assertEquals(2002, generator2.getMaxP(), 0); From dffe039ce27c9836bf64ef89d60d0e58a48b0d22 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Thu, 29 Aug 2024 16:09:38 +0200 Subject: [PATCH 04/23] finish GeneratorField + correction in GeneratorModification Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/GeneratorField.java | 25 +++++++------ .../modifications/GeneratorModification.java | 37 +++++++++++-------- 2 files changed, 34 insertions(+), 28 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 43c4fcbe7..427afef97 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -11,15 +11,15 @@ import com.powsybl.iidm.network.extensions.ActivePowerControl; import com.powsybl.iidm.network.extensions.ActivePowerControlAdder; import com.powsybl.iidm.network.extensions.CoordinatedReactiveControl; -import com.powsybl.iidm.network.extensions.CoordinatedReactiveControlAdder; import com.powsybl.iidm.network.extensions.GeneratorShortCircuit; -import com.powsybl.iidm.network.extensions.GeneratorShortCircuitAdder; import com.powsybl.iidm.network.extensions.GeneratorStartup; +import com.powsybl.network.store.iidm.impl.extensions.CoordinatedReactiveControlAdderImpl; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.modifications.ModificationUtils; import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; +import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorShortCircuitAttributes; import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorStartUpAttributes; /** @@ -68,7 +68,6 @@ public static Double getReferenceValue(Generator generator, String generatorFiel public static void setNewValue(Generator generator, String generatorField, Double newValue) { if (!Double.isNaN(newValue)) { - GeneratorShortCircuit generatorShortCircuit = generator.getExtension(GeneratorShortCircuit.class); GeneratorField field = GeneratorField.valueOf(generatorField); switch (field) { case MAXIMUM_ACTIVE_POWER -> generator.setMaxP(newValue); @@ -135,15 +134,17 @@ public static void setNewValue(Generator generator, String generatorField, Doubl new AttributeModification<>(newValue.floatValue(), OperationType.SET), null); } - case TRANSIENT_REACTANCE -> generator.newExtension(GeneratorShortCircuitAdder.class) - .withDirectTransX(newValue) - .withStepUpTransformerX(generatorShortCircuit == null ? Double.NaN : generatorShortCircuit.getStepUpTransformerX()) - .add(); - case STEP_UP_TRANSFORMER_REACTANCE -> generator.newExtension(GeneratorShortCircuitAdder.class) - .withDirectTransX(generatorShortCircuit == null ? 0.0D : generatorShortCircuit.getDirectTransX()) - .withStepUpTransformerX(newValue) - .add(); - case Q_PERCENT -> generator.newExtension(CoordinatedReactiveControlAdder.class) + case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes( + new AttributeModification<>(newValue, OperationType.SET), + null, + generator, + null); + case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes( + null, + new AttributeModification<>(newValue, OperationType.SET), + generator, + null); + case Q_PERCENT -> generator.newExtension(CoordinatedReactiveControlAdderImpl.class) .withQPercent(newValue) .add(); } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index 93f148210..f5aa368d4 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -93,53 +93,58 @@ private void modifyGenerator(Generator generator, GeneratorModificationInfos mod modifyGeneratorLimitsAttributes(modificationInfos, generator, subReportNode); modifyGeneratorSetpointsAttributes(modificationInfos, generator, subReportNode); - modifyGeneratorShortCircuitAttributes(modificationInfos, generator, subReportNode); + modifyGeneratorShortCircuitAttributes(modificationInfos.getDirectTransX(), modificationInfos.getStepUpTransformerX(), generator, subReportNode); modifyGeneratorStartUpAttributesAndLog(modificationInfos, generator, subReportNode); modifyGeneratorConnectivityAttributes(modificationInfos, generator, subReportNode); PropertiesUtils.applyProperties(generator, subReportNode, modificationInfos.getProperties(), "GeneratorProperties"); } - private void modifyGeneratorShortCircuitAttributes(GeneratorModificationInfos modificationInfos, - Generator generator, ReportNode subReportNode) { + public static void modifyGeneratorShortCircuitAttributes(AttributeModification directTransX, + AttributeModification stepUpTransformerX, + Generator generator, + ReportNode subReportNode) { List reports = new ArrayList<>(); GeneratorShortCircuit generatorShortCircuit = generator.getExtension(GeneratorShortCircuit.class); Double oldTransientReactance = generatorShortCircuit != null ? generatorShortCircuit.getDirectTransX() : Double.NaN; Double oldStepUpTransformerReactance = generatorShortCircuit != null ? generatorShortCircuit.getStepUpTransformerX() : Double.NaN; // Either transient reactance or step-up transformer reactance are modified or // both - if (modificationInfos.getDirectTransX() != null - && modificationInfos.getStepUpTransformerX() != null) { + if (directTransX != null && stepUpTransformerX != null) { generator.newExtension(GeneratorShortCircuitAdder.class) - .withDirectTransX(modificationInfos.getDirectTransX().getValue()) - .withStepUpTransformerX(modificationInfos.getStepUpTransformerX().getValue()) + .withDirectTransX(directTransX.getValue()) + .withStepUpTransformerX(stepUpTransformerX.getValue()) .add(); reports.add(ModificationUtils.getInstance().buildModificationReport( oldTransientReactance, - modificationInfos.getDirectTransX().getValue(), + directTransX.getValue(), "Transient reactance")); reports.add(ModificationUtils.getInstance().buildModificationReport( oldStepUpTransformerReactance, - modificationInfos.getStepUpTransformerX().getValue(), + stepUpTransformerX.getValue(), "Transformer reactance")); - } else if (modificationInfos.getDirectTransX() != null) { + } else if (directTransX != null) { generator.newExtension(GeneratorShortCircuitAdder.class) - .withDirectTransX(modificationInfos.getDirectTransX().getValue()) + .withStepUpTransformerX(oldStepUpTransformerReactance) + .withDirectTransX(directTransX.getValue()) .add(); reports.add(ModificationUtils.getInstance().buildModificationReport( oldTransientReactance, - modificationInfos.getDirectTransX().getValue(), + directTransX.getValue(), "Transient reactance")); - } else if (modificationInfos.getStepUpTransformerX() != null) { + } else if (stepUpTransformerX != null) { generator.newExtension(GeneratorShortCircuitAdder.class) - .withStepUpTransformerX(modificationInfos.getStepUpTransformerX().getValue()) + .withStepUpTransformerX(stepUpTransformerX.getValue()) + .withDirectTransX(oldTransientReactance) .add(); reports.add(ModificationUtils.getInstance().buildModificationReport( oldStepUpTransformerReactance, - modificationInfos.getStepUpTransformerX().getValue(), + stepUpTransformerX.getValue(), "Transformer reactance")); } - ModificationUtils.getInstance().reportModifications(subReportNode, reports, "shortCircuitAttributesModified", "Short-circuit", Map.of()); + if (subReportNode != null) { + ModificationUtils.getInstance().reportModifications(subReportNode, reports, "shortCircuitAttributesModified", "Short-circuit", Map.of()); + } } private void modifyGeneratorReactiveCapabilityCurvePoints(GeneratorModificationInfos modificationInfos, From 3c1c0fad3d88151ed7b908bf553deee8ef892303 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Mon, 2 Sep 2024 13:42:03 +0200 Subject: [PATCH 05/23] shunt compensator MAXIMUM_SECTION_COUNT Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/ShuntCompensatorField.java | 11 ++++---- .../ShuntCompensatorModification.java | 28 ++++++++++++++----- 2 files changed, 27 insertions(+), 12 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java index e155d4720..d70c5e4fb 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java @@ -12,6 +12,10 @@ import com.powsybl.iidm.network.ShuntCompensatorModelType; import com.powsybl.iidm.network.VoltageLevel; import org.gridsuite.modification.server.NetworkModificationException; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; + +import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaximumSectionCount; /** * @author Seddik Yengui @@ -43,11 +47,8 @@ public static void setNewValue(ShuntCompensator shuntCompensator, String shuntCo ShuntCompensatorField field = ShuntCompensatorField.valueOf(shuntCompensatorField); VoltageLevel voltageLevel = shuntCompensator.getTerminal().getVoltageLevel(); switch (field) { - case MAXIMUM_SECTION_COUNT -> { - int maximumSectionCount = newValue.intValue(); - model.setBPerSection(model.getBPerSection() * shuntCompensator.getMaximumSectionCount() / maximumSectionCount); - model.setMaximumSectionCount(maximumSectionCount); - } + case MAXIMUM_SECTION_COUNT -> modifyMaximumSectionCount(new AttributeModification<>(newValue.intValue(), OperationType.SET), + null, null, null, shuntCompensator, model); case SECTION_COUNT -> shuntCompensator.setSectionCount(newValue.intValue()); case MAXIMUM_SUSCEPTANCE -> model.setBPerSection(newValue / shuntCompensator.getMaximumSectionCount()); case MAXIMUM_Q_AT_NOMINAL_VOLTAGE -> { diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java index 25aaebe37..2f1dd346d 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java @@ -13,6 +13,7 @@ import com.powsybl.iidm.network.extensions.ConnectablePosition; import com.powsybl.iidm.network.extensions.ConnectablePositionAdder; import org.gridsuite.modification.server.NetworkModificationException; +import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.ShuntCompensatorModificationInfos; import org.gridsuite.modification.server.dto.ShuntCompensatorType; @@ -81,13 +82,20 @@ public void apply(Network network, ReportNode subReportNode) { PropertiesUtils.applyProperties(shuntCompensator, subReportNode, modificationInfos.getProperties(), "ShuntCompensatorProperties"); } - private void modifyMaximumSectionCount(List reports, ShuntCompensator shuntCompensator, ShuntCompensatorLinearModel model) { - if (modificationInfos.getMaximumSectionCount() != null) { - var maximumSectionCount = modificationInfos.getMaximumSectionCount().getValue(); - if (modificationInfos.getMaxSusceptance() == null && modificationInfos.getMaxQAtNominalV() == null) { + public static void modifyMaximumSectionCount(AttributeModification maximumSectionCountModif, + AttributeModification maxSusceptance, + AttributeModification maxQAtNominalV, + List reports, + ShuntCompensator shuntCompensator, + ShuntCompensatorLinearModel model) { + if (maximumSectionCountModif != null) { + var maximumSectionCount = maximumSectionCountModif.getValue(); + if (maxSusceptance == null && maxQAtNominalV == null) { model.setBPerSection(model.getBPerSection() * shuntCompensator.getMaximumSectionCount() / maximumSectionCount); } - reports.add(ModificationUtils.getInstance().buildModificationReport(shuntCompensator.getMaximumSectionCount(), maximumSectionCount, "Maximum section count")); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(shuntCompensator.getMaximumSectionCount(), maximumSectionCount, "Maximum section count")); + } model.setMaximumSectionCount(maximumSectionCount); } } @@ -119,9 +127,15 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe // when maximum section count old value is greater than the new one if (modificationInfos.getMaximumSectionCount() != null && modificationInfos.getMaximumSectionCount().getValue() < shuntCompensator.getMaximumSectionCount()) { modifySectionCount(reports, shuntCompensator); - modifyMaximumSectionCount(reports, shuntCompensator, model); + modifyMaximumSectionCount(modificationInfos.getMaximumSectionCount(), + modificationInfos.getMaxSusceptance(), + modificationInfos.getMaxQAtNominalV(), + reports, shuntCompensator, model); } else { - modifyMaximumSectionCount(reports, shuntCompensator, model); + modifyMaximumSectionCount(modificationInfos.getMaximumSectionCount(), + modificationInfos.getMaxSusceptance(), + modificationInfos.getMaxQAtNominalV(), + reports, shuntCompensator, model); modifySectionCount(reports, shuntCompensator); } From f4a62ebb45c9e3b8343abc498acb1752f814b374 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Mon, 2 Sep 2024 15:52:43 +0200 Subject: [PATCH 06/23] shunt compensator Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/ShuntCompensatorField.java | 17 +++-- .../ShuntCompensatorModification.java | 66 +++++++++++++------ 2 files changed, 55 insertions(+), 28 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java index d70c5e4fb..5b60793cb 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java @@ -14,8 +14,12 @@ import org.gridsuite.modification.server.NetworkModificationException; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; +import org.gridsuite.modification.server.dto.ShuntCompensatorType; +import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaxSusceptance; +import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaximumQAtNominalVoltage; import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaximumSectionCount; +import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifySectionCount; /** * @author Seddik Yengui @@ -46,16 +50,15 @@ public static void setNewValue(ShuntCompensator shuntCompensator, String shuntCo ShuntCompensatorLinearModel model = shuntCompensator.getModel(ShuntCompensatorLinearModel.class); ShuntCompensatorField field = ShuntCompensatorField.valueOf(shuntCompensatorField); VoltageLevel voltageLevel = shuntCompensator.getTerminal().getVoltageLevel(); + var shuntCompensatorType = model.getBPerSection() > 0 ? ShuntCompensatorType.CAPACITOR : ShuntCompensatorType.REACTOR; switch (field) { case MAXIMUM_SECTION_COUNT -> modifyMaximumSectionCount(new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null, shuntCompensator, model); - case SECTION_COUNT -> shuntCompensator.setSectionCount(newValue.intValue()); - case MAXIMUM_SUSCEPTANCE -> model.setBPerSection(newValue / shuntCompensator.getMaximumSectionCount()); - case MAXIMUM_Q_AT_NOMINAL_VOLTAGE -> { - double newQatNominalV = newValue / shuntCompensator.getMaximumSectionCount(); - double newSusceptancePerSection = newQatNominalV / Math.pow(voltageLevel.getNominalV(), 2); - model.setBPerSection(newSusceptancePerSection); - } + case SECTION_COUNT -> modifySectionCount(new AttributeModification<>(newValue.intValue(), OperationType.SET), null, shuntCompensator); + case MAXIMUM_SUSCEPTANCE -> modifyMaxSusceptance(new AttributeModification<>(newValue, OperationType.SET), + shuntCompensator.getMaximumSectionCount(), null, model); + case MAXIMUM_Q_AT_NOMINAL_VOLTAGE -> modifyMaximumQAtNominalVoltage(new AttributeModification<>(newValue, OperationType.SET), + voltageLevel, shuntCompensator.getMaximumSectionCount(), null, model, shuntCompensatorType); } } } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java index 2f1dd346d..67c7cbe76 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java @@ -100,10 +100,12 @@ public static void modifyMaximumSectionCount(AttributeModification maxi } } - private void modifySectionCount(List reports, ShuntCompensator shuntCompensator) { - if (modificationInfos.getSectionCount() != null) { - var newSectionCount = modificationInfos.getSectionCount().getValue(); - reports.add(ModificationUtils.getInstance().buildModificationReport(shuntCompensator.getSectionCount(), newSectionCount, "Section count")); + public static void modifySectionCount(AttributeModification sectionCount, List reports, ShuntCompensator shuntCompensator) { + if (sectionCount != null) { + var newSectionCount = sectionCount.getValue(); + if (reports != null) { + reports.add(ModificationUtils.getInstance().buildModificationReport(shuntCompensator.getSectionCount(), newSectionCount, "Section count")); + } shuntCompensator.setSectionCount(newSectionCount); } } @@ -114,7 +116,6 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe var shuntCompensatorType = model.getBPerSection() > 0 ? ShuntCompensatorType.CAPACITOR : ShuntCompensatorType.REACTOR; double oldSusceptancePerSection = model.getBPerSection(); double oldQAtNominalV = Math.abs(Math.pow(voltageLevel.getNominalV(), 2) * oldSusceptancePerSection); - double oldMaxSusceptance = oldSusceptancePerSection * shuntCompensator.getMaximumSectionCount(); double oldMaxQAtNominalV = oldQAtNominalV * shuntCompensator.getMaximumSectionCount(); double oldSwitchedOnSusceptance = oldSusceptancePerSection * shuntCompensator.getSectionCount(); double oldSwitchedOnQAtNominalV = oldQAtNominalV * shuntCompensator.getSectionCount(); @@ -126,7 +127,7 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe // due to cross validation between maximum section count and section count, we need to modify section count first // when maximum section count old value is greater than the new one if (modificationInfos.getMaximumSectionCount() != null && modificationInfos.getMaximumSectionCount().getValue() < shuntCompensator.getMaximumSectionCount()) { - modifySectionCount(reports, shuntCompensator); + modifySectionCount(modificationInfos.getSectionCount(), reports, shuntCompensator); modifyMaximumSectionCount(modificationInfos.getMaximumSectionCount(), modificationInfos.getMaxSusceptance(), modificationInfos.getMaxQAtNominalV(), @@ -136,7 +137,7 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe modificationInfos.getMaxSusceptance(), modificationInfos.getMaxQAtNominalV(), reports, shuntCompensator, model); - modifySectionCount(reports, shuntCompensator); + modifySectionCount(modificationInfos.getSectionCount(), reports, shuntCompensator); } int maximumSectionCount = modificationInfos.getMaximumSectionCount() != null ? modificationInfos.getMaximumSectionCount().getValue() : shuntCompensator.getMaximumSectionCount(); @@ -154,22 +155,10 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe } if (modificationInfos.getMaxQAtNominalV() != null) { - if (modificationInfos.getMaxQAtNominalV().getValue() < 0) { - throw new NetworkModificationException(NetworkModificationException.Type.MODIFY_SHUNT_COMPENSATOR_ERROR, - "Qmax at nominal voltage should be greater or equal to 0"); - } - double newQatNominalV = modificationInfos.getMaxQAtNominalV().getValue() / maximumSectionCount; - double newSusceptancePerSection = newQatNominalV / Math.pow(voltageLevel.getNominalV(), 2); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldMaxQAtNominalV, modificationInfos.getMaxQAtNominalV().getValue(), "Qmax available at nominal voltage")); - - model.setBPerSection(shuntCompensatorType == ShuntCompensatorType.CAPACITOR ? newSusceptancePerSection : -newSusceptancePerSection); + modifyMaximumQAtNominalVoltage(modificationInfos.getMaxQAtNominalV(), voltageLevel, maximumSectionCount, reports, model, shuntCompensatorType); } - if (modificationInfos.getMaxSusceptance() != null) { - double newSusceptancePerSection = modificationInfos.getMaxSusceptance().getValue() / maximumSectionCount; - reports.add(ModificationUtils.getInstance().buildModificationReport(oldMaxSusceptance, modificationInfos.getMaxSusceptance().getValue(), "Maximal susceptance available")); - - model.setBPerSection(newSusceptancePerSection); + modifyMaxSusceptance(modificationInfos.getMaxSusceptance(), maximumSectionCount, reports, model); } reportSwitchedOnAndPerSectionValues(reports, oldQAtNominalV, oldSwitchedOnQAtNominalV, oldSusceptancePerSection, oldSwitchedOnSusceptance, oldMaxQAtNominalV, sectionCount, maximumSectionCount); @@ -177,6 +166,41 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe reports.forEach(report -> insertReportNode(subReportNode, report)); } + public static void modifyMaxSusceptance(AttributeModification maxSusceptance, + int maximumSectionCount, + List reports, + ShuntCompensatorLinearModel model) { + double newSusceptancePerSection = maxSusceptance.getValue() / maximumSectionCount; + if (reports != null) { + double oldSusceptancePerSection = model.getBPerSection(); + double oldMaxSusceptance = oldSusceptancePerSection * maximumSectionCount; + reports.add(ModificationUtils.getInstance().buildModificationReport(oldMaxSusceptance, maxSusceptance.getValue(), "Maximal susceptance available")); + } + model.setBPerSection(newSusceptancePerSection); + } + + public static void modifyMaximumQAtNominalVoltage(AttributeModification maxQAtNominalV, + VoltageLevel voltageLevel, + int maximumSectionCount, + List reports, + ShuntCompensatorLinearModel model, + ShuntCompensatorType shuntCompensatorType) { + if (maxQAtNominalV.getValue() < 0) { + throw new NetworkModificationException(NetworkModificationException.Type.MODIFY_SHUNT_COMPENSATOR_ERROR, + "Qmax at nominal voltage should be greater or equal to 0"); + } + double newQatNominalV = maxQAtNominalV.getValue() / maximumSectionCount; + double newSusceptancePerSection = newQatNominalV / Math.pow(voltageLevel.getNominalV(), 2); + if (reports != null) { + double oldSusceptancePerSection = model.getBPerSection(); + double oldQAtNominalV = Math.abs(Math.pow(voltageLevel.getNominalV(), 2) * oldSusceptancePerSection); + double oldMaxQAtNominalV = oldQAtNominalV * maximumSectionCount; + reports.add(ModificationUtils.getInstance().buildModificationReport(oldMaxQAtNominalV, maxQAtNominalV.getValue(), "Qmax available at nominal voltage")); + } + + model.setBPerSection(shuntCompensatorType == ShuntCompensatorType.CAPACITOR ? newSusceptancePerSection : -newSusceptancePerSection); + } + private void reportSwitchedOnAndPerSectionValues(List reports, double oldQAtNominalV, double oldSwitchedOnQAtNominalV, double oldSusceptancePerSection, double oldSwitchedOnSusceptance, double oldMaxQAtNominalV, int sectionCount, int maximumSectionCount) { if (modificationInfos.getMaxQAtNominalV() != null) { double newQatNominalV = modificationInfos.getMaxQAtNominalV().getValue() / maximumSectionCount; From 52a7eeb18d10e8ad64f964b114f57f4b95d7b8e9 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Mon, 2 Sep 2024 16:47:55 +0200 Subject: [PATCH 07/23] VoltageLevelFields Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/VoltageLevelField.java | 24 +++++++------------ .../VoltageLevelModification.java | 22 ++++++++++------- 2 files changed, 22 insertions(+), 24 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java index a1fc1d644..3338e144f 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java @@ -9,7 +9,10 @@ import com.powsybl.iidm.network.VoltageLevel; import com.powsybl.iidm.network.extensions.IdentifiableShortCircuit; -import com.powsybl.iidm.network.extensions.IdentifiableShortCircuitAdder; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; + +import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyVoltageLevelShortCircuit; /** * @author Seddik Yengui @@ -35,26 +38,15 @@ public static Double getReferenceValue(VoltageLevel voltageLevel, String voltage } public static void setNewValue(VoltageLevel voltageLevel, String voltageLevelField, Double newValue) { - IdentifiableShortCircuit identifiableShortCircuit = voltageLevel.getExtension(IdentifiableShortCircuit.class); VoltageLevelField field = VoltageLevelField.valueOf(voltageLevelField); switch (field) { case NOMINAL_VOLTAGE -> voltageLevel.setNominalV(newValue); case LOW_VOLTAGE_LIMIT -> voltageLevel.setLowVoltageLimit(newValue); case HIGH_VOLTAGE_LIMIT -> voltageLevel.setHighVoltageLimit(newValue); - case LOW_SHORT_CIRCUIT_CURRENT_LIMIT -> { - IdentifiableShortCircuitAdder adder = voltageLevel.newExtension(IdentifiableShortCircuitAdder.class).withIpMin(newValue); - if (identifiableShortCircuit != null) { - adder.withIpMax(identifiableShortCircuit.getIpMax()); - } - adder.add(); - } - case HIGH_SHORT_CIRCUIT_CURRENT_LIMIT -> { - IdentifiableShortCircuitAdder adder = voltageLevel.newExtension(IdentifiableShortCircuitAdder.class).withIpMax(newValue); - if (identifiableShortCircuit != null) { - adder.withIpMin(identifiableShortCircuit.getIpMin()); - } - adder.add(); - } + case LOW_SHORT_CIRCUIT_CURRENT_LIMIT -> modifyVoltageLevelShortCircuit( + new AttributeModification<>(newValue, OperationType.SET), null, null, voltageLevel); + case HIGH_SHORT_CIRCUIT_CURRENT_LIMIT -> modifyVoltageLevelShortCircuit( + null, new AttributeModification<>(newValue, OperationType.SET), null, voltageLevel); } } } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index 7bbd83e8b..68a0cd82a 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -13,6 +13,7 @@ import com.powsybl.iidm.network.extensions.IdentifiableShortCircuit; import com.powsybl.iidm.network.extensions.IdentifiableShortCircuitAdder; import org.gridsuite.modification.server.NetworkModificationException; +import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.VoltageLevelModificationInfos; import java.util.ArrayList; import java.util.List; @@ -88,20 +89,23 @@ public void apply(Network network, ReportNode subReportNode) { ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setLowVoltageLimit, voltageLevel::getLowVoltageLimit, modificationInfos.getLowVoltageLimit(), subReportNode, "Low voltage limit"); ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setHighVoltageLimit, voltageLevel::getHighVoltageLimit, modificationInfos.getHighVoltageLimit(), subReportNode, "High voltage limit"); - modifyVoltageLevelShortCircuit(subReportNode, voltageLevel); + modifyVoltageLevelShortCircuit(modificationInfos.getIpMin(), modificationInfos.getIpMax(), subReportNode, voltageLevel); PropertiesUtils.applyProperties(voltageLevel, subReportNode, modificationInfos.getProperties(), "VlProperties"); } - private void modifyVoltageLevelShortCircuit(ReportNode subReportNode, VoltageLevel voltageLevel) { - if (modificationInfos.getIpMin() != null || modificationInfos.getIpMax() != null) { + public static void modifyVoltageLevelShortCircuit(AttributeModification ipMin, + AttributeModification ipMax, + ReportNode subReportNode, + VoltageLevel voltageLevel) { + if (ipMin != null || ipMax != null) { List reports = new ArrayList<>(); IdentifiableShortCircuit identifiableShortCircuit = voltageLevel.getExtension(IdentifiableShortCircuit.class); IdentifiableShortCircuitAdder identifiableShortCircuitAdder = voltageLevel.newExtension(IdentifiableShortCircuitAdder.class); var oldIpMin = identifiableShortCircuit == null ? null : identifiableShortCircuit.getIpMin(); var oldIpMax = identifiableShortCircuit == null ? null : identifiableShortCircuit.getIpMax(); - if (modificationInfos.getIpMin() != null) { - var newIpMin = modificationInfos.getIpMin().getValue(); + if (ipMin != null) { + var newIpMin = ipMin.getValue(); identifiableShortCircuitAdder.withIpMin(newIpMin); @@ -115,8 +119,8 @@ private void modifyVoltageLevelShortCircuit(ReportNode subReportNode, VoltageLev identifiableShortCircuitAdder.withIpMin(oldIpMin); } - if (modificationInfos.getIpMax() != null) { - var newIpMax = modificationInfos.getIpMax().getValue(); + if (ipMax != null) { + var newIpMax = ipMax.getValue(); identifiableShortCircuitAdder.withIpMax(newIpMax); //Convert to kA to report it like the user set it. @@ -129,7 +133,9 @@ private void modifyVoltageLevelShortCircuit(ReportNode subReportNode, VoltageLev } identifiableShortCircuitAdder.add(); - reports.forEach(report -> insertReportNode(subReportNode, report)); + if (subReportNode != null) { + reports.forEach(report -> insertReportNode(subReportNode, report)); + } } } } From 4dcf358660b8a9d6223f377ad54b6c76d97db602 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Mon, 2 Sep 2024 17:09:09 +0200 Subject: [PATCH 08/23] reduce modifyVoltageLevelShortCircuit code complexity Signed-off-by: Mathieu DEHARBE --- .../VoltageLevelModification.java | 79 ++++++++++--------- 1 file changed, 42 insertions(+), 37 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index 68a0cd82a..5c243a233 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -97,45 +97,50 @@ public static void modifyVoltageLevelShortCircuit(AttributeModification AttributeModification ipMax, ReportNode subReportNode, VoltageLevel voltageLevel) { - if (ipMin != null || ipMax != null) { - List reports = new ArrayList<>(); - IdentifiableShortCircuit identifiableShortCircuit = voltageLevel.getExtension(IdentifiableShortCircuit.class); - IdentifiableShortCircuitAdder identifiableShortCircuitAdder = voltageLevel.newExtension(IdentifiableShortCircuitAdder.class); - var oldIpMin = identifiableShortCircuit == null ? null : identifiableShortCircuit.getIpMin(); - var oldIpMax = identifiableShortCircuit == null ? null : identifiableShortCircuit.getIpMax(); - - if (ipMin != null) { - var newIpMin = ipMin.getValue(); - - identifiableShortCircuitAdder.withIpMin(newIpMin); - - //convert to kA to report it like the user set it. - var oldIpMinToReport = oldIpMin != null ? oldIpMin * 0.001 : null; - var newIpMinToReport = newIpMin * 0.001; - - reports.add(ModificationUtils.getInstance() - .buildModificationReport(oldIpMinToReport, newIpMinToReport, "Low short circuit current limit")); - } else if (oldIpMin != null) { - identifiableShortCircuitAdder.withIpMin(oldIpMin); - } + if (ipMin == null && ipMax == null) { + return; + } - if (ipMax != null) { - var newIpMax = ipMax.getValue(); - identifiableShortCircuitAdder.withIpMax(newIpMax); - - //Convert to kA to report it like the user set it. - var oldIpMaxToReport = oldIpMax != null ? oldIpMax * 0.001 : null; - var newIpMaxToReport = newIpMax * 0.001; - reports.add(ModificationUtils.getInstance() - .buildModificationReport(oldIpMaxToReport, newIpMaxToReport, "High short circuit current limit")); - } else if (oldIpMax != null) { - identifiableShortCircuitAdder.withIpMax(oldIpMax); - } + List reports = new ArrayList<>(); + IdentifiableShortCircuitAdder identifiableShortCircuitAdder = voltageLevel.newExtension(IdentifiableShortCircuitAdder.class); + Double oldIpMin = null; + Double oldIpMax = null; + IdentifiableShortCircuit identifiableShortCircuit = voltageLevel.getExtension(IdentifiableShortCircuit.class); + if (identifiableShortCircuit != null) { + oldIpMin = identifiableShortCircuit.getIpMin(); + oldIpMax = identifiableShortCircuit.getIpMax(); + } - identifiableShortCircuitAdder.add(); - if (subReportNode != null) { - reports.forEach(report -> insertReportNode(subReportNode, report)); - } + if (ipMin != null) { + var newIpMin = ipMin.getValue(); + + identifiableShortCircuitAdder.withIpMin(newIpMin); + + //convert to kA to report it like the user set it. + var oldIpMinToReport = oldIpMin != null ? oldIpMin * 0.001 : null; + var newIpMinToReport = newIpMin * 0.001; + reports.add(ModificationUtils.getInstance() + .buildModificationReport(oldIpMinToReport, newIpMinToReport, "Low short circuit current limit")); + } else if (oldIpMin != null) { + identifiableShortCircuitAdder.withIpMin(oldIpMin); + } + + if (ipMax != null) { + var newIpMax = ipMax.getValue(); + identifiableShortCircuitAdder.withIpMax(newIpMax); + + //Convert to kA to report it like the user set it. + var oldIpMaxToReport = oldIpMax != null ? oldIpMax * 0.001 : null; + var newIpMaxToReport = newIpMax * 0.001; + reports.add(ModificationUtils.getInstance() + .buildModificationReport(oldIpMaxToReport, newIpMaxToReport, "High short circuit current limit")); + } else if (oldIpMax != null) { + identifiableShortCircuitAdder.withIpMax(oldIpMax); + } + + identifiableShortCircuitAdder.add(); + if (subReportNode != null) { + reports.forEach(report -> insertReportNode(subReportNode, report)); } } } From 2ce33edbdd60ba155e254085d2d61c60af761770 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 13:24:48 +0200 Subject: [PATCH 09/23] always send formulaReports Signed-off-by: Mathieu DEHARBE --- .../server/modifications/ByFormulaModification.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java index 774ce6373..f581d39ba 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java @@ -98,7 +98,6 @@ public void apply(Network network, ReportNode subReportNode) { .withUntypedValue(KEY_VALUE, equipmentCount) .withSeverity(TypedValue.INFO_SEVERITY) .add(); - report(formulaSubReporter, formulaReports); } else { if (equipmentNotModifiedCount == equipmentCount) { createReport(subReportNode, "byFormulaModificationNone", @@ -111,9 +110,9 @@ public void apply(Network network, ReportNode subReportNode) { .withUntypedValue(KEY_NB_UNCHANGED, equipmentNotModifiedCount + equipmentNotFoundCount) .withSeverity(TypedValue.WARN_SEVERITY) .add(); - report(formulaSubReporter, formulaReports); } } + report(formulaSubReporter, formulaReports); } } From c3bbff89386ae7186c2cbd7f4d26b9efecda3762 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 16:08:02 +0200 Subject: [PATCH 10/23] refacto BatteryField Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 25 +++++++++-- .../equipmentfield/GeneratorField.java | 1 + .../modifications/BatteryModification.java | 44 ++++++++++++------- .../modifications/GeneratorModification.java | 2 +- .../modifications/ModificationUtils.java | 32 +++++--------- 5 files changed, 61 insertions(+), 43 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index e8d27f76d..cf94bb81f 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -15,6 +15,8 @@ import org.gridsuite.modification.server.modifications.ModificationUtils; import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; +import static org.gridsuite.modification.server.modifications.BatteryModification.modifyBatteryActiveLimitsAttributes; +import static org.gridsuite.modification.server.modifications.BatteryModification.modifyBatterySetpointsAttributes; /** * @author Seddik Yengui @@ -42,8 +44,18 @@ public static Double getReferenceValue(Battery battery, String batteryField) { public static void setNewValue(Battery battery, String batteryField, Double newValue) { BatteryField field = BatteryField.valueOf(batteryField); switch (field) { - case MINIMUM_ACTIVE_POWER -> battery.setMinP(newValue); - case MAXIMUM_ACTIVE_POWER -> battery.setMaxP(newValue); + case MINIMUM_ACTIVE_POWER -> + modifyBatteryActiveLimitsAttributes( + null, + new AttributeModification<>(newValue, OperationType.SET), + battery, + null); + case MAXIMUM_ACTIVE_POWER -> + modifyBatteryActiveLimitsAttributes( + new AttributeModification<>(newValue, OperationType.SET), + null, + battery, + null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( new AttributeModification<>(newValue, OperationType.SET), @@ -55,9 +67,13 @@ public static void setNewValue(Battery battery, String batteryField, Double newV MODIFY_GENERATOR_ERROR, "Battery '" + battery.getId() + "' : " ); - battery.setTargetP(newValue); + modifyBatterySetpointsAttributes( + new AttributeModification<>(newValue, OperationType.SET), null, null, null, + battery, null); } - case REACTIVE_POWER_SET_POINT -> battery.setTargetQ(newValue); + case REACTIVE_POWER_SET_POINT -> modifyBatterySetpointsAttributes( + null, new AttributeModification<>(newValue, OperationType.SET), null, null, + battery, null); case DROOP -> { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); @@ -66,6 +82,7 @@ public static void setNewValue(Battery battery, String batteryField, Double newV activePowerControlAdder, null, new AttributeModification<>(newValue.floatValue(), OperationType.SET), + null, null); } } diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 427afef97..5988584d2 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -132,6 +132,7 @@ public static void setNewValue(Generator generator, String generatorField, Doubl activePowerControlAdder, null, new AttributeModification<>(newValue.floatValue(), OperationType.SET), + null, null); } case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes( diff --git a/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java b/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java index ab1c1ef04..1ac388c8f 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/BatteryModification.java @@ -18,6 +18,7 @@ import com.powsybl.iidm.network.extensions.ConnectablePosition; import com.powsybl.iidm.network.extensions.ConnectablePositionAdder; import org.gridsuite.modification.server.NetworkModificationException; +import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.BatteryModificationInfos; import org.gridsuite.modification.server.dto.ReactiveCapabilityCurveModificationInfos; @@ -86,17 +87,24 @@ private void modifyBattery(Battery battery, BatteryModificationInfos modificatio } modifyBatteryLimitsAttributes(modificationInfos, battery, subReportNode); - modifyBatterySetpointsAttributes(modificationInfos, battery, subReportNode); + modifyBatterySetpointsAttributes( + modificationInfos.getTargetP(), modificationInfos.getTargetQ(), + modificationInfos.getParticipate(), modificationInfos.getDroop(), + battery, subReportNode); modifyBatteryConnectivityAttributes(modificationInfos, battery, subReportNode); PropertiesUtils.applyProperties(battery, subReportNode, modificationInfos.getProperties(), "BatteryProperties"); } - private void modifyBatterySetpointsAttributes(BatteryModificationInfos modificationInfos, - Battery battery, ReportNode subReportNode) { - ReportNode reportActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setTargetP, battery::getTargetP, modificationInfos.getTargetP(), "Active power"); - ReportNode reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setTargetQ, battery::getTargetQ, modificationInfos.getTargetQ(), "Reactive power"); + public static void modifyBatterySetpointsAttributes(AttributeModification targetP, + AttributeModification targetQ, + AttributeModification participate, + AttributeModification droop, + Battery battery, + ReportNode subReportNode) { + ReportNode reportActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setTargetP, battery::getTargetP, targetP, "Active power"); + ReportNode reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setTargetQ, battery::getTargetQ, targetQ, "Reactive power"); ReportNode subReporterSetpoints = null; - if (reportActivePower != null || reportReactivePower != null) { + if (subReportNode != null && (reportActivePower != null || reportReactivePower != null)) { subReporterSetpoints = subReportNode.newReportNode().withMessageTemplate(SETPOINTS, SETPOINTS).add(); subReporterSetpoints.newReportNode() .withMessageTemplate(SETPOINTS, SETPOINTS) @@ -109,12 +117,12 @@ private void modifyBatterySetpointsAttributes(BatteryModificationInfos modificat insertReportNode(subReporterSetpoints, reportReactivePower); } } - modifyBatteryActivePowerControlAttributes(modificationInfos, battery, subReportNode, subReporterSetpoints); + modifyBatteryActivePowerControlAttributes(participate, droop, battery, subReportNode, subReporterSetpoints); } private void modifyBatteryLimitsAttributes(BatteryModificationInfos modificationInfos, Battery battery, ReportNode subReportNode) { - ReportNode subReportNodeLimits = modifyBatteryActiveLimitsAttributes(modificationInfos, battery, subReportNode); + ReportNode subReportNodeLimits = modifyBatteryActiveLimitsAttributes(modificationInfos.getMaxP(), modificationInfos.getMinP(), battery, subReportNode); modifyBatteryReactiveLimitsAttributes(modificationInfos, battery, subReportNode, subReportNodeLimits); } @@ -127,12 +135,13 @@ private void modifyBatteryReactiveCapabilityCurvePoints(BatteryModificationInfos ModificationUtils.getInstance().modifyReactiveCapabilityCurvePoints(points, modificationPoints, adder, subReportNode, subReportNodeLimits); } - private ReportNode modifyBatteryActiveLimitsAttributes(BatteryModificationInfos modificationInfos, - Battery battery, ReportNode subReportNode) { + public static ReportNode modifyBatteryActiveLimitsAttributes(AttributeModification maxP, + AttributeModification minP, + Battery battery, ReportNode subReportNode) { ReportNode subReportNodeLimits = null; - ReportNode reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setMaxP, battery::getMaxP, modificationInfos.getMaxP(), "Max active power"); - ReportNode reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setMinP, battery::getMinP, modificationInfos.getMinP(), "Min active power"); - if (reportMaxActivePower != null || reportMinActivePower != null) { + ReportNode reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setMaxP, battery::getMaxP, maxP, "Max active power"); + ReportNode reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(battery::setMinP, battery::getMinP, minP, "Min active power"); + if (subReportNode != null && (reportMaxActivePower != null || reportMinActivePower != null)) { subReportNodeLimits = subReportNode.newReportNode().withMessageTemplate(LIMITS, LIMITS).add(); subReportNodeLimits.newReportNode() .withMessageTemplate(LIMITS, LIMITS) @@ -168,11 +177,14 @@ private void modifyBatteryReactiveLimitsAttributes(BatteryModificationInfos modi } } - private ReportNode modifyBatteryActivePowerControlAttributes(BatteryModificationInfos modificationInfos, - Battery battery, ReportNode subReportNode, ReportNode subReportNodeSetpoints) { + public static ReportNode modifyBatteryActivePowerControlAttributes(AttributeModification participate, + AttributeModification droop, + Battery battery, + ReportNode subReportNode, + ReportNode subReportNodeSetpoints) { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); - return ModificationUtils.getInstance().modifyActivePowerControlAttributesAndLog(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); + return ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, participate, droop, subReportNode, subReportNodeSetpoints); } private ReportNode modifyBatteryConnectivityAttributes(BatteryModificationInfos modificationInfos, diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index f5aa368d4..eca93e855 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -217,7 +217,7 @@ private ReportNode modifyGeneratorActivePowerControlAttributes(GeneratorModifica Generator generator, ReportNode subReportNode, ReportNode subReportNodeSetpoints) { ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); - return ModificationUtils.getInstance().modifyActivePowerControlAttributesAndLog(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); + return ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); } private void modifyGeneratorStartUpAttributesAndLog(GeneratorModificationInfos modificationInfos, Generator generator, diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index 0dcd805d8..b060018dc 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -1025,33 +1025,21 @@ private void createNewActivePowerControl(ActivePowerControlAdder adder, adder.add(); } - /** - * @param reports Data changes will be added to this list. The array may be null but no modification report will be created - */ - public void modifyActivePowerControlAttributes(ActivePowerControl activePowerControl, - ActivePowerControlAdder activePowerControlAdder, - AttributeModification participateInfo, - AttributeModification droopInfo, - List reports) { + public ReportNode modifyActivePowerControlAttributes(ActivePowerControl activePowerControl, + ActivePowerControlAdder activePowerControlAdder, + AttributeModification participateInfo, + AttributeModification droopInfo, + ReportNode subReportNode, + ReportNode subReporterSetpoints) { + List reports = new ArrayList<>(); if (activePowerControl != null) { modifyExistingActivePowerControl(activePowerControl, participateInfo, droopInfo, reports); } else { createNewActivePowerControl(activePowerControlAdder, participateInfo, droopInfo, reports); } - } - - public ReportNode modifyActivePowerControlAttributesAndLog(ActivePowerControl activePowerControl, - ActivePowerControlAdder activePowerControlAdder, - AttributeModification participateInfo, - AttributeModification droopInfo, - ReportNode subReportNode, - ReportNode subReporterSetpoints) { - List reports = new ArrayList<>(); - modifyActivePowerControlAttributes(activePowerControl, - activePowerControlAdder, - participateInfo, - droopInfo, - reports); + if (subReportNode == null) { + return null; + } ReportNode subReportNodeSetpoints2 = subReporterSetpoints; if (subReporterSetpoints == null && !reports.isEmpty()) { From fe01d837b85ce6d8cad860bcd9ea8fbfca029ec6 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 16:55:08 +0200 Subject: [PATCH 11/23] refacto GeneratorField Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/GeneratorField.java | 25 +++++-- .../modifications/GeneratorModification.java | 72 ++++++++++++------- 2 files changed, 65 insertions(+), 32 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 5988584d2..c2587cac5 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -19,8 +19,11 @@ import org.gridsuite.modification.server.modifications.ModificationUtils; import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; +import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorActiveLimitsAttributes; import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorShortCircuitAttributes; import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorStartUpAttributes; +import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyTargetQ; +import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyTargetV; /** * @author Seddik Yengui @@ -70,8 +73,16 @@ public static void setNewValue(Generator generator, String generatorField, Doubl if (!Double.isNaN(newValue)) { GeneratorField field = GeneratorField.valueOf(generatorField); switch (field) { - case MAXIMUM_ACTIVE_POWER -> generator.setMaxP(newValue); - case MINIMUM_ACTIVE_POWER -> generator.setMinP(newValue); + case MAXIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(new AttributeModification<>(newValue, OperationType.SET), + null, + null, + generator, + null); + case MINIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(null, + new AttributeModification<>(newValue, OperationType.SET), + null, + generator, + null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( new AttributeModification<>(newValue, OperationType.SET), @@ -85,9 +96,13 @@ public static void setNewValue(Generator generator, String generatorField, Doubl ); generator.setTargetP(newValue); } - case RATED_NOMINAL_POWER -> generator.setRatedS(newValue); - case REACTIVE_POWER_SET_POINT -> generator.setTargetQ(newValue); - case VOLTAGE_SET_POINT -> generator.setTargetV(newValue); + case RATED_NOMINAL_POWER -> modifyGeneratorActiveLimitsAttributes(null, + null, + new AttributeModification<>(newValue, OperationType.SET), + generator, + null); + case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, new AttributeModification<>(newValue, OperationType.SET)); + case VOLTAGE_SET_POINT -> modifyTargetV(generator, new AttributeModification<>(newValue, OperationType.SET)); case PLANNED_ACTIVE_POWER_SET_POINT -> modifyGeneratorStartUpAttributes( new AttributeModification<>(newValue, OperationType.SET), diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index eca93e855..6fec37804 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -155,22 +155,25 @@ private void modifyGeneratorReactiveCapabilityCurvePoints(GeneratorModificationI ModificationUtils.getInstance().modifyReactiveCapabilityCurvePoints(points, modificationPoints, adder, subReportNode, subReportNodeLimits); } - private ReportNode modifyGeneratorActiveLimitsAttributes(GeneratorModificationInfos modificationInfos, - Generator generator, ReportNode subReportNode) { + public static ReportNode modifyGeneratorActiveLimitsAttributes(AttributeModification maxP, + AttributeModification minP, + AttributeModification ratedS, + Generator generator, + ReportNode subReportNode) { ReportNode subReporterLimits = null; ReportNode reportMaxActivePower; ReportNode reportMinActivePower; - if (modificationInfos.getMaxP() != null && modificationInfos.getMaxP().getValue() > generator.getMinP()) { - reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMaxP, generator::getMaxP, modificationInfos.getMaxP(), "Max active power"); - reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMinP, generator::getMinP, modificationInfos.getMinP(), "Min active power"); + if (maxP != null && maxP.getValue() > generator.getMinP()) { + reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMaxP, generator::getMaxP, maxP, "Max active power"); + reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMinP, generator::getMinP, minP, "Min active power"); } else { - reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMinP, generator::getMinP, modificationInfos.getMinP(), "Min active power"); - reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMaxP, generator::getMaxP, modificationInfos.getMaxP(), "Max active power"); + reportMinActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMinP, generator::getMinP, minP, "Min active power"); + reportMaxActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setMaxP, generator::getMaxP, maxP, "Max active power"); } - ReportNode reportRatedNominalPower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setRatedS, generator::getRatedS, modificationInfos.getRatedS(), "Rated nominal power"); - if (reportMaxActivePower != null || reportMinActivePower != null || reportRatedNominalPower != null) { + ReportNode reportRatedNominalPower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setRatedS, generator::getRatedS, ratedS, "Rated nominal power"); + if (subReportNode != null && (reportMaxActivePower != null || reportMinActivePower != null || reportRatedNominalPower != null)) { subReporterLimits = subReportNode.newReportNode().withMessageTemplate(LIMITS, LIMITS).add(); subReporterLimits.newReportNode() .withMessageTemplate(LIMITS, LIMITS) @@ -384,15 +387,7 @@ private ReportNode modifyGeneratorVoltageRegulatorAttributes(GeneratorModificati Generator generator, ReportNode subReportNode, ReportNode subReportNodeSetpoints) { List voltageRegulationReports = new ArrayList<>(); - ReportNode reportVoltageSetpoint = null; - if (modificationInfos.getTargetV() != null) { - if (modificationInfos.getTargetV().getOp() == OperationType.SET) { - reportVoltageSetpoint = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetV, generator::getTargetV, - modificationInfos.getTargetV(), "Voltage"); - } else { - reportVoltageSetpoint = ModificationUtils.getInstance().buildModificationReport(generator.getTargetV(), Double.NaN, "Voltage"); - } - } + ReportNode reportVoltageSetpoint = modifyTargetV(generator, modificationInfos.getTargetV()); voltageRegulationReports.add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setVoltageRegulatorOn, generator::isVoltageRegulatorOn, modificationInfos.getVoltageRegulationOn(), "VoltageRegulationOn")); @@ -439,17 +434,24 @@ private ReportNode modifyGeneratorVoltageRegulatorAttributes(GeneratorModificati return subReportNodeSetpoints2; } - private void modifyGeneratorSetpointsAttributes(GeneratorModificationInfos modificationInfos, - Generator generator, ReportNode subReportNode) { - ReportNode reportActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetP, generator::getTargetP, modificationInfos.getTargetP(), "Active power"); - ReportNode reportReactivePower = null; - if (modificationInfos.getTargetQ() != null) { - if (modificationInfos.getTargetQ().getOp() == OperationType.SET) { - reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetQ, generator::getTargetQ, modificationInfos.getTargetQ(), "Reactive power"); + public static ReportNode modifyTargetV(Generator generator, AttributeModification modifTargetV) { + ReportNode reportVoltageSetpoint = null; + if (modifTargetV != null) { + if (modifTargetV.getOp() == OperationType.SET) { + reportVoltageSetpoint = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetV, generator::getTargetV, + modifTargetV, "Voltage"); } else { - reportReactivePower = ModificationUtils.getInstance().buildModificationReport(generator.getTargetQ(), Double.NaN, "Reactive power"); + reportVoltageSetpoint = ModificationUtils.getInstance().buildModificationReport(generator.getTargetV(), Double.NaN, "Voltage"); } } + return reportVoltageSetpoint; + } + + private void modifyGeneratorSetpointsAttributes(GeneratorModificationInfos modificationInfos, + Generator generator, ReportNode subReportNode) { + ReportNode reportActivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetP, generator::getTargetP, modificationInfos.getTargetP(), "Active power"); + + ReportNode reportReactivePower = modifyTargetQ(generator, modificationInfos.getTargetQ()); ReportNode subReporterSetpoints = null; if (reportActivePower != null || reportReactivePower != null) { @@ -469,9 +471,25 @@ private void modifyGeneratorSetpointsAttributes(GeneratorModificationInfos modif modifyGeneratorActivePowerControlAttributes(modificationInfos, generator, subReportNode, subReporterSetpoints); } + public static ReportNode modifyTargetQ(Generator generator, AttributeModification modifTargetQ) { + ReportNode reportReactivePower = null; + if (modifTargetQ != null) { + if (modifTargetQ.getOp() == OperationType.SET) { + reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetQ, generator::getTargetQ, modifTargetQ, "Reactive power"); + } else { + reportReactivePower = ModificationUtils.getInstance().buildModificationReport(generator.getTargetQ(), Double.NaN, "Reactive power"); + } + } + return reportReactivePower; + } + private void modifyGeneratorLimitsAttributes(GeneratorModificationInfos modificationInfos, Generator generator, ReportNode subReportNode) { - ReportNode subReportNodeLimits = modifyGeneratorActiveLimitsAttributes(modificationInfos, generator, subReportNode); + ReportNode subReportNodeLimits = modifyGeneratorActiveLimitsAttributes(modificationInfos.getMaxP(), + modificationInfos.getMinP(), + modificationInfos.getRatedS(), + generator, + subReportNode); modifyGeneratorReactiveLimitsAttributes(modificationInfos, generator, subReportNode, subReportNodeLimits); } From 3337dd9ec987c459b152acb5b8eb4d153ecc611c Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 17:22:22 +0200 Subject: [PATCH 12/23] refacto VoltageLevelField Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/VoltageLevelField.java | 9 ++++++--- .../VoltageLevelModification.java | 18 +++++++++++++++--- 2 files changed, 21 insertions(+), 6 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java index 3338e144f..07cc36476 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java @@ -12,6 +12,9 @@ import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; +import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifLowVoltageLimit; +import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyHighVoltageLimit; +import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyNominalV; import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyVoltageLevelShortCircuit; /** @@ -40,9 +43,9 @@ public static Double getReferenceValue(VoltageLevel voltageLevel, String voltage public static void setNewValue(VoltageLevel voltageLevel, String voltageLevelField, Double newValue) { VoltageLevelField field = VoltageLevelField.valueOf(voltageLevelField); switch (field) { - case NOMINAL_VOLTAGE -> voltageLevel.setNominalV(newValue); - case LOW_VOLTAGE_LIMIT -> voltageLevel.setLowVoltageLimit(newValue); - case HIGH_VOLTAGE_LIMIT -> voltageLevel.setHighVoltageLimit(newValue); + case NOMINAL_VOLTAGE -> modifyNominalV(voltageLevel, new AttributeModification<>(newValue, OperationType.SET), null); + case LOW_VOLTAGE_LIMIT -> modifLowVoltageLimit(voltageLevel, new AttributeModification<>(newValue, OperationType.SET), null); + case HIGH_VOLTAGE_LIMIT -> modifyHighVoltageLimit(voltageLevel, new AttributeModification<>(newValue, OperationType.SET), null); case LOW_SHORT_CIRCUIT_CURRENT_LIMIT -> modifyVoltageLevelShortCircuit( new AttributeModification<>(newValue, OperationType.SET), null, null, voltageLevel); case HIGH_SHORT_CIRCUIT_CURRENT_LIMIT -> modifyVoltageLevelShortCircuit( diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index 5c243a233..b9c8ed2ec 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -85,14 +85,26 @@ public void apply(Network network, ReportNode subReportNode) { .add(); ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setName, () -> voltageLevel.getOptionalName().orElse("No value"), modificationInfos.getEquipmentName(), subReportNode, "Name"); - ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setNominalV, voltageLevel::getNominalV, modificationInfos.getNominalV(), subReportNode, "Nominal voltage"); - ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setLowVoltageLimit, voltageLevel::getLowVoltageLimit, modificationInfos.getLowVoltageLimit(), subReportNode, "Low voltage limit"); - ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setHighVoltageLimit, voltageLevel::getHighVoltageLimit, modificationInfos.getHighVoltageLimit(), subReportNode, "High voltage limit"); + modifyNominalV(voltageLevel, modificationInfos.getNominalV(), subReportNode); + modifLowVoltageLimit(voltageLevel, modificationInfos.getLowVoltageLimit(), subReportNode); + modifyHighVoltageLimit(voltageLevel, modificationInfos.getHighVoltageLimit(), subReportNode); modifyVoltageLevelShortCircuit(modificationInfos.getIpMin(), modificationInfos.getIpMax(), subReportNode, voltageLevel); PropertiesUtils.applyProperties(voltageLevel, subReportNode, modificationInfos.getProperties(), "VlProperties"); } + public static void modifyHighVoltageLimit(VoltageLevel voltageLevel, AttributeModification highVoltageLimit, ReportNode subReportNode) { + ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setHighVoltageLimit, voltageLevel::getHighVoltageLimit, highVoltageLimit, subReportNode, "High voltage limit"); + } + + public static void modifLowVoltageLimit(VoltageLevel voltageLevel, AttributeModification lowVoltageLimit, ReportNode subReportNode) { + ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setLowVoltageLimit, voltageLevel::getLowVoltageLimit, lowVoltageLimit, subReportNode, "Low voltage limit"); + } + + public static void modifyNominalV(VoltageLevel voltageLevel, AttributeModification modifNominalV, ReportNode subReportNode) { + ModificationUtils.getInstance().applyElementaryModifications(voltageLevel::setNominalV, voltageLevel::getNominalV, modifNominalV, subReportNode, "Nominal voltage"); + } + public static void modifyVoltageLevelShortCircuit(AttributeModification ipMin, AttributeModification ipMax, ReportNode subReportNode, From c37e5a0fb8bd93469e9853b6b714a0d354c15cf9 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 17:34:41 +0200 Subject: [PATCH 13/23] correct tests Signed-off-by: Mathieu DEHARBE --- .../modification/server/modifications/ModificationUtils.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index b060018dc..7fe8e8627 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -516,7 +516,9 @@ public void applyElementaryModifications(Consumer setter, Supplier get T newValue = modification.applyModification(oldValue); setter.accept(newValue); - insertReportNode(subReportNode, buildModificationReport(oldValue, newValue, fieldName)); + if (subReportNode != null) { + insertReportNode(subReportNode, buildModificationReport(oldValue, newValue, fieldName)); + } } } From a8ae013eb9c451648a889dd7dd60233260e1347b Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 3 Sep 2024 18:02:45 +0200 Subject: [PATCH 14/23] correct tests Signed-off-by: Mathieu DEHARBE --- .../dto/formula/equipmentfield/LoadField.java | 9 +++++++-- .../server/modifications/LoadModification.java | 13 +++++++++++-- 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/LoadField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/LoadField.java index 2743186a6..8c01d3f96 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/LoadField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/LoadField.java @@ -8,6 +8,11 @@ package org.gridsuite.modification.server.dto.formula.equipmentfield; import com.powsybl.iidm.network.Load; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; + +import static org.gridsuite.modification.server.modifications.LoadModification.modifyP0; +import static org.gridsuite.modification.server.modifications.LoadModification.modifyQ0; /** * @author Seddik Yengui @@ -28,8 +33,8 @@ public static Double getReferenceValue(Load load, String loadField) { public static void setNewValue(Load load, String loadField, Double newValue) { LoadField field = LoadField.valueOf(loadField); switch (field) { - case ACTIVE_POWER -> load.setP0(newValue); - case REACTIVE_POWER -> load.setQ0(newValue); + case ACTIVE_POWER -> modifyP0(load, new AttributeModification<>(newValue, OperationType.SET), null); + case REACTIVE_POWER -> modifyQ0(load, new AttributeModification<>(newValue, OperationType.SET), null); } } } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/LoadModification.java b/src/main/java/org/gridsuite/modification/server/modifications/LoadModification.java index 019271d8e..3bbbb68c8 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/LoadModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/LoadModification.java @@ -13,6 +13,7 @@ import com.powsybl.iidm.network.extensions.ConnectablePosition; import com.powsybl.iidm.network.extensions.ConnectablePositionAdder; import org.gridsuite.modification.server.NetworkModificationException; +import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.LoadModificationInfos; import static org.gridsuite.modification.server.NetworkModificationException.Type.LOAD_NOT_FOUND; @@ -53,13 +54,21 @@ private void modifyLoad(Load load, ReportNode subReportNode) { ModificationUtils.getInstance().applyElementaryModifications(load::setName, () -> load.getOptionalName().orElse("No value"), modificationInfos.getEquipmentName(), subReportNode, "Name"); ModificationUtils.getInstance().applyElementaryModifications(load::setLoadType, load::getLoadType, modificationInfos.getLoadType(), subReportNode, "Type"); - ModificationUtils.getInstance().applyElementaryModifications(load::setP0, load::getP0, modificationInfos.getP0(), subReportNode, "Constant active power"); - ModificationUtils.getInstance().applyElementaryModifications(load::setQ0, load::getQ0, modificationInfos.getQ0(), subReportNode, "Constant reactive power"); + modifyP0(load, modificationInfos.getP0(), subReportNode); + modifyQ0(load, modificationInfos.getQ0(), subReportNode); modifyLoadConnectivityAttributes(modificationInfos, load, subReportNode); // properties PropertiesUtils.applyProperties(load, subReportNode, modificationInfos.getProperties(), "LoadProperties"); } + public static void modifyQ0(Load load, AttributeModification q0, ReportNode subReportNode) { + ModificationUtils.getInstance().applyElementaryModifications(load::setQ0, load::getQ0, q0, subReportNode, "Constant reactive power"); + } + + public static void modifyP0(Load load, AttributeModification p0, ReportNode subReportNode) { + ModificationUtils.getInstance().applyElementaryModifications(load::setP0, load::getP0, p0, subReportNode, "Constant active power"); + } + private ReportNode modifyLoadConnectivityAttributes(LoadModificationInfos modificationInfos, Load load, ReportNode subReportNode) { ConnectablePosition connectablePosition = load.getExtension(ConnectablePosition.class); From 906613bba5cbcad43c54b45d299f1a27fbfa146d Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 4 Sep 2024 10:31:44 +0200 Subject: [PATCH 15/23] modifyBranchValues Signed-off-by: Mathieu DEHARBE --- .../equipmentfield/GeneratorField.java | 92 ++++--------------- .../TwoWindingsTransformerField.java | 9 +- .../TwoWindingsTransformerModification.java | 29 +++--- 3 files changed, 43 insertions(+), 87 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index c2587cac5..6fed86d25 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -72,94 +72,38 @@ public static Double getReferenceValue(Generator generator, String generatorFiel public static void setNewValue(Generator generator, String generatorField, Double newValue) { if (!Double.isNaN(newValue)) { GeneratorField field = GeneratorField.valueOf(generatorField); + final AttributeModification attrModif = new AttributeModification<>(newValue, OperationType.SET); switch (field) { - case MAXIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(new AttributeModification<>(newValue, OperationType.SET), - null, - null, - generator, - null); - case MINIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(null, - new AttributeModification<>(newValue, OperationType.SET), - null, - generator, - null); + case MAXIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes( + attrModif, null, null, generator, null); + case MINIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(null, attrModif, null, generator, null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( - new AttributeModification<>(newValue, OperationType.SET), - null, - null, - generator.getMinP(), - generator.getMaxP(), - generator.getTargetP(), - MODIFY_GENERATOR_ERROR, - "Generator '" + generator.getId() + "' : " + attrModif, null, null, + generator.getMinP(), generator.getMaxP(), generator.getTargetP(), + MODIFY_GENERATOR_ERROR, "Generator '" + generator.getId() + "' : " ); generator.setTargetP(newValue); } - case RATED_NOMINAL_POWER -> modifyGeneratorActiveLimitsAttributes(null, - null, - new AttributeModification<>(newValue, OperationType.SET), - generator, - null); - case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, new AttributeModification<>(newValue, OperationType.SET)); - case VOLTAGE_SET_POINT -> modifyTargetV(generator, new AttributeModification<>(newValue, OperationType.SET)); + case RATED_NOMINAL_POWER -> modifyGeneratorActiveLimitsAttributes(null, null, attrModif, generator, null); + case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, attrModif); + case VOLTAGE_SET_POINT -> modifyTargetV(generator, attrModif); case PLANNED_ACTIVE_POWER_SET_POINT -> - modifyGeneratorStartUpAttributes( - new AttributeModification<>(newValue, OperationType.SET), - null, - null, - null, - generator, - null, - null); + modifyGeneratorStartUpAttributes(attrModif, null, null, null, generator, null, null); case MARGINAL_COST -> - modifyGeneratorStartUpAttributes( - null, - new AttributeModification<>(newValue, OperationType.SET), - null, - null, - generator, - null, - null); + modifyGeneratorStartUpAttributes(null, attrModif, null, null, generator, null, null); case PLANNED_OUTAGE_RATE -> - modifyGeneratorStartUpAttributes( - null, - null, - new AttributeModification<>(newValue, OperationType.SET), - null, - generator, - null, - null); + modifyGeneratorStartUpAttributes(null, null, attrModif, null, generator, null, null); case FORCED_OUTAGE_RATE -> - modifyGeneratorStartUpAttributes( - null, - null, - null, - new AttributeModification<>(newValue, OperationType.SET), - generator, - null, - null); + modifyGeneratorStartUpAttributes(null, null, null, attrModif, generator, null, null); case DROOP -> { ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); - ModificationUtils.getInstance().modifyActivePowerControlAttributes( - activePowerControl, - activePowerControlAdder, - null, - new AttributeModification<>(newValue.floatValue(), OperationType.SET), - null, - null); + ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, null, + new AttributeModification<>(newValue.floatValue(), OperationType.SET), null, null); } - case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes( - new AttributeModification<>(newValue, OperationType.SET), - null, - generator, - null); - case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes( - null, - new AttributeModification<>(newValue, OperationType.SET), - generator, - null); + case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes(attrModif, null, generator, null); + case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes(null, attrModif, generator, null); case Q_PERCENT -> generator.newExtension(CoordinatedReactiveControlAdderImpl.class) .withQPercent(newValue) .add(); diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java index e0f6d52df..6f0c924d1 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java @@ -3,6 +3,10 @@ import com.powsybl.iidm.network.PhaseTapChanger; import com.powsybl.iidm.network.RatioTapChanger; import com.powsybl.iidm.network.TwoWindingsTransformer; +import org.gridsuite.modification.server.dto.AttributeModification; +import org.gridsuite.modification.server.dto.OperationType; + +import static org.gridsuite.modification.server.modifications.TwoWindingsTransformerModification.modifyBranchValues; public enum TwoWindingsTransformerField { R, @@ -48,10 +52,11 @@ public static void setNewValue(TwoWindingsTransformer transformer, String twoWin TwoWindingsTransformerField field = TwoWindingsTransformerField.valueOf(twoWindingsTransformerField); final PhaseTapChanger phaseTapChanger = transformer.getPhaseTapChanger(); final RatioTapChanger ratioTapChanger = transformer.getRatioTapChanger(); + final AttributeModification attrModif = new AttributeModification<>(newValue, OperationType.SET); switch (field) { - case R -> transformer.setR(newValue); - case X -> transformer.setX(newValue); + case R -> modifyBranchValues(transformer, attrModif, null, null); + case X -> modifyBranchValues(transformer, null, attrModif, null); case G -> transformer.setG(newValue); case B -> transformer.setB(newValue); case RATED_U1 -> transformer.setRatedU1(newValue); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java index 74c74e6b4..c9a4073c7 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java @@ -62,17 +62,7 @@ protected void modifyCharacteristics(Branch branch, BranchModificationInfos b .withSeverity(TypedValue.INFO_SEVERITY) .add(); - // Branch specific fields - if (branchModificationInfos.getR() != null && branchModificationInfos.getR().getValue() != null) { - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(twoWindingsTransformer.getR(), - branchModificationInfos.getR().getValue(), "Series resistance", 1)); - twoWindingsTransformer.setR(branchModificationInfos.getR().getValue()); - } - if (branchModificationInfos.getX() != null && branchModificationInfos.getX().getValue() != null) { - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(twoWindingsTransformer.getX(), - branchModificationInfos.getX().getValue(), "Series reactance", 1)); - twoWindingsTransformer.setX(branchModificationInfos.getX().getValue()); - } + modifyBranchValues(twoWindingsTransformer, branchModificationInfos.getR(), branchModificationInfos.getX(), characteristicsReporter); // Transformer specific fields TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos = (TwoWindingsTransformerModificationInfos) branchModificationInfos; @@ -109,6 +99,23 @@ protected void modifyCharacteristics(Branch branch, BranchModificationInfos b } } + public static void modifyBranchValues(TwoWindingsTransformer twt, AttributeModification modifR, AttributeModification modifX, ReportNode reportNode) { + if (modifR != null && modifR.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getR(), + modifR.getValue(), "Series resistance", 1)); + } + twt.setR(modifR.getValue()); + } + if (modifX != null && modifX.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getX(), + modifX.getValue(), "Series reactance", 1)); + } + twt.setX(modifX.getValue()); + } + } + private void addTapChangersToTwoWindingsTransformer(Network network, TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos, TwoWindingsTransformer twt, ReportNode subReportNode) { if (twt.hasRatioTapChanger() && twoWindingsTransformerModificationInfos.getRatioTapChanger().getEnabled() != null && Boolean.FALSE.equals(twoWindingsTransformerModificationInfos.getRatioTapChanger().getEnabled().getValue())) { twt.getRatioTapChanger().remove(); From 6f7a6aeeb84cf125ae801a643ee61e65b695f49f Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 4 Sep 2024 14:20:15 +0200 Subject: [PATCH 16/23] finish TwoWindingsTransformerField Signed-off-by: Mathieu DEHARBE --- .../TwoWindingsTransformerField.java | 41 +-- .../TwoWindingsTransformerModification.java | 260 +++++++++++------- 2 files changed, 187 insertions(+), 114 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java index 6f0c924d1..7f561c65c 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java @@ -5,8 +5,7 @@ import com.powsybl.iidm.network.TwoWindingsTransformer; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; - -import static org.gridsuite.modification.server.modifications.TwoWindingsTransformerModification.modifyBranchValues; +import static org.gridsuite.modification.server.modifications.TwoWindingsTransformerModification.*; public enum TwoWindingsTransformerField { R, @@ -55,21 +54,29 @@ public static void setNewValue(TwoWindingsTransformer transformer, String twoWin final AttributeModification attrModif = new AttributeModification<>(newValue, OperationType.SET); switch (field) { - case R -> modifyBranchValues(transformer, attrModif, null, null); - case X -> modifyBranchValues(transformer, null, attrModif, null); - case G -> transformer.setG(newValue); - case B -> transformer.setB(newValue); - case RATED_U1 -> transformer.setRatedU1(newValue); - case RATED_U2 -> transformer.setRatedU2(newValue); - case RATED_S -> transformer.setRatedS(newValue); - case TARGET_V -> ratioTapChanger.setTargetV(newValue); - case RATIO_LOW_TAP_POSITION -> ratioTapChanger.setLowTapPosition(newValue.intValue()); - case RATIO_TAP_POSITION -> ratioTapChanger.setTapPosition(newValue.intValue()); - case RATIO_TARGET_DEADBAND -> ratioTapChanger.setTargetDeadband(newValue); - case REGULATION_VALUE -> phaseTapChanger.setRegulationValue(newValue); - case PHASE_LOW_TAP_POSITION -> phaseTapChanger.setLowTapPosition(newValue.intValue()); - case PHASE_TAP_POSITION -> phaseTapChanger.setTapPosition(newValue.intValue()); - case PHASE_TARGET_DEADBAND -> phaseTapChanger.setTargetDeadband(newValue); + case R -> modifyBranchFields(transformer, attrModif, null, null); + case X -> modifyBranchFields(transformer, null, attrModif, null); + case G -> modifyG(transformer, attrModif, null); + case B -> modifyB(transformer, attrModif, null); + case RATED_U1 -> modifyRatedU1(transformer, attrModif, null); + case RATED_U2 -> modifyRatedU2(transformer, attrModif, null); + case RATED_S -> modifyRatedS(transformer, attrModif, null); + case TARGET_V -> modifyTargets(ratioTapChanger, null, true, attrModif, null, null); + case RATIO_LOW_TAP_POSITION -> processTapChangerPositionsAndSteps(ratioTapChanger, null, true, + new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null); + case RATIO_TAP_POSITION -> processTapChangerPositionsAndSteps(ratioTapChanger, null, true, + null, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null); + case RATIO_TARGET_DEADBAND -> modifyTargets(ratioTapChanger, null, true, null, attrModif, null); + case REGULATION_VALUE -> processPhaseTapRegulation( + phaseTapChanger, null, null, true, attrModif, null, null + ); + case PHASE_LOW_TAP_POSITION -> processTapChangerPositionsAndSteps(phaseTapChanger, null, true, + new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null); + case PHASE_TAP_POSITION -> processTapChangerPositionsAndSteps(phaseTapChanger, null, true, + null, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null); + case PHASE_TARGET_DEADBAND -> processPhaseTapRegulation( + phaseTapChanger, null, null, true, null, attrModif, null + ); } } } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java index c9a4073c7..2ac20e1dd 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java @@ -62,44 +62,84 @@ protected void modifyCharacteristics(Branch branch, BranchModificationInfos b .withSeverity(TypedValue.INFO_SEVERITY) .add(); - modifyBranchValues(twoWindingsTransformer, branchModificationInfos.getR(), branchModificationInfos.getX(), characteristicsReporter); + modifyBranchFields(twoWindingsTransformer, branchModificationInfos.getR(), branchModificationInfos.getX(), characteristicsReporter); // Transformer specific fields TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos = (TwoWindingsTransformerModificationInfos) branchModificationInfos; - if (twoWindingsTransformerModificationInfos.getG() != null && twoWindingsTransformerModificationInfos.getG().getValue() != null) { - // convert reported value from siemens to microsiemens - double oldMagnetizingConductanceToReport = twoWindingsTransformer.getG() * Math.pow(10, 6); - double newMagnetizingConductanceToReport = twoWindingsTransformerModificationInfos.getG().getValue() * Math.pow(10, 6); - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(oldMagnetizingConductanceToReport, - newMagnetizingConductanceToReport, "Magnetizing conductance", 1)); - twoWindingsTransformer.setG(twoWindingsTransformerModificationInfos.getG().getValue()); + modifyTransformerFields(twoWindingsTransformer, twoWindingsTransformerModificationInfos.getG(), twoWindingsTransformerModificationInfos.getB(), twoWindingsTransformerModificationInfos.getRatedS(), twoWindingsTransformerModificationInfos.getRatedU1(), twoWindingsTransformerModificationInfos.getRatedU2(), characteristicsReporter); + } + + public static void modifyTransformerFields(TwoWindingsTransformer transformer, + AttributeModification modifG, + AttributeModification modifB, + AttributeModification modifRatedS, + AttributeModification modifRatedU1, + AttributeModification modifRatedU2, + ReportNode reportNode) { + modifyG(transformer, modifG, reportNode); + modifyB(transformer, modifB, reportNode); + modifyRatedS(transformer, modifRatedS, reportNode); + modifyRatedU1(transformer, modifRatedU1, reportNode); + modifyRatedU2(transformer, modifRatedU2, reportNode); + } + + public static void modifyRatedU2(TwoWindingsTransformer transformer, AttributeModification modifRatedU2, ReportNode reportNode) { + if (modifRatedU2 != null && modifRatedU2.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(transformer.getRatedU2(), + modifRatedU2.getValue(), "Rated Voltage (Side 2)", 1)); + } + transformer.setRatedU2(modifRatedU2.getValue()); } - if (twoWindingsTransformerModificationInfos.getB() != null && twoWindingsTransformerModificationInfos.getB().getValue() != null) { - // convert reported value from siemens to microsiemens - double oldMagnetizingSusceptanceToReport = twoWindingsTransformer.getB() * Math.pow(10, 6); - double newMagnetizingSusceptanceToReport = twoWindingsTransformerModificationInfos.getB().getValue() * Math.pow(10, 6); - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(oldMagnetizingSusceptanceToReport, - newMagnetizingSusceptanceToReport, "Magnetizing susceptance", 1)); - twoWindingsTransformer.setB(twoWindingsTransformerModificationInfos.getB().getValue()); + } + + public static void modifyRatedU1(TwoWindingsTransformer transformer, AttributeModification modifRatedU1, ReportNode reportNode) { + if (modifRatedU1 != null && modifRatedU1.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(transformer.getRatedU1(), + modifRatedU1.getValue(), "Rated Voltage (Side 1)", 1)); + } + transformer.setRatedU1(modifRatedU1.getValue()); } - if (twoWindingsTransformerModificationInfos.getRatedS() != null && twoWindingsTransformerModificationInfos.getRatedS().getValue() != null) { - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(twoWindingsTransformer.getRatedS(), - twoWindingsTransformerModificationInfos.getRatedS().getValue(), "Rated nominal power", 1)); - twoWindingsTransformer.setRatedS(twoWindingsTransformerModificationInfos.getRatedS().getValue()); + } + + public static void modifyRatedS(TwoWindingsTransformer transformer, AttributeModification modifRatedS, ReportNode reportNode) { + if (modifRatedS != null && modifRatedS.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(transformer.getRatedS(), + modifRatedS.getValue(), "Rated nominal power", 1)); + } + transformer.setRatedS(modifRatedS.getValue()); } - if (twoWindingsTransformerModificationInfos.getRatedU1() != null && twoWindingsTransformerModificationInfos.getRatedU1().getValue() != null) { - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(twoWindingsTransformer.getRatedU1(), - twoWindingsTransformerModificationInfos.getRatedU1().getValue(), "Rated Voltage (Side 1)", 1)); - twoWindingsTransformer.setRatedU1(twoWindingsTransformerModificationInfos.getRatedU1().getValue()); + } + + public static void modifyB(TwoWindingsTransformer transformer, AttributeModification modifB, ReportNode reportNode) { + if (modifB != null && modifB.getValue() != null) { + // convert reported value from siemens to microsiemens + if (reportNode != null) { + double oldMagnetizingSusceptanceToReport = transformer.getB() * Math.pow(10, 6); + double newMagnetizingSusceptanceToReport = modifB.getValue() * Math.pow(10, 6); + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(oldMagnetizingSusceptanceToReport, + newMagnetizingSusceptanceToReport, "Magnetizing susceptance", 1)); + } + transformer.setB(modifB.getValue()); } - if (twoWindingsTransformerModificationInfos.getRatedU2() != null && twoWindingsTransformerModificationInfos.getRatedU2().getValue() != null) { - insertReportNode(characteristicsReporter, ModificationUtils.getInstance().buildModificationReportWithIndentation(twoWindingsTransformer.getRatedU2(), - twoWindingsTransformerModificationInfos.getRatedU2().getValue(), "Rated Voltage (Side 2)", 1)); - twoWindingsTransformer.setRatedU2(twoWindingsTransformerModificationInfos.getRatedU2().getValue()); + } + + public static void modifyG(TwoWindingsTransformer transformer, AttributeModification modifG, ReportNode reportNode) { + if (modifG != null && modifG.getValue() != null) { + // convert reported value from siemens to microsiemens + if (reportNode != null) { + double oldMagnetizingConductanceToReport = transformer.getG() * Math.pow(10, 6); + double newMagnetizingConductanceToReport = modifG.getValue() * Math.pow(10, 6); + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(oldMagnetizingConductanceToReport, + newMagnetizingConductanceToReport, "Magnetizing conductance", 1)); + } + transformer.setG(modifG.getValue()); } } - public static void modifyBranchValues(TwoWindingsTransformer twt, AttributeModification modifR, AttributeModification modifX, ReportNode reportNode) { + public static void modifyBranchFields(TwoWindingsTransformer twt, AttributeModification modifR, AttributeModification modifX, ReportNode reportNode) { if (modifR != null && modifR.getValue() != null) { if (reportNode != null) { insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getR(), @@ -161,8 +201,8 @@ private void processPhaseTapChanger(Network network, regulationMode = phaseTapChangerInfos.getRegulationMode().getValue(); } if (!PhaseTapChanger.RegulationMode.FIXED_TAP.equals(regulationMode)) { - processPhaseTapRegulation(phaseTapChangerInfos, phaseTapChanger, phaseTapChangerAdder, regulationReports, - regulationMode, isModification); + processPhaseTapRegulation(phaseTapChanger, phaseTapChangerAdder, regulationMode, isModification, phaseTapChangerInfos.getRegulationValue(), phaseTapChangerInfos.getTargetDeadband(), regulationReports + ); } processRegulatingTerminal(phaseTapChangerInfos, phaseTapChanger, phaseTapChangerAdder, regulationReports, @@ -170,8 +210,7 @@ private void processPhaseTapChanger(Network network, twt, isModification); List positionsAndStepsReports = new ArrayList<>(); - processTapChangerPositionsAndSteps(phaseTapChangerInfos, phaseTapChanger, phaseTapChangerAdder, positionsAndStepsReports, - isModification); + processTapChangerPositionsAndSteps(phaseTapChanger, phaseTapChangerAdder, isModification, phaseTapChangerInfos.getLowTapPosition(), phaseTapChangerInfos.getTapPosition(), phaseTapChangerInfos.getSteps(), positionsAndStepsReports); if (!isModification) { phaseTapChangerAdder.add(); @@ -199,28 +238,33 @@ private void processPhaseTapChanger(Network network, } } - private void processPhaseTapRegulation(PhaseTapChangerModificationInfos phaseTapChangerInfos, - PhaseTapChanger phaseTapChanger, - PhaseTapChangerAdder phaseTapChangerAdder, - List regulationReports, - PhaseTapChanger.RegulationMode regulationMode, - boolean isModification) { - - if (regulationMode != null) { - regulationReports.add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( - isModification ? phaseTapChanger::setRegulationValue - : phaseTapChangerAdder::setRegulationValue, - isModification ? phaseTapChanger::getRegulationValue : () -> null, - phaseTapChangerInfos.getRegulationValue(), - regulationMode.equals(PhaseTapChanger.RegulationMode.CURRENT_LIMITER) ? "Value" : "Flow set point", - 2)); - } - - regulationReports.add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + public static void processPhaseTapRegulation(PhaseTapChanger phaseTapChanger, + PhaseTapChangerAdder phaseTapChangerAdder, + PhaseTapChanger.RegulationMode regulationMode, + boolean isModification, + AttributeModification modifyRegulationValue, + AttributeModification modifyTargetDeadband, + List regulationReports) { + + String fieldName = (regulationMode != null && regulationMode.equals(PhaseTapChanger.RegulationMode.CURRENT_LIMITER)) ? "Value" : "Flow set point"; + ReportNode regulationValueReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + isModification ? phaseTapChanger::setRegulationValue + : phaseTapChangerAdder::setRegulationValue, + isModification ? phaseTapChanger::getRegulationValue : () -> null, + modifyRegulationValue, + fieldName, + 2); + + ReportNode targetDeadbandReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( isModification ? phaseTapChanger::setTargetDeadband : phaseTapChangerAdder::setTargetDeadband, isModification ? phaseTapChanger::getTargetDeadband : () -> null, - phaseTapChangerInfos.getTargetDeadband(), "Target deadband", 2)); + modifyTargetDeadband, "Target deadband", 2); + + if (regulationReports != null) { + regulationReports.add(regulationValueReportNode); + regulationReports.add(targetDeadbandReportNode); + } if (isModification) { phaseTapChanger.setRegulating(true); @@ -250,8 +294,8 @@ private void processRatioTapChanger(Network network, processRatioVoltageRegulation(ratioTapChangerInfos, twt, ratioTapChanger, ratioTapChangerAdder, voltageRegulationReports, network, isModification); List positionsAndStepsReports = new ArrayList<>(); - processTapChangerPositionsAndSteps(ratioTapChangerInfos, ratioTapChanger, ratioTapChangerAdder, positionsAndStepsReports, - isModification); + processTapChangerPositionsAndSteps(ratioTapChanger, ratioTapChangerAdder, isModification, ratioTapChangerInfos.getLowTapPosition(), ratioTapChangerInfos.getTapPosition(), ratioTapChangerInfos.getSteps(), positionsAndStepsReports + ); if (!isModification) { ratioTapChangerAdder.add(); @@ -297,24 +341,31 @@ private void processRatioVoltageRegulation(RatioTapChangerModificationInfos rati List voltageRegulationReports, Network network, boolean isModification) { - voltageRegulationReports - .add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( - isModification ? ratioTapChanger::setTargetV - : ratioTapChangerAdder::setTargetV, - isModification ? ratioTapChanger::getTargetV : () -> null, - ratioTapChangerInfos.getTargetV(), "Target voltage", 2)); - - voltageRegulationReports - .add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( - isModification ? ratioTapChanger::setTargetDeadband - : ratioTapChangerAdder::setTargetDeadband, - isModification ? ratioTapChanger::getTargetDeadband : () -> null, - ratioTapChangerInfos.getTargetDeadband(), "Target deadband", 2)); + modifyTargets(ratioTapChanger, ratioTapChangerAdder, isModification, ratioTapChangerInfos.getTargetV(), ratioTapChangerInfos.getTargetDeadband(), voltageRegulationReports); processRegulatingTerminal(ratioTapChangerInfos, ratioTapChanger, ratioTapChangerAdder, voltageRegulationReports, network, twt, isModification); } + public static void modifyTargets(RatioTapChanger ratioTapChanger, RatioTapChangerAdder ratioTapChangerAdder, boolean isModification, AttributeModification targetV, AttributeModification targetDeadband, List voltageRegulationReports) { + ReportNode targetVoltageReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + isModification ? ratioTapChanger::setTargetV + : ratioTapChangerAdder::setTargetV, + isModification ? ratioTapChanger::getTargetV : () -> null, + targetV, "Target voltage", 2); + + ReportNode targetDeadbandReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + isModification ? ratioTapChanger::setTargetDeadband + : ratioTapChangerAdder::setTargetDeadband, + isModification ? ratioTapChanger::getTargetDeadband : () -> null, + targetDeadband, "Target deadband", 2); + + if (voltageRegulationReports != null) { + voltageRegulationReports.add(targetVoltageReportNode); + voltageRegulationReports.add(targetDeadbandReportNode); + } + } + private void processRegulatingTerminal(TapChangerModificationInfos tapChangerModificationInfos, TapChanger tapChanger, TapChangerAdder tapChangerAdder, @@ -369,17 +420,21 @@ private void setRegulatingTerminalInfos(TapChangerModificationInfos tapChangerMo tapChangerModificationInfos.setRegulatingTerminalType(new AttributeModification<>(terminal.getConnectable().getType().name(), OperationType.SET)); } - private void processTapchangerSteps(List tapChangerStepsReports, - TapChangerModificationInfos tapChangerModificationInfos, - TapChangerAdder tapChangerAdder, - TapChangerStepsReplacer tapChangerStepReplacer, - boolean isModification) { - tapChangerStepsReports.add(ReportNode.newRootReportNode() - .withMessageTemplate("tapChangerStepsModification", " Taps were replaced by new ones below") - .withSeverity(TypedValue.INFO_SEVERITY) - .build()); - for (TapChangerStepCreationInfos step : tapChangerModificationInfos.getSteps()) { - addStepAttributeReports(tapChangerStepsReports, step); + private static void processTapchangerSteps(List tapChangerStepsReports, + TapChangerAdder tapChangerAdder, + TapChangerStepsReplacer tapChangerStepReplacer, + boolean isModification, + List modifSteps) { + if (tapChangerStepsReports != null) { + tapChangerStepsReports.add(ReportNode.newRootReportNode() + .withMessageTemplate("tapChangerStepsModification", " Taps were replaced by new ones below") + .withSeverity(TypedValue.INFO_SEVERITY) + .build()); + } + for (TapChangerStepCreationInfos step : modifSteps) { + if (tapChangerStepsReports != null) { + addStepAttributeReports(tapChangerStepsReports, step); + } if (tapChangerStepReplacer instanceof RatioTapChangerStepsReplacer || tapChangerAdder instanceof RatioTapChangerAdder) { if (isModification) { tapChangerStepReplacer.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) @@ -389,8 +444,10 @@ private void processTapchangerSteps(List tapChangerStepsReports, .setB(step.getB()).setRho(step.getRho()).endStep(); } } else { - addStepAttributeReport(tapChangerStepsReports, "newStepAlpha" + step.getAlpha(), - " Shift angle : ${alpha}", "alpha", String.valueOf(step.getAlpha())); + if (tapChangerStepsReports != null) { + addStepAttributeReport(tapChangerStepsReports, "newStepAlpha" + step.getAlpha(), + " Shift angle : ${alpha}", "alpha", String.valueOf(step.getAlpha())); + } if (isModification) { ((PhaseTapChangerStepsReplacer) tapChangerStepReplacer).beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) .setB(step.getB()).setRho(step.getRho()).setAlpha(step.getAlpha()).endStep(); @@ -405,7 +462,7 @@ private void processTapchangerSteps(List tapChangerStepsReports, } } - private void addStepAttributeReports(List tapChangerStepsReports, TapChangerStepCreationInfos step) { + private static void addStepAttributeReports(List tapChangerStepsReports, TapChangerStepCreationInfos step) { addStepAttributeReport(tapChangerStepsReports, "newStepIndex" + step.getIndex(), " Tap (${index})", "index", String.valueOf(step.getIndex())); addStepAttributeReport(tapChangerStepsReports, "newStepResistance" + step.getR(), @@ -420,35 +477,44 @@ private void addStepAttributeReports(List tapChangerStepsReports, Ta " Ratio : ${rho}", "rho", String.valueOf(step.getRho())); } - private void processTapChangerPositionsAndSteps(TapChangerModificationInfos tapChangerModificationInfos, - TapChanger tapChanger, - TapChangerAdder tapChangerAdder, - List tapChangerReports, - boolean isModification) { - tapChangerReports.add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + public static void processTapChangerPositionsAndSteps(TapChanger tapChanger, + TapChangerAdder tapChangerAdder, + boolean isModification, + AttributeModification modifyLowTapPosition, + AttributeModification modifyTapPosition, + List modifySteps, + List tapChangerReports) { + ReportNode lowTapPositionReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( isModification ? tapChanger::setLowTapPosition : tapChangerAdder::setLowTapPosition, isModification ? tapChanger::getLowTapPosition : () -> null, - tapChangerModificationInfos.getLowTapPosition(), "Low tap position", 2)); + modifyLowTapPosition, "Low tap position", 2); - tapChangerReports.add(ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( + ReportNode tapPositionReportNode = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport( isModification ? tapChanger::setTapPosition : tapChangerAdder::setTapPosition, isModification ? tapChanger::getTapPosition : () -> null, - tapChangerModificationInfos.getTapPosition(), "Tap position", 2)); + modifyTapPosition, "Tap position", 2); + + if (tapChangerReports != null) { + tapChangerReports.add(lowTapPositionReportNode); + tapChangerReports.add(tapPositionReportNode); + } // Add steps - if (tapChangerModificationInfos.getSteps() != null) { - tapChangerReports.add(ReportNode.newRootReportNode() - .withMessageTemplate("tapsModification", " Taps") - .withSeverity(TypedValue.INFO_SEVERITY) - .build()); - processTapchangerSteps(tapChangerReports, tapChangerModificationInfos, - tapChangerAdder, isModification ? tapChanger.stepsReplacer() : null, isModification); + if (modifySteps != null) { + if (tapChangerReports != null) { + tapChangerReports.add(ReportNode.newRootReportNode() + .withMessageTemplate("tapsModification", " Taps") + .withSeverity(TypedValue.INFO_SEVERITY) + .build()); + } + processTapchangerSteps(tapChangerReports, + tapChangerAdder, isModification ? tapChanger.stepsReplacer() : null, isModification, modifySteps); } } - private void addStepAttributeReport(List tapChangerStepsReports, String key, String defaultMessage, + private static void addStepAttributeReport(List tapChangerStepsReports, String key, String defaultMessage, String valueKey, String value) { tapChangerStepsReports.add(ReportNode.newRootReportNode() .withMessageTemplate(key, defaultMessage) From 6e29fdcb5f1b687dff6ab79feed4ebfb2f5ba87b Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 4 Sep 2024 14:58:46 +0200 Subject: [PATCH 17/23] reduce cognitive complexity Signed-off-by: Mathieu DEHARBE --- .../TwoWindingsTransformerModification.java | 44 +++++++++++-------- 1 file changed, 26 insertions(+), 18 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java index 2ac20e1dd..ae272ab6f 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java @@ -436,25 +436,9 @@ private static void processTapchangerSteps(List tapChangerStepsRepor addStepAttributeReports(tapChangerStepsReports, step); } if (tapChangerStepReplacer instanceof RatioTapChangerStepsReplacer || tapChangerAdder instanceof RatioTapChangerAdder) { - if (isModification) { - tapChangerStepReplacer.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) - .setB(step.getB()).setRho(step.getRho()).endStep(); - } else { - tapChangerAdder.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) - .setB(step.getB()).setRho(step.getRho()).endStep(); - } + processRatioTapChangerStep(tapChangerAdder, tapChangerStepReplacer, isModification, step); } else { - if (tapChangerStepsReports != null) { - addStepAttributeReport(tapChangerStepsReports, "newStepAlpha" + step.getAlpha(), - " Shift angle : ${alpha}", "alpha", String.valueOf(step.getAlpha())); - } - if (isModification) { - ((PhaseTapChangerStepsReplacer) tapChangerStepReplacer).beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) - .setB(step.getB()).setRho(step.getRho()).setAlpha(step.getAlpha()).endStep(); - } else { - ((PhaseTapChangerAdder) tapChangerAdder).beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) - .setB(step.getB()).setRho(step.getRho()).setAlpha(step.getAlpha()).endStep(); - } + processPhaseTapChangerStep(tapChangerStepsReports, (PhaseTapChangerAdder) tapChangerAdder, (PhaseTapChangerStepsReplacer) tapChangerStepReplacer, isModification, step); } } if (isModification) { @@ -462,6 +446,30 @@ private static void processTapchangerSteps(List tapChangerStepsRepor } } + private static void processPhaseTapChangerStep(List tapChangerStepsReports, PhaseTapChangerAdder tapChangerAdder, PhaseTapChangerStepsReplacer tapChangerStepReplacer, boolean isModification, TapChangerStepCreationInfos step) { + if (tapChangerStepsReports != null) { + addStepAttributeReport(tapChangerStepsReports, "newStepAlpha" + step.getAlpha(), + " Shift angle : ${alpha}", "alpha", String.valueOf(step.getAlpha())); + } + if (isModification) { + tapChangerStepReplacer.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) + .setB(step.getB()).setRho(step.getRho()).setAlpha(step.getAlpha()).endStep(); + } else { + tapChangerAdder.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) + .setB(step.getB()).setRho(step.getRho()).setAlpha(step.getAlpha()).endStep(); + } + } + + private static void processRatioTapChangerStep(TapChangerAdder tapChangerAdder, TapChangerStepsReplacer tapChangerStepReplacer, boolean isModification, TapChangerStepCreationInfos step) { + if (isModification) { + tapChangerStepReplacer.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) + .setB(step.getB()).setRho(step.getRho()).endStep(); + } else { + tapChangerAdder.beginStep().setR(step.getR()).setX(step.getX()).setG(step.getG()) + .setB(step.getB()).setRho(step.getRho()).endStep(); + } + } + private static void addStepAttributeReports(List tapChangerStepsReports, TapChangerStepCreationInfos step) { addStepAttributeReport(tapChangerStepsReports, "newStepIndex" + step.getIndex(), " Tap (${index})", "index", String.valueOf(step.getIndex())); From d249d45540b87bb079b361c0cf6331316c1b2c4d Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 4 Sep 2024 15:24:09 +0200 Subject: [PATCH 18/23] small refect on BatteryField Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 38 +++++-------------- 1 file changed, 9 insertions(+), 29 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index cf94bb81f..703d44066 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -43,47 +43,27 @@ public static Double getReferenceValue(Battery battery, String batteryField) { public static void setNewValue(Battery battery, String batteryField, Double newValue) { BatteryField field = BatteryField.valueOf(batteryField); + final AttributeModification modif = new AttributeModification<>(newValue, OperationType.SET); switch (field) { case MINIMUM_ACTIVE_POWER -> - modifyBatteryActiveLimitsAttributes( - null, - new AttributeModification<>(newValue, OperationType.SET), - battery, - null); + modifyBatteryActiveLimitsAttributes(null, modif, battery, null); case MAXIMUM_ACTIVE_POWER -> - modifyBatteryActiveLimitsAttributes( - new AttributeModification<>(newValue, OperationType.SET), - null, - battery, - null); + modifyBatteryActiveLimitsAttributes(modif, null, battery, null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( - new AttributeModification<>(newValue, OperationType.SET), - null, - null, - battery.getMinP(), - battery.getMaxP(), - battery.getTargetP(), - MODIFY_GENERATOR_ERROR, - "Battery '" + battery.getId() + "' : " + modif, null, null, battery.getMinP(), + battery.getMaxP(), battery.getTargetP(), MODIFY_GENERATOR_ERROR, "Battery '" + battery.getId() + "' : " ); - modifyBatterySetpointsAttributes( - new AttributeModification<>(newValue, OperationType.SET), null, null, null, - battery, null); + modifyBatterySetpointsAttributes(modif, null, null, null, battery, null); } case REACTIVE_POWER_SET_POINT -> modifyBatterySetpointsAttributes( - null, new AttributeModification<>(newValue, OperationType.SET), null, null, - battery, null); + null, modif, null, null, battery, null); case DROOP -> { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); ModificationUtils.getInstance().modifyActivePowerControlAttributes( - activePowerControl, - activePowerControlAdder, - null, - new AttributeModification<>(newValue.floatValue(), OperationType.SET), - null, - null); + activePowerControl, activePowerControlAdder, null, + new AttributeModification<>(newValue.floatValue(), OperationType.SET), null, null); } } } From 90b6b5c00e657d974f29ad8f9af119c435bca3f7 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 4 Sep 2024 15:49:12 +0200 Subject: [PATCH 19/23] ultimate cleaning Signed-off-by: Mathieu DEHARBE --- .../server/dto/formula/equipmentfield/GeneratorField.java | 8 ++------ .../dto/formula/equipmentfield/ShuntCompensatorField.java | 5 +---- .../dto/formula/equipmentfield/VoltageLevelField.java | 5 +---- .../server/modifications/ByFormulaModification.java | 2 +- .../server/modifications/GeneratorModification.java | 6 +++--- .../modifications/ShuntCompensatorModification.java | 6 +++--- .../modifications/TwoWindingsTransformerModification.java | 8 +++++++- 7 files changed, 18 insertions(+), 22 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 6fed86d25..0d3f6602c 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -19,11 +19,7 @@ import org.gridsuite.modification.server.modifications.ModificationUtils; import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; -import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorActiveLimitsAttributes; -import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorShortCircuitAttributes; -import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyGeneratorStartUpAttributes; -import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyTargetQ; -import static org.gridsuite.modification.server.modifications.GeneratorModification.modifyTargetV; +import static org.gridsuite.modification.server.modifications.GeneratorModification.*; /** * @author Seddik Yengui @@ -89,7 +85,7 @@ public static void setNewValue(Generator generator, String generatorField, Doubl case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, attrModif); case VOLTAGE_SET_POINT -> modifyTargetV(generator, attrModif); case PLANNED_ACTIVE_POWER_SET_POINT -> - modifyGeneratorStartUpAttributes(attrModif, null, null, null, generator, null, null); + modifyGeneratorStartUpAttributes(attrModif, null, null, null, generator, null, null); case MARGINAL_COST -> modifyGeneratorStartUpAttributes(null, attrModif, null, null, generator, null, null); case PLANNED_OUTAGE_RATE -> diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java index 5b60793cb..4bbea3112 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java @@ -16,10 +16,7 @@ import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.dto.ShuntCompensatorType; -import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaxSusceptance; -import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaximumQAtNominalVoltage; -import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifyMaximumSectionCount; -import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.modifySectionCount; +import static org.gridsuite.modification.server.modifications.ShuntCompensatorModification.*; /** * @author Seddik Yengui diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java index 07cc36476..69f366ad4 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/VoltageLevelField.java @@ -12,10 +12,7 @@ import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; -import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifLowVoltageLimit; -import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyHighVoltageLimit; -import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyNominalV; -import static org.gridsuite.modification.server.modifications.VoltageLevelModification.modifyVoltageLevelShortCircuit; +import static org.gridsuite.modification.server.modifications.VoltageLevelModification.*; /** * @author Seddik Yengui diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java index f581d39ba..eb8ebbc3d 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java @@ -286,7 +286,7 @@ private void applyFormula(Identifiable identifiable, .withUntypedValue(KEY_VALUE, newValue) .withSeverity(TypedValue.TRACE_SEVERITY) .build()); - } catch (Exception e) { // ATTENTION : ce catch attrape bien mes throw mais sans utiliser les messages donc c'est un peu gâché; En faire un spécifique pour les NetworkModificationException ? + } catch (Exception e) { notEditableEquipments.add(identifiable.getId()); equipmentNotModifiedCount += 1; reports.add(ReportNode.newRootReportNode() diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index 6fec37804..271455f14 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -94,7 +94,7 @@ private void modifyGenerator(Generator generator, GeneratorModificationInfos mod modifyGeneratorLimitsAttributes(modificationInfos, generator, subReportNode); modifyGeneratorSetpointsAttributes(modificationInfos, generator, subReportNode); modifyGeneratorShortCircuitAttributes(modificationInfos.getDirectTransX(), modificationInfos.getStepUpTransformerX(), generator, subReportNode); - modifyGeneratorStartUpAttributesAndLog(modificationInfos, generator, subReportNode); + modifyGeneratorStartUpAttributes(modificationInfos, generator, subReportNode); modifyGeneratorConnectivityAttributes(modificationInfos, generator, subReportNode); PropertiesUtils.applyProperties(generator, subReportNode, modificationInfos.getProperties(), "GeneratorProperties"); } @@ -223,8 +223,8 @@ private ReportNode modifyGeneratorActivePowerControlAttributes(GeneratorModifica return ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, modificationInfos.getParticipate(), modificationInfos.getDroop(), subReportNode, subReportNodeSetpoints); } - private void modifyGeneratorStartUpAttributesAndLog(GeneratorModificationInfos modificationInfos, Generator generator, - ReportNode subReportNode) { + private void modifyGeneratorStartUpAttributes(GeneratorModificationInfos modificationInfos, Generator generator, + ReportNode subReportNode) { List reports = new ArrayList<>(); modifyGeneratorStartUpAttributes(modificationInfos.getPlannedActivePowerSetPoint(), modificationInfos.getMarginalCost(), diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java index 67c7cbe76..899ace841 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ShuntCompensatorModification.java @@ -167,9 +167,9 @@ private void applyModificationOnLinearModel(ReportNode subReportNode, ShuntCompe } public static void modifyMaxSusceptance(AttributeModification maxSusceptance, - int maximumSectionCount, - List reports, - ShuntCompensatorLinearModel model) { + int maximumSectionCount, + List reports, + ShuntCompensatorLinearModel model) { double newSusceptancePerSection = maxSusceptance.getValue() / maximumSectionCount; if (reports != null) { double oldSusceptancePerSection = model.getBPerSection(); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java index ae272ab6f..b51672d5e 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java @@ -66,7 +66,13 @@ protected void modifyCharacteristics(Branch branch, BranchModificationInfos b // Transformer specific fields TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos = (TwoWindingsTransformerModificationInfos) branchModificationInfos; - modifyTransformerFields(twoWindingsTransformer, twoWindingsTransformerModificationInfos.getG(), twoWindingsTransformerModificationInfos.getB(), twoWindingsTransformerModificationInfos.getRatedS(), twoWindingsTransformerModificationInfos.getRatedU1(), twoWindingsTransformerModificationInfos.getRatedU2(), characteristicsReporter); + modifyTransformerFields(twoWindingsTransformer, + twoWindingsTransformerModificationInfos.getG(), + twoWindingsTransformerModificationInfos.getB(), + twoWindingsTransformerModificationInfos.getRatedS(), + twoWindingsTransformerModificationInfos.getRatedU1(), + twoWindingsTransformerModificationInfos.getRatedU2(), + characteristicsReporter); } public static void modifyTransformerFields(TwoWindingsTransformer transformer, From e758123d88eae61759e7906294007266e18e1ac0 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Tue, 17 Sep 2024 18:16:26 +0200 Subject: [PATCH 20/23] corections post review Signed-off-by: Mathieu DEHARBE --- .../formula/equipmentfield/BatteryField.java | 19 +++--- .../equipmentfield/GeneratorField.java | 29 ++++----- .../equipmentfield/ShuntCompensatorField.java | 5 +- .../TwoWindingsTransformerField.java | 24 ++++---- .../modifications/ModificationUtils.java | 25 ++++---- .../TwoWindingsTransformerModification.java | 32 ++++++---- .../VoltageLevelModification.java | 60 +++++++++++-------- 7 files changed, 109 insertions(+), 85 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java index 703d44066..7c82638e7 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/BatteryField.java @@ -10,11 +10,12 @@ import com.powsybl.iidm.network.Battery; import com.powsybl.iidm.network.extensions.ActivePowerControl; import com.powsybl.iidm.network.extensions.ActivePowerControlAdder; +import jakarta.validation.constraints.NotNull; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.modifications.ModificationUtils; -import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_GENERATOR_ERROR; +import static org.gridsuite.modification.server.NetworkModificationException.Type.MODIFY_BATTERY_ERROR; import static org.gridsuite.modification.server.modifications.BatteryModification.modifyBatteryActiveLimitsAttributes; import static org.gridsuite.modification.server.modifications.BatteryModification.modifyBatterySetpointsAttributes; @@ -41,23 +42,23 @@ public static Double getReferenceValue(Battery battery, String batteryField) { }; } - public static void setNewValue(Battery battery, String batteryField, Double newValue) { + public static void setNewValue(Battery battery, String batteryField, @NotNull Double newValue) { BatteryField field = BatteryField.valueOf(batteryField); - final AttributeModification modif = new AttributeModification<>(newValue, OperationType.SET); + final AttributeModification attributeModification = new AttributeModification<>(newValue, OperationType.SET); switch (field) { case MINIMUM_ACTIVE_POWER -> - modifyBatteryActiveLimitsAttributes(null, modif, battery, null); + modifyBatteryActiveLimitsAttributes(null, attributeModification, battery, null); case MAXIMUM_ACTIVE_POWER -> - modifyBatteryActiveLimitsAttributes(modif, null, battery, null); + modifyBatteryActiveLimitsAttributes(attributeModification, null, battery, null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( - modif, null, null, battery.getMinP(), - battery.getMaxP(), battery.getTargetP(), MODIFY_GENERATOR_ERROR, "Battery '" + battery.getId() + "' : " + attributeModification, null, null, battery.getMinP(), + battery.getMaxP(), battery.getTargetP(), MODIFY_BATTERY_ERROR, "Battery '" + battery.getId() + "' : " ); - modifyBatterySetpointsAttributes(modif, null, null, null, battery, null); + modifyBatterySetpointsAttributes(attributeModification, null, null, null, battery, null); } case REACTIVE_POWER_SET_POINT -> modifyBatterySetpointsAttributes( - null, modif, null, null, battery, null); + null, attributeModification, null, null, battery, null); case DROOP -> { ActivePowerControl activePowerControl = battery.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = battery.newExtension(ActivePowerControlAdder.class); diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 0d3f6602c..83063f9ef 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -14,6 +14,7 @@ import com.powsybl.iidm.network.extensions.GeneratorShortCircuit; import com.powsybl.iidm.network.extensions.GeneratorStartup; import com.powsybl.network.store.iidm.impl.extensions.CoordinatedReactiveControlAdderImpl; +import jakarta.validation.constraints.NotNull; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.modifications.ModificationUtils; @@ -65,41 +66,41 @@ public static Double getReferenceValue(Generator generator, String generatorFiel }; } - public static void setNewValue(Generator generator, String generatorField, Double newValue) { + public static void setNewValue(Generator generator, String generatorField, @NotNull Double newValue) { if (!Double.isNaN(newValue)) { GeneratorField field = GeneratorField.valueOf(generatorField); - final AttributeModification attrModif = new AttributeModification<>(newValue, OperationType.SET); + final AttributeModification attributeModification = new AttributeModification<>(newValue, OperationType.SET); switch (field) { case MAXIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes( - attrModif, null, null, generator, null); - case MINIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(null, attrModif, null, generator, null); + attributeModification, null, null, generator, null); + case MINIMUM_ACTIVE_POWER -> modifyGeneratorActiveLimitsAttributes(null, attributeModification, null, generator, null); case ACTIVE_POWER_SET_POINT -> { ModificationUtils.getInstance().checkActivePowerZeroOrBetweenMinAndMaxActivePower( - attrModif, null, null, + attributeModification, null, null, generator.getMinP(), generator.getMaxP(), generator.getTargetP(), MODIFY_GENERATOR_ERROR, "Generator '" + generator.getId() + "' : " ); generator.setTargetP(newValue); } - case RATED_NOMINAL_POWER -> modifyGeneratorActiveLimitsAttributes(null, null, attrModif, generator, null); - case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, attrModif); - case VOLTAGE_SET_POINT -> modifyTargetV(generator, attrModif); + case RATED_NOMINAL_POWER -> modifyGeneratorActiveLimitsAttributes(null, null, attributeModification, generator, null); + case REACTIVE_POWER_SET_POINT -> modifyTargetQ(generator, attributeModification); + case VOLTAGE_SET_POINT -> modifyTargetV(generator, attributeModification); case PLANNED_ACTIVE_POWER_SET_POINT -> - modifyGeneratorStartUpAttributes(attrModif, null, null, null, generator, null, null); + modifyGeneratorStartUpAttributes(attributeModification, null, null, null, generator, null, null); case MARGINAL_COST -> - modifyGeneratorStartUpAttributes(null, attrModif, null, null, generator, null, null); + modifyGeneratorStartUpAttributes(null, attributeModification, null, null, generator, null, null); case PLANNED_OUTAGE_RATE -> - modifyGeneratorStartUpAttributes(null, null, attrModif, null, generator, null, null); + modifyGeneratorStartUpAttributes(null, null, attributeModification, null, generator, null, null); case FORCED_OUTAGE_RATE -> - modifyGeneratorStartUpAttributes(null, null, null, attrModif, generator, null, null); + modifyGeneratorStartUpAttributes(null, null, null, attributeModification, generator, null, null); case DROOP -> { ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, null, new AttributeModification<>(newValue.floatValue(), OperationType.SET), null, null); } - case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes(attrModif, null, generator, null); - case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes(null, attrModif, generator, null); + case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes(attributeModification, null, generator, null); + case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes(null, attributeModification, generator, null); case Q_PERCENT -> generator.newExtension(CoordinatedReactiveControlAdderImpl.class) .withQPercent(newValue) .add(); diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java index 4bbea3112..87dabb14a 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/ShuntCompensatorField.java @@ -47,7 +47,10 @@ public static void setNewValue(ShuntCompensator shuntCompensator, String shuntCo ShuntCompensatorLinearModel model = shuntCompensator.getModel(ShuntCompensatorLinearModel.class); ShuntCompensatorField field = ShuntCompensatorField.valueOf(shuntCompensatorField); VoltageLevel voltageLevel = shuntCompensator.getTerminal().getVoltageLevel(); - var shuntCompensatorType = model.getBPerSection() > 0 ? ShuntCompensatorType.CAPACITOR : ShuntCompensatorType.REACTOR; + var shuntCompensatorType = ShuntCompensatorType.REACTOR; + if (model != null && model.getBPerSection() > 0) { + shuntCompensatorType = ShuntCompensatorType.CAPACITOR; + } switch (field) { case MAXIMUM_SECTION_COUNT -> modifyMaximumSectionCount(new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null, shuntCompensator, model); diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java index 7f561c65c..4451c826b 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java @@ -51,31 +51,31 @@ public static void setNewValue(TwoWindingsTransformer transformer, String twoWin TwoWindingsTransformerField field = TwoWindingsTransformerField.valueOf(twoWindingsTransformerField); final PhaseTapChanger phaseTapChanger = transformer.getPhaseTapChanger(); final RatioTapChanger ratioTapChanger = transformer.getRatioTapChanger(); - final AttributeModification attrModif = new AttributeModification<>(newValue, OperationType.SET); + final AttributeModification attributeModification = new AttributeModification<>(newValue, OperationType.SET); switch (field) { - case R -> modifyBranchFields(transformer, attrModif, null, null); - case X -> modifyBranchFields(transformer, null, attrModif, null); - case G -> modifyG(transformer, attrModif, null); - case B -> modifyB(transformer, attrModif, null); - case RATED_U1 -> modifyRatedU1(transformer, attrModif, null); - case RATED_U2 -> modifyRatedU2(transformer, attrModif, null); - case RATED_S -> modifyRatedS(transformer, attrModif, null); - case TARGET_V -> modifyTargets(ratioTapChanger, null, true, attrModif, null, null); + case R -> modifyR(transformer, attributeModification, null); + case X -> modifyX(transformer, attributeModification, null); + case G -> modifyG(transformer, attributeModification, null); + case B -> modifyB(transformer, attributeModification, null); + case RATED_U1 -> modifyRatedU1(transformer, attributeModification, null); + case RATED_U2 -> modifyRatedU2(transformer, attributeModification, null); + case RATED_S -> modifyRatedS(transformer, attributeModification, null); + case TARGET_V -> modifyTargets(ratioTapChanger, null, true, attributeModification, null, null); case RATIO_LOW_TAP_POSITION -> processTapChangerPositionsAndSteps(ratioTapChanger, null, true, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null); case RATIO_TAP_POSITION -> processTapChangerPositionsAndSteps(ratioTapChanger, null, true, null, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null); - case RATIO_TARGET_DEADBAND -> modifyTargets(ratioTapChanger, null, true, null, attrModif, null); + case RATIO_TARGET_DEADBAND -> modifyTargets(ratioTapChanger, null, true, null, attributeModification, null); case REGULATION_VALUE -> processPhaseTapRegulation( - phaseTapChanger, null, null, true, attrModif, null, null + phaseTapChanger, null, null, true, attributeModification, null, null ); case PHASE_LOW_TAP_POSITION -> processTapChangerPositionsAndSteps(phaseTapChanger, null, true, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null); case PHASE_TAP_POSITION -> processTapChangerPositionsAndSteps(phaseTapChanger, null, true, null, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null); case PHASE_TARGET_DEADBAND -> processPhaseTapRegulation( - phaseTapChanger, null, null, true, null, attrModif, null + phaseTapChanger, null, null, true, null, attributeModification, null ); } } diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java index 7fe8e8627..6b1b34ac5 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ModificationUtils.java @@ -1039,20 +1039,19 @@ public ReportNode modifyActivePowerControlAttributes(ActivePowerControl activ } else { createNewActivePowerControl(activePowerControlAdder, participateInfo, droopInfo, reports); } - if (subReportNode == null) { - return null; - } - - ReportNode subReportNodeSetpoints2 = subReporterSetpoints; - if (subReporterSetpoints == null && !reports.isEmpty()) { - subReportNodeSetpoints2 = subReportNode.newReportNode().withMessageTemplate(SETPOINTS, SETPOINTS).add(); - subReportNodeSetpoints2.newReportNode() - .withMessageTemplate(SETPOINTS, SETPOINTS) - .withSeverity(TypedValue.INFO_SEVERITY) - .add(); + if (subReportNode != null) { + ReportNode subReportNodeSetpoints2 = subReporterSetpoints; + if (subReporterSetpoints == null && !reports.isEmpty()) { + subReportNodeSetpoints2 = subReportNode.newReportNode().withMessageTemplate(SETPOINTS, SETPOINTS).add(); + subReportNodeSetpoints2.newReportNode() + .withMessageTemplate(SETPOINTS, SETPOINTS) + .withSeverity(TypedValue.INFO_SEVERITY) + .add(); + } + reportModifications(subReportNodeSetpoints2, reports, "activePowerRegulationModified", "Active power regulation", Map.of()); + return subReportNodeSetpoints2; } - reportModifications(subReportNodeSetpoints2, reports, "activePowerRegulationModified", "Active power regulation", Map.of()); - return subReportNodeSetpoints2; + return null; } public void checkMaxQGreaterThanMinQ( diff --git a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java index b51672d5e..2d5cabf6b 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/TwoWindingsTransformerModification.java @@ -27,6 +27,7 @@ public class TwoWindingsTransformerModification extends AbstractBranchModificati private static final String RATIO_TAP_CHANGER_SUBREPORTER_DEFAULT_MESSAGE = "Ratio tap changer"; private static final String PHASE_TAP_CHANGER_SUBREPORTER_DEFAULT_MESSAGE = "Phase tap changer"; + public static final String MAGNETIZING_CONDUCTANCE_FIELD_NAME = "Magnetizing conductance"; public TwoWindingsTransformerModification(TwoWindingsTransformerModificationInfos modificationInfos) { super(modificationInfos); @@ -62,7 +63,9 @@ protected void modifyCharacteristics(Branch branch, BranchModificationInfos b .withSeverity(TypedValue.INFO_SEVERITY) .add(); - modifyBranchFields(twoWindingsTransformer, branchModificationInfos.getR(), branchModificationInfos.getX(), characteristicsReporter); + // Branch specific fields + modifyR(twoWindingsTransformer, branchModificationInfos.getR(), characteristicsReporter); + modifyX(twoWindingsTransformer, branchModificationInfos.getX(), characteristicsReporter); // Transformer specific fields TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos = (TwoWindingsTransformerModificationInfos) branchModificationInfos; @@ -138,21 +141,18 @@ public static void modifyG(TwoWindingsTransformer transformer, AttributeModifica if (reportNode != null) { double oldMagnetizingConductanceToReport = transformer.getG() * Math.pow(10, 6); double newMagnetizingConductanceToReport = modifG.getValue() * Math.pow(10, 6); - insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(oldMagnetizingConductanceToReport, - newMagnetizingConductanceToReport, "Magnetizing conductance", 1)); + ReportNode gReportNode = ModificationUtils.getInstance().buildModificationReportWithIndentation( + oldMagnetizingConductanceToReport, + newMagnetizingConductanceToReport, + MAGNETIZING_CONDUCTANCE_FIELD_NAME, + 1); + insertReportNode(reportNode, gReportNode); } transformer.setG(modifG.getValue()); } } - public static void modifyBranchFields(TwoWindingsTransformer twt, AttributeModification modifR, AttributeModification modifX, ReportNode reportNode) { - if (modifR != null && modifR.getValue() != null) { - if (reportNode != null) { - insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getR(), - modifR.getValue(), "Series resistance", 1)); - } - twt.setR(modifR.getValue()); - } + public static void modifyX(TwoWindingsTransformer twt, AttributeModification modifX, ReportNode reportNode) { if (modifX != null && modifX.getValue() != null) { if (reportNode != null) { insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getX(), @@ -162,6 +162,16 @@ public static void modifyBranchFields(TwoWindingsTransformer twt, AttributeModif } } + public static void modifyR(TwoWindingsTransformer twt, AttributeModification modifR, ReportNode reportNode) { + if (modifR != null && modifR.getValue() != null) { + if (reportNode != null) { + insertReportNode(reportNode, ModificationUtils.getInstance().buildModificationReportWithIndentation(twt.getR(), + modifR.getValue(), "Series resistance", 1)); + } + twt.setR(modifR.getValue()); + } + } + private void addTapChangersToTwoWindingsTransformer(Network network, TwoWindingsTransformerModificationInfos twoWindingsTransformerModificationInfos, TwoWindingsTransformer twt, ReportNode subReportNode) { if (twt.hasRatioTapChanger() && twoWindingsTransformerModificationInfos.getRatioTapChanger().getEnabled() != null && Boolean.FALSE.equals(twoWindingsTransformerModificationInfos.getRatioTapChanger().getEnabled().getValue())) { twt.getRatioTapChanger().remove(); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index b9c8ed2ec..d79f633b0 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -15,6 +15,8 @@ import org.gridsuite.modification.server.NetworkModificationException; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.VoltageLevelModificationInfos; +import java.util.function.Consumer; + import java.util.ArrayList; import java.util.List; import java.util.Objects; @@ -122,37 +124,45 @@ public static void modifyVoltageLevelShortCircuit(AttributeModification oldIpMin = identifiableShortCircuit.getIpMin(); oldIpMax = identifiableShortCircuit.getIpMax(); } + updateShortCircuitLimits(ipMin, ipMax, oldIpMin, oldIpMax, identifiableShortCircuitAdder, reports); - if (ipMin != null) { - var newIpMin = ipMin.getValue(); - - identifiableShortCircuitAdder.withIpMin(newIpMin); - - //convert to kA to report it like the user set it. - var oldIpMinToReport = oldIpMin != null ? oldIpMin * 0.001 : null; - var newIpMinToReport = newIpMin * 0.001; - reports.add(ModificationUtils.getInstance() - .buildModificationReport(oldIpMinToReport, newIpMinToReport, "Low short circuit current limit")); - } else if (oldIpMin != null) { - identifiableShortCircuitAdder.withIpMin(oldIpMin); + identifiableShortCircuitAdder.add(); + if (subReportNode != null) { + reports.forEach(report -> insertReportNode(subReportNode, report)); } + } + private static void updateShortCircuitLimits(AttributeModification ipMin, + AttributeModification ipMax, + Double oldIpMin, + Double oldIpMax, + IdentifiableShortCircuitAdder identifiableShortCircuitAdder, + List reports) { + if (ipMin != null) { + updateShortCircuitLimit(ipMin.getValue(), oldIpMin, "Low short circuit current limit", identifiableShortCircuitAdder::withIpMin, reports); + } if (ipMax != null) { - var newIpMax = ipMax.getValue(); - identifiableShortCircuitAdder.withIpMax(newIpMax); - - //Convert to kA to report it like the user set it. - var oldIpMaxToReport = oldIpMax != null ? oldIpMax * 0.001 : null; - var newIpMaxToReport = newIpMax * 0.001; - reports.add(ModificationUtils.getInstance() - .buildModificationReport(oldIpMaxToReport, newIpMaxToReport, "High short circuit current limit")); - } else if (oldIpMax != null) { - identifiableShortCircuitAdder.withIpMax(oldIpMax); + updateShortCircuitLimit(ipMax.getValue(), oldIpMax, "High short circuit current limit", identifiableShortCircuitAdder::withIpMax, reports); } + } - identifiableShortCircuitAdder.add(); - if (subReportNode != null) { - reports.forEach(report -> insertReportNode(subReportNode, report)); + private static void updateShortCircuitLimit(Double newValue, + Double oldValue, + String limitDescription, + Consumer setterMethod, + List reports) { + if (newValue != null) { + setterMethod.accept(newValue); + Double oldValueToReport = convertToKiloAmps(oldValue); + Double newValueToReport = convertToKiloAmps(newValue); + reports.add(ModificationUtils.getInstance().buildModificationReport(oldValueToReport, newValueToReport, limitDescription)); + } else if (oldValue != null) { + setterMethod.accept(oldValue); } } + + private static Double convertToKiloAmps(Double value) { + return (value != null) ? value * 0.001 : null; + } } + From 68e970abd2fe7ccab0dfa3c5400a73145e12b94c Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 18 Sep 2024 12:32:12 +0200 Subject: [PATCH 21/23] revert to correct unit tests Signed-off-by: Mathieu DEHARBE --- .../TwoWindingsTransformerField.java | 3 +- .../VoltageLevelModification.java | 53 +++++++++---------- 2 files changed, 27 insertions(+), 29 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java index 4451c826b..6a13e93d6 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/TwoWindingsTransformerField.java @@ -51,6 +51,7 @@ public static void setNewValue(TwoWindingsTransformer transformer, String twoWin TwoWindingsTransformerField field = TwoWindingsTransformerField.valueOf(twoWindingsTransformerField); final PhaseTapChanger phaseTapChanger = transformer.getPhaseTapChanger(); final RatioTapChanger ratioTapChanger = transformer.getRatioTapChanger(); + final PhaseTapChanger.RegulationMode regulationMode = phaseTapChanger != null ? phaseTapChanger.getRegulationMode() : null; final AttributeModification attributeModification = new AttributeModification<>(newValue, OperationType.SET); switch (field) { @@ -68,7 +69,7 @@ public static void setNewValue(TwoWindingsTransformer transformer, String twoWin null, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null); case RATIO_TARGET_DEADBAND -> modifyTargets(ratioTapChanger, null, true, null, attributeModification, null); case REGULATION_VALUE -> processPhaseTapRegulation( - phaseTapChanger, null, null, true, attributeModification, null, null + phaseTapChanger, null, regulationMode, true, attributeModification, null, null ); case PHASE_LOW_TAP_POSITION -> processTapChangerPositionsAndSteps(phaseTapChanger, null, true, new AttributeModification<>(newValue.intValue(), OperationType.SET), null, null, null); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index d79f633b0..aca5bee9e 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -124,40 +124,37 @@ public static void modifyVoltageLevelShortCircuit(AttributeModification oldIpMin = identifiableShortCircuit.getIpMin(); oldIpMax = identifiableShortCircuit.getIpMax(); } - updateShortCircuitLimits(ipMin, ipMax, oldIpMin, oldIpMax, identifiableShortCircuitAdder, reports); - identifiableShortCircuitAdder.add(); - if (subReportNode != null) { - reports.forEach(report -> insertReportNode(subReportNode, report)); - } - } - - private static void updateShortCircuitLimits(AttributeModification ipMin, - AttributeModification ipMax, - Double oldIpMin, - Double oldIpMax, - IdentifiableShortCircuitAdder identifiableShortCircuitAdder, - List reports) { if (ipMin != null) { - updateShortCircuitLimit(ipMin.getValue(), oldIpMin, "Low short circuit current limit", identifiableShortCircuitAdder::withIpMin, reports); + var newIpMin = ipMin.getValue(); + + identifiableShortCircuitAdder.withIpMin(newIpMin); + + //convert to kA to report it like the user set it. + var oldIpMinToReport = convertToKiloAmps(oldIpMin); + var newIpMinToReport = convertToKiloAmps(newIpMin); + reports.add(ModificationUtils.getInstance() + .buildModificationReport(oldIpMinToReport, newIpMinToReport, "Low short circuit current limit")); + } else if (oldIpMin != null) { + identifiableShortCircuitAdder.withIpMin(oldIpMin); } + if (ipMax != null) { - updateShortCircuitLimit(ipMax.getValue(), oldIpMax, "High short circuit current limit", identifiableShortCircuitAdder::withIpMax, reports); + var newIpMax = ipMax.getValue(); + identifiableShortCircuitAdder.withIpMax(newIpMax); + + //Convert to kA to report it like the user set it. + var oldIpMaxToReport = convertToKiloAmps(oldIpMax); + var newIpMaxToReport = convertToKiloAmps(newIpMax); + reports.add(ModificationUtils.getInstance() + .buildModificationReport(oldIpMaxToReport, newIpMaxToReport, "High short circuit current limit")); + } else if (oldIpMax != null) { + identifiableShortCircuitAdder.withIpMax(oldIpMax); } - } - private static void updateShortCircuitLimit(Double newValue, - Double oldValue, - String limitDescription, - Consumer setterMethod, - List reports) { - if (newValue != null) { - setterMethod.accept(newValue); - Double oldValueToReport = convertToKiloAmps(oldValue); - Double newValueToReport = convertToKiloAmps(newValue); - reports.add(ModificationUtils.getInstance().buildModificationReport(oldValueToReport, newValueToReport, limitDescription)); - } else if (oldValue != null) { - setterMethod.accept(oldValue); + identifiableShortCircuitAdder.add(); + if (subReportNode != null) { + reports.forEach(report -> insertReportNode(subReportNode, report)); } } From 55de8556519807c29117b7e2f42b6bdf02d811be Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 18 Sep 2024 12:39:34 +0200 Subject: [PATCH 22/23] clean imports Signed-off-by: Mathieu DEHARBE --- .../server/modifications/VoltageLevelModification.java | 1 - 1 file changed, 1 deletion(-) diff --git a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java index aca5bee9e..0fb9eebc3 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/VoltageLevelModification.java @@ -15,7 +15,6 @@ import org.gridsuite.modification.server.NetworkModificationException; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.VoltageLevelModificationInfos; -import java.util.function.Consumer; import java.util.ArrayList; import java.util.List; From 1bf83ed7aa1af95619a8b49c67e4ce8b0e98c6f9 Mon Sep 17 00:00:00 2001 From: Mathieu DEHARBE Date: Wed, 25 Sep 2024 12:25:39 +0200 Subject: [PATCH 23/23] post review Signed-off-by: Mathieu DEHARBE --- .../server/dto/formula/equipmentfield/GeneratorField.java | 5 ++--- .../server/modifications/ByFormulaModification.java | 2 +- .../server/modifications/GeneratorModification.java | 4 ++-- 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java index 83063f9ef..d36390c58 100644 --- a/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java +++ b/src/main/java/org/gridsuite/modification/server/dto/formula/equipmentfield/GeneratorField.java @@ -14,7 +14,6 @@ import com.powsybl.iidm.network.extensions.GeneratorShortCircuit; import com.powsybl.iidm.network.extensions.GeneratorStartup; import com.powsybl.network.store.iidm.impl.extensions.CoordinatedReactiveControlAdderImpl; -import jakarta.validation.constraints.NotNull; import org.gridsuite.modification.server.dto.AttributeModification; import org.gridsuite.modification.server.dto.OperationType; import org.gridsuite.modification.server.modifications.ModificationUtils; @@ -66,7 +65,7 @@ public static Double getReferenceValue(Generator generator, String generatorFiel }; } - public static void setNewValue(Generator generator, String generatorField, @NotNull Double newValue) { + public static void setNewValue(Generator generator, String generatorField, double newValue) { if (!Double.isNaN(newValue)) { GeneratorField field = GeneratorField.valueOf(generatorField); final AttributeModification attributeModification = new AttributeModification<>(newValue, OperationType.SET); @@ -97,7 +96,7 @@ public static void setNewValue(Generator generator, String generatorField, @NotN ActivePowerControl activePowerControl = generator.getExtension(ActivePowerControl.class); ActivePowerControlAdder activePowerControlAdder = generator.newExtension(ActivePowerControlAdder.class); ModificationUtils.getInstance().modifyActivePowerControlAttributes(activePowerControl, activePowerControlAdder, null, - new AttributeModification<>(newValue.floatValue(), OperationType.SET), null, null); + new AttributeModification<>((float) newValue, OperationType.SET), null, null); } case TRANSIENT_REACTANCE -> modifyGeneratorShortCircuitAttributes(attributeModification, null, generator, null); case STEP_UP_TRANSFORMER_REACTANCE -> modifyGeneratorShortCircuitAttributes(null, attributeModification, generator, null); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java index e50fb6038..a1f119008 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/ByFormulaModification.java @@ -266,7 +266,7 @@ private void applyFormula(Identifiable identifiable, try { final Double newValue = applyOperation(formulaInfos.getOperator(), value1, value2); switch (identifiable.getType()) { - case GENERATOR -> GeneratorField.setNewValue((Generator) identifiable, formulaInfos.getEditedField(), newValue); + case GENERATOR -> GeneratorField.setNewValue((Generator) identifiable, formulaInfos.getEditedField(), newValue.doubleValue()); case BATTERY -> BatteryField.setNewValue((Battery) identifiable, formulaInfos.getEditedField(), newValue); case SHUNT_COMPENSATOR -> ShuntCompensatorField.setNewValue((ShuntCompensator) identifiable, formulaInfos.getEditedField(), newValue); case VOLTAGE_LEVEL -> VoltageLevelField.setNewValue((VoltageLevel) identifiable, formulaInfos.getEditedField(), newValue); diff --git a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java index d534a1ed5..71a4508b9 100644 --- a/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java +++ b/src/main/java/org/gridsuite/modification/server/modifications/GeneratorModification.java @@ -460,9 +460,9 @@ public static ReportNode modifyTargetQ(Generator generator, AttributeModificatio ReportNode reportReactivePower = null; if (modifTargetQ != null) { if (modifTargetQ.getOp() == OperationType.SET) { - reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetQ, generator::getTargetQ, modifTargetQ, "Reactive power"); + reportReactivePower = ModificationUtils.getInstance().applyElementaryModificationsAndReturnReport(generator::setTargetQ, generator::getTargetQ, modifTargetQ, "Target reactive power"); } else { - reportReactivePower = ModificationUtils.getInstance().buildModificationReport(generator.getTargetQ(), Double.NaN, "Reactive power"); + reportReactivePower = ModificationUtils.getInstance().buildModificationReport(generator.getTargetQ(), Double.NaN, "Target reactive power"); } } return reportReactivePower;