Skip to content

Commit

Permalink
Test is ok
Browse files Browse the repository at this point in the history
Signed-off-by: Hadrien <[email protected]>
  • Loading branch information
Hadrien-Godard committed Jun 7, 2022
1 parent 15436b7 commit 6707e39
Showing 1 changed file with 17 additions and 8 deletions.
25 changes: 17 additions & 8 deletions src/main/java/com/powsybl/openloadflow/sa/DcSecurityAnalysis.java
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,7 @@ SecurityAnalysisReport runSync(String workingVariantId, SecurityAnalysisParamete
}
detector.checkActivePower(branch, Branch.Side.ONE, Math.abs(v.getFunctionReference()),
violation -> violations.put(Pair.of(violation.getSubjectId(), violation.getSide()), violation));
checkDcCurrent(branch, Math.abs(v.getFunctionReference()), violations);
}
preContingencyLimitViolationsMap.forEach((subjectSideId, preContingencyViolation) -> {
LimitViolation postContingencyViolation = violations.get(subjectSideId);
Expand All @@ -117,17 +118,25 @@ private void checkDcCurrent(Branch<?> branch, double activePower, Map<Pair<Strin
double cosPhi = Math.cos(Math.atan(0.4));
// Permanent limits
// Check side 1
double branchCurrent1 = currentFromAdnActivePower(activePower, branch.getTerminal1().getVoltageLevel().getNominalV(), cosPhi);
if (branchCurrent1 > branch.getCurrentLimits1().getPermanentLimit()) {
LimitViolation violation = new LimitViolation(branch.getId(), LimitViolationType.CURRENT, "Current_Violation_1_" + branch.getId(), 2147483647, branch.getCurrentLimits1().getPermanentLimit(), 0, branchCurrent1, Branch.Side.ONE);
preContingencyLimitViolationsMap.put(Pair.of(violation.getSubjectId(), violation.getSide()), violation);
try {
double permanentLimit1 = branch.getCurrentLimits1().getPermanentLimit();
double branchCurrent1 = currentFromAdnActivePower(activePower, branch.getTerminal1().getVoltageLevel().getNominalV(), cosPhi);
if (branchCurrent1 > permanentLimit1) {
LimitViolation violation = new LimitViolation(branch.getId(), LimitViolationType.CURRENT, "Current_Permanent_Limit_Violation_1_" + branch.getId(), 2147483647, permanentLimit1, 1, branchCurrent1, Branch.Side.ONE);
preContingencyLimitViolationsMap.put(Pair.of(violation.getSubjectId(), violation.getSide()), violation);
}
} catch (NullPointerException ignored) {
}

// Check side 2
double branchCurrent2 = currentFromAdnActivePower(activePower, branch.getTerminal2().getVoltageLevel().getNominalV(), cosPhi);
if (branchCurrent2 > branch.getCurrentLimits2().getPermanentLimit()) {
LimitViolation violation = new LimitViolation(branch.getId(), LimitViolationType.CURRENT, "Current_Violation_2_" + branch.getId(), 2147483647, branch.getCurrentLimits2().getPermanentLimit(), 0, branchCurrent2, Branch.Side.TWO);
preContingencyLimitViolationsMap.put(Pair.of(violation.getSubjectId(), violation.getSide()), violation);
try {
double permanentLimit2 = branch.getCurrentLimits2().getPermanentLimit();
double branchCurrent2 = currentFromAdnActivePower(activePower, branch.getTerminal2().getVoltageLevel().getNominalV(), cosPhi);
if (branchCurrent2 > permanentLimit2) {
LimitViolation violation = new LimitViolation(branch.getId(), LimitViolationType.CURRENT, "Current_Permanent_Limit_Violation_2_" + branch.getId(), 2147483647, permanentLimit2, 1, branchCurrent2, Branch.Side.TWO);
preContingencyLimitViolationsMap.put(Pair.of(violation.getSubjectId(), violation.getSide()), violation);
}
} catch (NullPointerException ignored) {
}
// TODO: temporary limits
}
Expand Down

0 comments on commit 6707e39

Please sign in to comment.