Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generic Area model in IIDM #2955

Merged
merged 155 commits into from
Jun 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
155 commits
Select commit Hold shift + click to select a range
8bc88d6
Create Area and AreaType API and Impl
m-guibert Mar 27, 2024
5d5a612
Merge branch 'main' into 2883_iidm_generic_area_model
m-guibert Mar 27, 2024
b453033
Move AIC related methods to new AicArea API and impl
m-guibert Apr 8, 2024
4b571ae
Create adders for Area and AreaType
m-guibert Apr 8, 2024
2bfa64f
Update to IIDM version 1.13
colinepiloquet Apr 10, 2024
a7230f4
add Area attribute to voltageLevels and store Areas in the Network
vmouradian Apr 12, 2024
e349fa0
refactor interfaces
vmouradian Apr 17, 2024
6291db1
store areas in NetworkIndex and implement new interface
vmouradian Apr 17, 2024
aba1dc2
implement new methods (in particular : add VoltageLevel to Area and v…
vmouradian Apr 17, 2024
46599c1
implement new interface of AreaAdder
vmouradian Apr 17, 2024
dbecfe5
clean and checkstyle
vmouradian Apr 17, 2024
4fef0ae
AreaTypeAdder implemented
vmouradian Apr 17, 2024
3e8dc92
update interfaces (ex: stream/iterable getters)
vmouradian Apr 17, 2024
c484b70
implement new interface
vmouradian Apr 17, 2024
5cec967
create basic unit tests
vmouradian Apr 17, 2024
4f6bfe0
Create and implement AicAreaAdder
vmouradian Apr 19, 2024
ab1a19f
updates AreasTests
vmouradian Apr 19, 2024
3e057de
adjust interfaces and clarify Area add
vmouradian Apr 19, 2024
04cd7b3
network interface for getAreas... gives Areas and AicAreas
vmouradian Apr 19, 2024
5e7df53
subnetwork calls to areas redirected to parent Network
vmouradian Apr 19, 2024
bc2c983
update Network interface
vmouradian Apr 19, 2024
24e7d55
improve Unit tests
vmouradian Apr 19, 2024
ba6ec04
clean
vmouradian Apr 19, 2024
adc2dd6
refactor Area and AicArea adders with abstract classes to share code …
vmouradian Apr 22, 2024
984a01c
Add unit test for Subnetwork Area adding methods
vmouradian Apr 22, 2024
a3bd284
fix
colinepiloquet Apr 22, 2024
4e3feff
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet Apr 22, 2024
54227f4
Merge branch 'main' into 2883_iidm_generic_area_model
jeandemanged Apr 26, 2024
708e77b
copyright and authors
jeandemanged Apr 26, 2024
e8c4078
fix and disable binary tests
colinepiloquet Apr 26, 2024
15a6a13
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet Apr 26, 2024
a0f52f7
refacto iidm tck
jeandemanged Apr 26, 2024
01cad58
Merge remote-tracking branch 'refs/remotes/origin/evolution_xiidm/1.1…
jeandemanged Apr 26, 2024
b82b819
rename
jeandemanged Apr 26, 2024
92daa4b
Remove binary unit tests
flo-dup Apr 29, 2024
8766636
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet Apr 30, 2024
7d5e1a2
Fix xsd
colinepiloquet Apr 30, 2024
b255ca9
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet May 7, 2024
8e4dbd6
Add areas to Substation and SubstationImpl, with area adders (WIP)
m-guibert May 13, 2024
cbe7f6b
Merge remote-tracking branch 'origin/evolution_xiidm/1.13' into 2883_…
m-guibert May 16, 2024
4c7d9d0
Add SerDe for Area-s and AreaType-s (WIP)
m-guibert May 16, 2024
82f6ace
fix checkstyle
jeandemanged May 17, 2024
f94bda0
fix xsd
jeandemanged May 17, 2024
d0eef34
change file ref
vmouradian May 17, 2024
df698cc
Integrate AC position target and mismatch tolerance into Area data mo…
m-guibert May 17, 2024
c060a9d
Limit Area assignation to VoltageLevels
m-guibert May 17, 2024
8894d19
Serde unit tests update
vmouradian May 17, 2024
c46d3e3
small update of voltagelevel
vmouradian May 22, 2024
e14c796
serde for areas ac interchange
vmouradian May 22, 2024
e628c48
serde for areas of voltagelevels
vmouradian May 22, 2024
369a161
clean
vmouradian May 22, 2024
33b1efc
clean
vmouradian May 22, 2024
491bbdd
Add boundary points to Area-s
m-guibert May 22, 2024
02f8372
method to remove areas + update/clean unit tests
vmouradian May 22, 2024
b1d77dc
merge networks with areas (wip: boundaries not taken into account yet)
vmouradian May 22, 2024
fc6f43f
Code cleaning
m-guibert May 23, 2024
82a04cf
Delete obsolete AbstractAreaAdders
m-guibert May 23, 2024
19c2a5e
Improve exception message in AbstractVoltageLevel::addArea
m-guibert May 23, 2024
8c4b6df
Replace obsolete concat function in NetworkImpl::getAreaTypes
m-guibert May 23, 2024
57d196f
Refactor Area boundary terminals
m-guibert May 23, 2024
e09db45
Fix AbstractAreaTest::throwRemovedVoltageLevel
m-guibert May 23, 2024
5281c4d
update subnetwork areas implementation
vmouradian May 23, 2024
897792a
update areas merging
vmouradian May 23, 2024
45d0e48
update areas merging (clarify + more checks for mergeability)
vmouradian May 24, 2024
92d4f78
Refactor Area SerDe and add serde for its boundaryTerminals
m-guibert May 24, 2024
2f6bd01
update unit test for subnetwork Areas related implementation
vmouradian May 24, 2024
f88fa29
finalize removeArea/removeVoltageLevel implementation
vmouradian May 24, 2024
586e881
add copy() to AreaTypeAdder
vmouradian May 24, 2024
2b1c7a6
use new removeArea() method in merge
vmouradian May 24, 2024
bb44822
update exception message
vmouradian May 24, 2024
cfcca4f
adapt subnetwork detach() for Areas
vmouradian May 24, 2024
ef9a27e
update unit tests for merging
vmouradian May 24, 2024
e0ba715
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet May 27, 2024
52434ab
Fix
colinepiloquet May 27, 2024
77c55b9
clean
vmouradian May 27, 2024
54bf53a
update merge and detach
vmouradian May 27, 2024
9b6c593
Merge branch 'main' into evolution_xiidm/1.13
colinepiloquet May 27, 2024
485a765
Remove unused binary files
colinepiloquet May 27, 2024
3d2f95d
Merge remote-tracking branch 'origin/evolution_xiidm/1.13' into 2883_…
m-guibert May 27, 2024
c771491
Update imports: class Ref was moved
m-guibert May 27, 2024
aaf8c87
Add javadoc
m-guibert May 27, 2024
ceb3669
Fix name copy in AreaAdderImpl and AreaTypeAdderImpl
m-guibert May 29, 2024
e007feb
Move and refactor network merge and detach tests
m-guibert May 29, 2024
f2ebdc5
Add name assertions to mergeAndDetachWithAreas tests
m-guibert May 30, 2024
b126349
AreaType-s are now modelled by a simple String attribute in Area data…
m-guibert May 30, 2024
5f6ac95
Revert MergeTest to its initial state
m-guibert May 30, 2024
f1333c8
Add subnetworkRef to Area-s and update (sub)network methods accordingly
m-guibert May 30, 2024
cf94ac5
Revert merge and detach methods to their initial state: Area-s are no…
m-guibert May 30, 2024
0e1d65d
Update SerDe tests since areaType is now a simple string
m-guibert May 30, 2024
47d6cd7
Update SerDe xsd since areaType is now a simple string in the Area da…
m-guibert May 30, 2024
0885f72
Fix typo in AbstractAreaTest
m-guibert May 30, 2024
023e6b1
add count() methods in Network for Area and AreaType
vmouradian May 31, 2024
e36b00c
remove properties adder from AreaAdder
vmouradian May 31, 2024
e23a2c1
refactor add voltagelevels and boundaries to Areas (check same networ…
vmouradian May 31, 2024
a09b739
update unit tests
vmouradian May 31, 2024
e2dcaef
(wip) replace boundaryTerminals by the new AreaBoundary class
vmouradian Jun 3, 2024
895d750
(wip) AreaBoundarySerDe
vmouradian Jun 3, 2024
b1420e1
Area boundary terminals replaced by new class AreaBoundary
vmouradian Jun 3, 2024
ac77dd3
Serde for new class AreaBoundary
vmouradian Jun 3, 2024
6d303cd
move checks on areaBoundary attributes to the adder
vmouradian Jun 4, 2024
f37ed2c
fix code smells
vmouradian Jun 4, 2024
cc0e8de
Add methods to get the AC, DC or total net positions of an Area
m-guibert Jun 5, 2024
4b5dfe1
Delete the AC net interchange tolerance attribute from Area
m-guibert Jun 5, 2024
08bfa8e
Add a NetworkListener to Area-s to delete AreaBoundary-s when the cor…
m-guibert Jun 5, 2024
b3d7445
Refactor AbstractAreaTest::assertBoundaries
m-guibert Jun 5, 2024
04ff2c6
AreaBoundary should have a Boundary attribute instead of a DanglingLi…
m-guibert Jun 5, 2024
b059f0b
AreaBoundary should have a Boundary attribute instead of a DanglingLi…
m-guibert Jun 6, 2024
c9bd501
refactor adders for AreaBoundaries
vmouradian Jun 6, 2024
9a10db2
rename
vmouradian Jun 6, 2024
21f0172
add check for areaTypes creation
vmouradian Jun 6, 2024
acd5ff2
test for Serde with subnetworks and Areas
vmouradian Jun 6, 2024
10f8d1c
Merge branch 'main' into evolution_xiidm/1.13
jeandemanged Jun 7, 2024
5dc8ef5
Merge remote-tracking branch 'origin/evolution_xiidm/1.13' into 2883_…
m-guibert Jun 7, 2024
2794a1e
Fix Area net position sign to respect load convention
m-guibert Jun 7, 2024
01b9a38
AreaBoundary SerDe : use attributes instead of child nodes for termin…
vmouradian Jun 7, 2024
6cd6dd0
Add Area to doc (v0)
vmouradian Jun 7, 2024
1ed9673
add copyrigths and javadoc
vmouradian Jun 7, 2024
a2e1d7f
Improve Area documentation
m-guibert Jun 7, 2024
f40c8e8
Fix javadoc mentioning obsolete AreaType class
m-guibert Jun 10, 2024
f1f2d0b
update exception messages
vmouradian Jun 12, 2024
b933ca8
simplify
vmouradian Jun 12, 2024
e8eadde
update reference files for Area serde
vmouradian Jun 12, 2024
993baae
simplify Area Boundary serde
vmouradian Jun 12, 2024
77ae1f3
Write Areas only with iidm version >=13
vmouradian Jun 12, 2024
2796ed4
Update clean and make public tck unit tests
vmouradian Jun 12, 2024
a9f5cd0
add method to remove areas
vmouradian Jun 12, 2024
2c766e3
AreaImpl : share code + add comment
vmouradian Jun 12, 2024
d40f8ba
update doc and javadoc for interchange convention
vmouradian Jun 12, 2024
f2778f7
Add unit test for interchange of Area without boundary
vmouradian Jun 12, 2024
200b839
remove useless check for removed Area in private interchange getter
vmouradian Jun 12, 2024
e171b6a
update comment for voltage level remove
vmouradian Jun 12, 2024
aa3972f
remove area listener when removing Area
vmouradian Jun 12, 2024
f6a9fbf
small adjustements
vmouradian Jun 12, 2024
b3cb4d6
clean and rename NetInterchange to just Interchange
jeandemanged Jun 14, 2024
e09b213
made EurostagTutorialExample area test network better corresponding t…
jeandemanged Jun 14, 2024
995f006
fix
jeandemanged Jun 14, 2024
f9a9f7a
add AreaBoundary#getArea and Area#getAreaBoundary
jeandemanged Jun 14, 2024
eb0c7d1
some Objects.requireNonNull checks
jeandemanged Jun 14, 2024
2eb31b4
wip setter interchange target, multivariant, updateNotification
jeandemanged Jun 14, 2024
44a24ac
fix
jeandemanged Jun 14, 2024
24e8a21
clean
jeandemanged Jun 14, 2024
f283c47
clean
jeandemanged Jun 17, 2024
ca98715
Fix typo in Area::removeAreaBoundary javadoc
m-guibert Jun 17, 2024
f6b023c
Fix typo in Area::removeAreaBoundary javadoc
m-guibert Jun 17, 2024
316a2ce
test
jeandemanged Jun 17, 2024
76725f2
review fixes
jeandemanged Jun 17, 2024
68dbd54
fix
jeandemanged Jun 18, 2024
73dbdaa
Small fixes in the documentation
m-guibert Jun 18, 2024
74a3b3d
Small fix in the Area documentation
m-guibert Jun 18, 2024
5f417e1
Add a table with AreaBoundary attributes to the doc
m-guibert Jun 18, 2024
be7663f
explanation for the AreaBoundary AC flag
jeandemanged Jun 18, 2024
b3c4c83
Merge branch 'main' into evolution_xiidm/1.13
olperr1 Jun 18, 2024
58634e0
Merge remote-tracking branch 'refs/remotes/origin/evolution_xiidm/1.1…
jeandemanged Jun 18, 2024
9b0f0dc
Merge branch 'main' into 2883_iidm_generic_area_model
olperr1 Jun 19, 2024
756c0ad
Update docs/grid_model/network_subnetwork.md
jeandemanged Jun 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
50 changes: 50 additions & 0 deletions docs/grid_model/network_subnetwork.md
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,56 @@ When defining the model, the user has to specify how the different equipment con
- [Identifiable Short-Circuit](extensions.md#identifiable-short-circuit)
- [Slack Terminal](extensions.md#slack-terminal)

(area)=
## Area
[![Javadoc](https://img.shields.io/badge/-javadoc-blue.svg)](https://javadoc.io/doc/com.powsybl/powsybl-core/latest/com/powsybl/iidm/network/Area.html)

An Area is a geographical zone of a given type.

An Area is composed of a collection of [voltage levels](#voltage-level), and a collection of area boundaries.
Area boundaries can be terminals of equipments or `Boundary` objects from [dangling lines](#dangling-line).

The area type is used to distinguish between various area concepts of different granularity. For instance: control areas, bidding zones, countries...

A [voltage level](#voltage-level) can belong to several areas, as long as all areas are of different type.

The area boundaries define how interchange are to be calculated for the area.
Area interchange is calculated by summing the active power flows across the area boundaries and can be obtained for AC part only (considering only AC boundaries),
for DC part only (considering only DC boundaries) and in total (AC+DC).
Note that if the Area has no boundary explicitly defined, the interchange is considered 0 MW.

For area types that are meant to be used for area interchange control, e.g. in Load Flow simulations, the interchange target of the area can be specified as an input for the simulation.
Note that this target interchange is for only the AC part of the interchange.

All area interchange values use the load sign convention: positive values indicate that the area is importing, negative values that the area is exporting.

**Characteristics of an Area**

| Attribute | Unit | Description |
|-----------------------|------|----------------------------------------------------------------|
| $AreaType$ | | To specify the type of Area (eg. ControlArea, BiddingZone ...) |
| $AcInterchangeTarget$ | MW | Target AC active power interchange |
olperr1 marked this conversation as resolved.
Show resolved Hide resolved
| $VoltageLevels$ | | List of voltage levels of the area |
| $AreaBoundaries$ | | List of area boundaries of the area |

**Characteristics of an AreaBoundary**

An area boundary is modeled by an `AreaBoundary` instance.
It is composed of either DanglingLine Boundary or a Terminal, and boolean telling if the area boundary
is to be considered as AC or DC.

The `Ac` flag is informative and is present to support the use case where boundaries are defined on AC components even though
the boundary is related to an HVDC link. An example for this is a DanglingLine (which is an AC equipment) that may actually represent
an HVDC interconnection that is not explicitly described in the network model. This information is used when computing area interchanges,
which are then separated for AC and DC parts.

| Attribute | Unit | Description |
|------------|------|-----------------------------------------------------------------------------|
| $Area$ | | The area of this boundary |
| $Boundary$ | | Boundary of a DanglingLine (mutually exclusive with the Terminal attribute) |
| $Terminal$ | | Terminal of an equipment (mutually exclusive with the Boundary attribute) |
| $Ac$ | | True if AreaBoundary is to be considered AC, false otherwise |

(generator)=
## Generator
[![Javadoc](https://img.shields.io/badge/-javadoc-blue.svg)](https://javadoc.io/doc/com.powsybl/powsybl-core/latest/com/powsybl/iidm/network/Generator.html)
Expand Down
191 changes: 191 additions & 0 deletions iidm/iidm-api/src/main/java/com/powsybl/iidm/network/Area.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,191 @@
/**
* Copyright (c) 2024, Coreso SA (https://www.coreso.eu/) and TSCNET Services GmbH (https://www.tscnet.eu/)
* 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.iidm.network;

import java.util.OptionalDouble;
import java.util.stream.Stream;

/**
* An Area is a geographical zone of a given type.
* <p> An Area is composed of a collection of voltage levels, and a collection of area boundaries.
* <p> The area type is used to distinguish between various area concepts of different granularity.
* For instance: control areas, bidding zones, countries...
* <p> To create an Area, see {@link AreaAdder}
*
* <p>
* Characteristics
* </p>
*
* <table style="border: 1px solid black; border-collapse: collapse">
* <thead>
* <tr>
* <th style="border: 1px solid black">Attribute</th>
* <th style="border: 1px solid black">Type</th>
* <th style="border: 1px solid black">Unit</th>
* <th style="border: 1px solid black">Required</th>
* <th style="border: 1px solid black">Default value</th>
* <th style="border: 1px solid black">Description</th>
* </tr>
* </thead>
* <tbody>
* <tr>
* <td style="border: 1px solid black">Id</td>
* <td style="border: 1px solid black">String</td>
* <td style="border: 1px solid black"> - </td>
* <td style="border: 1px solid black">yes</td>
* <td style="border: 1px solid black"> - </td>
* <td style="border: 1px solid black">Unique identifier of the Area</td>
* </tr>
* <tr>
* <td style="border: 1px solid black">Name</td>
* <td style="border: 1px solid black">String</td>
* <td style="border: 1px solid black">-</td>
* <td style="border: 1px solid black">no</td>
* <td style="border: 1px solid black"> - </td>
* <td style="border: 1px solid black">Human-readable name of the Area</td>
* </tr>
* <tr>
* <td style="border: 1px solid black">AreaType</td>
* <td style="border: 1px solid black">String</td>
* <td style="border: 1px solid black">-</td>
* <td style="border: 1px solid black">yes</td>
* <td style="border: 1px solid black"> - </td>
* <td style="border: 1px solid black">The type of Area. For instance: "ControlArea", "BiddingZone", "Country"...</td>
* </tr>
* <tr>
* <td style="border: 1px solid black">AcInterchangeTarget</td>
* <td style="border: 1px solid black">Double</td>
* <td style="border: 1px solid black">-</td>
* <td style="border: 1px solid black">no</td>
* <td style="border: 1px solid black"> - </td>
* <td style="border: 1px solid black">The optional target AC Interchange of this area in MW, using load sign convention (negative is export, positive is import)</td>
* </tr>
* </tbody>
* </table>
*
* @author Marine Guibert {@literal <marine.guibert at artelys.com>}
* @author Valentin Mouradian {@literal <valentin.mouradian at artelys.com>}
* @see VoltageLevel
* @see AreaBoundary
* @see AreaAdder
*/
public interface Area extends Identifiable<Area> {
olperr1 marked this conversation as resolved.
Show resolved Hide resolved

/**
* Get the type of this area
*/
String getAreaType();

/**
* Get all area voltage levels.
*/
Iterable<VoltageLevel> getVoltageLevels();

/**
* Get all area voltage levels.
*/
Stream<VoltageLevel> getVoltageLevelStream();

/**
* Adds a voltage level to the area.
* @param voltageLevel voltage level to be added
*/
Area addVoltageLevel(VoltageLevel voltageLevel);

/**
* Removes the provided VoltageLevel from the area. The VoltageLevel is not removed from the network,
* the VoltageLevel is not part of the Area anymore.
* @param voltageLevel the VoltageLevel to be removed from the Area.
*/
Area removeVoltageLevel(VoltageLevel voltageLevel);

/**
* @return adder to create a new area boundary
*/
AreaBoundaryAdder newAreaBoundary();

/**
* If exists, remove the area boundary associated with the provided terminal.
* The Terminal and its Connectable are not removed from the network, but are not part of the Area anymore.
* @param terminal terminal
*/
Area removeAreaBoundary(Terminal terminal);

/**
* If exists, remove the area boundary associated with the provided DanglingLine's Boundary.
* The DanglingLine and its Boundary are not removed from the network, but are not part of the Area anymore.
* @param boundary DanglingLine's boundary
*/
Area removeAreaBoundary(Boundary boundary);

/**
* If found, returns the area boundary associated with the provided DanglingLine's Boundary.
* Otherwise, null is returned.
* @param boundary DanglingLine's boundary
*/
AreaBoundary getAreaBoundary(Boundary boundary);

/**
* If found, returns the area boundary associated with the provided Terminal.
* Otherwise, null is returned.
* @param terminal terminal
*/
AreaBoundary getAreaBoundary(Terminal terminal);

/**
* Get all area boundaries.
*/
Iterable<AreaBoundary> getAreaBoundaries();

/**
* Get all area boundaries.
*/
Stream<AreaBoundary> getAreaBoundaryStream();

@Override
default IdentifiableType getType() {
return IdentifiableType.AREA;
}

/**
* Get the optional target AC Interchange of this area in MW, in load sign convention (negative is export, positive is import).
* <p>Depends on the working variant.</p>
*
* @return the AC Interchange target (MW)
*/
OptionalDouble getAcInterchangeTarget();

/**
* Set the target AC Interchange of this area in MW, in load sign convention (negative is export, positive is import).
* Providing Double.NaN removes the target.
* <p>Depends on the working variant.</p>
* @param acInterchangeTarget new AC interchange target (MW)
*/
Area setAcInterchangeTarget(double acInterchangeTarget);

/**
* Get the current AC Interchange of this area in MW, in load sign convention (negative is export, positive is import)
* @return the AC position (MW, 0 MW if no boundary)
*/
double getAcInterchange();

/**
* Get the current DC Interchange of this area in MW, in load sign convention (negative is export, positive is import)
* @return the DC position (MW, 0 MW if no boundary)
*/
double getDcInterchange();

/**
* Get the current total (AC+DC) Interchange of this area in MW, in load sign convention (negative is export, positive is import)
* @return the total position (MW, 0 MW if no boundary)
*/
double getTotalInterchange();

void remove();

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
/**
* Copyright (c) 2024, Coreso SA (https://www.coreso.eu/) and TSCNET Services GmbH (https://www.tscnet.eu/)
* 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.iidm.network;

/**
* To create an Area, from a <code>Network</code> instance call
* the {@link Network#newArea()} method to get an Area builder instance.
* <p>
* Example:
*<pre>
* Network n = ...
* Area a = n.newArea()
* .setId("FR")
* ...
* .add();
*</pre>
*
* @author Marine Guibert {@literal <marine.guibert at artelys.com>}
* @author Valentin Mouradian {@literal <valentin.mouradian at artelys.com>}
* @see Area
* @see Network
*/
public interface AreaAdder extends IdentifiableAdder<Area, AreaAdder> {

/**
* Set the Area type
*/
AreaAdder setAreaType(String areaType);

/**
* Set the target AC Interchange of this area in MW, in load sign convention (negative is export, positive is import).
*/
AreaAdder setAcInterchangeTarget(double acInterchangeTarget);

/**
* add a VoltageLevel to the Area
*/
AreaAdder addVoltageLevel(VoltageLevel voltageLevel);

/**
* add a Terminal as an area boundary
*/
AreaAdder addAreaBoundary(Terminal terminal, boolean ac);

/**
* add a DanglingLine boundary as an area boundary
*/
AreaAdder addAreaBoundary(Boundary boundary, boolean ac);

/**
* Build the Area object.
* <p>These are the checks that are performed before creating the object :</p>
* <ul>
* <li>areaType is not null;</li>
* </ul>
* @return {@link Area}
*/
@Override
Area add();
}
Loading