-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test(OPLF/NewtonCriteria): added new class test for Newton-Raphson st…
…opping criteria Signed-off-by: Alexandre Le Jean <alexandre.le-jean@artelys.com>
- Loading branch information
Showing
1 changed file
with
132 additions
and
0 deletions.
There are no files selected for viewing
132 changes: 132 additions & 0 deletions
132
src/test/java/com/powsybl/openloadflow/ac/nr/NewtonRaphsonStoppingCriteriaTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
/** | ||
* Copyright (c) 2019, RTE (http://www.rte-france.com) | ||
* This Source Code Form is subject to the terms of the Mozilla Public | ||
* License, v. 2.0. If a copy of the MPL was not distributed with this | ||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. | ||
* SPDX-License-Identifier: MPL-2.0 | ||
*/ | ||
package com.powsybl.openloadflow.ac.nr; | ||
|
||
import com.powsybl.iidm.network.Network; | ||
import com.powsybl.loadflow.LoadFlow; | ||
import com.powsybl.loadflow.LoadFlowParameters; | ||
import com.powsybl.loadflow.LoadFlowResult; | ||
import com.powsybl.math.matrix.DenseMatrixFactory; | ||
import com.powsybl.openloadflow.OpenLoadFlowParameters; | ||
import com.powsybl.openloadflow.OpenLoadFlowProvider; | ||
import com.powsybl.openloadflow.network.BoundaryFactory; | ||
import org.junit.jupiter.api.BeforeEach; | ||
import org.junit.jupiter.api.Test; | ||
|
||
import static org.junit.jupiter.api.Assertions.*; | ||
|
||
/** | ||
* @author Alexandre Le Jean <alexandre.le-jean at artelys.com> | ||
*/ | ||
class NewtonRaphsonStoppingCriteriaTest { | ||
|
||
private Network network; | ||
private LoadFlow.Runner loadFlowRunner; | ||
private LoadFlowParameters parameters; | ||
|
||
@BeforeEach | ||
void setUp() { | ||
network = BoundaryFactory.create(); | ||
loadFlowRunner = new LoadFlow.Runner(new OpenLoadFlowProvider(new DenseMatrixFactory())); | ||
parameters = new LoadFlowParameters(); | ||
} | ||
|
||
@Test | ||
void testDefaultUniformCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.UNIFORM_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(2, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testConvergedUniformCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setNewtonRaphsonConvEpsPerEq(0.1) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.UNIFORM_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(1, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testDefaultPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(2, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testVoltageConvergedPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxVoltageMismatch(1) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(2, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testVoltageMaxIterationPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxVoltageMismatch(0) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertFalse(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.MAX_ITERATION_REACHED, result.getComponentResults().get(0).getStatus()); | ||
} | ||
|
||
@Test | ||
void testActivePowerConvergedPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxActivePowerMismatch(0.038) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(2, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testActivePowerMaxIterationPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxActivePowerMismatch(0) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertFalse(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.MAX_ITERATION_REACHED, result.getComponentResults().get(0).getStatus()); | ||
} | ||
|
||
@Test | ||
void testReactivePowerConvergedPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxReactivePowerMismatch(1E-11) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertTrue(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.CONVERGED, result.getComponentResults().get(0).getStatus()); | ||
assertEquals(5, result.getComponentResults().get(0).getIterationCount()); | ||
} | ||
|
||
@Test | ||
void testReactivePowerMaxIterationPerEquationCriteria() { | ||
OpenLoadFlowParameters.create(parameters) | ||
.setMaxReactivePowerMismatch(0) | ||
.setNewtonRaphsonStoppingCriteriaType(NewtonRaphsonStoppingCriteriaType.PER_EQUATION_TYPE_CRITERIA); | ||
LoadFlowResult result = loadFlowRunner.run(network, parameters); | ||
assertFalse(result.isOk()); | ||
assertEquals(LoadFlowResult.ComponentResult.Status.MAX_ITERATION_REACHED, result.getComponentResults().get(0).getStatus()); | ||
} | ||
} |