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

Modify diagram apis #522

Merged
merged 47 commits into from
Sep 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
39b4eb0
Bump to v4.0.0-SNAPSHOT
So-Fras Apr 6, 2023
f05813c
Remove test jars usage (#515)
tadam50 May 31, 2023
472c544
change on network-area-diagram
So-Fras May 31, 2023
90ed0a8
change in single-line-diagram-cgmes
So-Fras May 31, 2023
e541a67
changes on single line diagram
So-Fras Jun 4, 2023
7a32a6d
make Config network agnostic (for SLD, already done for NAD)
So-Fras Jun 5, 2023
919a381
rename Config in Param
So-Fras Jun 5, 2023
79b6b66
fix omissions in Config -> Param renaming
So-Fras Jun 5, 2023
c7f2ad1
decrease code smell number
So-Fras Jun 6, 2023
ca8a44c
change on network-area-diagram
So-Fras May 31, 2023
1b7e1d1
change in single-line-diagram-cgmes
So-Fras May 31, 2023
a44deed
changes on single line diagram
So-Fras Jun 4, 2023
6941f1c
make Config network agnostic (for SLD, already done for NAD)
So-Fras Jun 5, 2023
4c3ebd1
rename Config in Param
So-Fras Jun 5, 2023
e9bcd3f
fix omissions in Config -> Param renaming
So-Fras Jun 5, 2023
34a8f9c
decrease code smell number
So-Fras Jun 6, 2023
1d31539
fix problems following rebase of main
So-Fras Jun 9, 2023
bcab707
changes following review
So-Fras Jun 19, 2023
1628b6a
update test references following svgParameters addition in metadata
So-Fras Jun 19, 2023
7a0547e
add @FunctionalInterface annotations + add missing ownership and auth…
So-Fras Jun 27, 2023
1ca0a62
following review: default VoltageLevelLayoutFactory should be the Sma…
So-Fras Jun 27, 2023
1682303
Merge branch 'main' into modify_diagram_apis
So-Fras Jul 11, 2023
f48f439
fix problem following update of branch with respect to main
So-Fras Jul 11, 2023
20b5e43
Merge branch 'main' into modify_diagram_apis
geofjamg Jul 13, 2023
eea4c52
add a StyleProviderFactory to be used in pypowsybl
So-Fras Jul 21, 2023
9d163fe
Merge branch 'main' into modify_diagram_apis
So-Fras Jul 28, 2023
575db17
Merge branch 'main' into modify_diagram_apis
So-Fras Jul 31, 2023
8691940
Merge branch 'modify_diagram_apis' of https://github.com/powsybl/pows…
So-Fras Aug 28, 2023
4869f4a
Merge branch 'main' into modify_diagram_apis
So-Fras Aug 28, 2023
d924398
Merge branch 'modify_diagram_apis' of https://github.com/powsybl/pows…
So-Fras Aug 28, 2023
bfbb02a
fix remaining problems following merge
So-Fras Aug 30, 2023
7cb337c
classify functions in SingleLineDiagram and NetworkAreaDiagram classe…
So-Fras Aug 30, 2023
616165f
add license identifier
So-Fras Aug 30, 2023
cc17f7d
add non null checks in SLD SvgParameters
So-Fras Aug 30, 2023
d8a1a43
factorize preDrawVoltageLevel and preDrawSubstation functions
So-Fras Aug 30, 2023
f5943b5
remove the builder classes for SldParameters and NadParameters
So-Fras Aug 31, 2023
ba52595
Merge branch 'main' into modify_diagram_apis
So-Fras Aug 31, 2023
4e971ca
create DefaultSvgWriter inside draw function to clean test code
So-Fras Sep 5, 2023
f881c80
Merge branch 'main' into modify_diagram_apis
So-Fras Sep 12, 2023
32a66b8
fix new test in TieLineTest to fit with new API design
So-Fras Sep 12, 2023
7478e4e
Merge branch 'main' into modifyd-iagram_apis
So-Fras Sep 25, 2023
4935442
Add multi substation draw functions to API
So-Fras Sep 25, 2023
5762046
Improve VoltageLevelLayoutFactoryCreator user-friendliness
So-Fras Sep 26, 2023
b659685
Merge branch 'main' into modify_diagram_apis
So-Fras Sep 26, 2023
71ab128
Merge branch 'main' into modify_diagram_apis
So-Fras Sep 27, 2023
9fe2fa8
Clean
geofjamg Sep 27, 2023
0e505fd
Clean
geofjamg Sep 27, 2023
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
2 changes: 2 additions & 0 deletions network-area-diagram/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
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

-->
<project xmlns="http://maven.apache.org/POM/4.0.0"
Expand Down Expand Up @@ -87,6 +88,7 @@
<artifactId>jimfs</artifactId>
<scope>test</scope>
</dependency>

</dependencies>

</project>
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
/**
* Copyright (c) 2023, 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.nad;

import com.powsybl.iidm.network.Network;
import com.powsybl.nad.build.iidm.IntIdProvider;
import com.powsybl.nad.layout.BasicForceLayoutFactory;
import com.powsybl.nad.layout.LayoutFactory;
import com.powsybl.nad.layout.LayoutParameters;
import com.powsybl.nad.svg.LabelProvider;
import com.powsybl.nad.svg.SvgParameters;
import com.powsybl.nad.svg.iidm.*;

import java.util.Objects;

/**
*
* @author Sophie Frasnedo <sophie.frasnedo at rte-france.com>
*/
public class NadParameters {

private SvgParameters svgParameters = new SvgParameters();
private LayoutParameters layoutParameters = new LayoutParameters();
private StyleProviderFactory styleProviderFactory = TopologicalStyleProvider::new;
private LabelProviderFactory labelProviderFactory = DefaultLabelProvider::new;
private LayoutFactory layoutFactory = new BasicForceLayoutFactory();
private IdProviderFactory idProviderFactory = IntIdProvider::new;

public SvgParameters getSvgParameters() {
return svgParameters;
}

public NadParameters setSvgParameters(SvgParameters svgParameters) {
this.svgParameters = Objects.requireNonNull(svgParameters);
return this;
}

public LayoutParameters getLayoutParameters() {
return layoutParameters;
}

public NadParameters setLayoutParameters(LayoutParameters layoutParameters) {
this.layoutParameters = Objects.requireNonNull(layoutParameters);
return this;
}

public StyleProviderFactory getStyleProviderFactory() {
return styleProviderFactory;
}

public NadParameters setStyleProviderFactory(StyleProviderFactory styleProviderFactory) {
this.styleProviderFactory = Objects.requireNonNull(styleProviderFactory);
return this;
}

public LabelProvider createLabelProvider(Network network) {
return labelProviderFactory.create(network, svgParameters);
So-Fras marked this conversation as resolved.
Show resolved Hide resolved
}

public NadParameters setLabelProviderFactory(LabelProviderFactory labelProviderFactory) {
this.labelProviderFactory = Objects.requireNonNull(labelProviderFactory);
return this;
}

public LayoutFactory getLayoutFactory() {
return layoutFactory;
}

public NadParameters setLayoutFactory(LayoutFactory layoutFactory) {
this.layoutFactory = Objects.requireNonNull(layoutFactory);
return this;
}

public IdProviderFactory getIdProviderFactory() {
return idProviderFactory;
}

public NadParameters setIdProviderFactory(IdProviderFactory idProviderFactory) {
this.idProviderFactory = Objects.requireNonNull(idProviderFactory);
return this;
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -3,25 +3,18 @@
* 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.nad;

import com.powsybl.commons.PowsyblException;
import com.powsybl.iidm.network.Network;
import com.powsybl.iidm.network.VoltageLevel;
import com.powsybl.nad.build.iidm.IdProvider;
import com.powsybl.nad.build.iidm.IntIdProvider;
import com.powsybl.nad.build.iidm.NetworkGraphBuilder;
import com.powsybl.nad.build.iidm.VoltageLevelFilter;
import com.powsybl.nad.layout.BasicForceLayoutFactory;
import com.powsybl.nad.layout.LayoutFactory;
import com.powsybl.nad.layout.LayoutParameters;
import com.powsybl.nad.model.Graph;
import com.powsybl.nad.svg.LabelProvider;
import com.powsybl.nad.svg.StyleProvider;
import com.powsybl.nad.svg.SvgParameters;
import com.powsybl.nad.svg.SvgWriter;
import com.powsybl.nad.svg.iidm.DefaultLabelProvider;
import com.powsybl.nad.svg.iidm.TopologicalStyleProvider;

import java.io.IOException;
import java.io.StringWriter;
Expand All @@ -35,116 +28,74 @@
/**
* @author Florian Dupuy <florian.dupuy at rte-france.com>
*/
public class NetworkAreaDiagram {
public final class NetworkAreaDiagram {

private final Network network;
private final Predicate<VoltageLevel> voltageLevelFilter;

public NetworkAreaDiagram(Network network) {
this(network, VoltageLevelFilter.NO_FILTER);
}

public NetworkAreaDiagram(Network network, String voltageLevelId, int depth) {
this(network, VoltageLevelFilter.createVoltageLevelDepthFilter(network, voltageLevelId, depth));
}

public NetworkAreaDiagram(Network network, List<String> voltageLevelIds) {
this(network, VoltageLevelFilter.createVoltageLevelsFilter(network, voltageLevelIds));
}

public NetworkAreaDiagram(Network network, List<String> voltageLevelIds, int depth) {
this(network, VoltageLevelFilter.createVoltageLevelsDepthFilter(network, voltageLevelIds, depth));
}

public NetworkAreaDiagram(Network network, Predicate<VoltageLevel> voltageLevelFilter) {
this.network = Objects.requireNonNull(network);
this.voltageLevelFilter = Objects.requireNonNull(voltageLevelFilter);
}

public Network getNetwork() {
return network;
}

public void draw(Path svgFile) {
draw(svgFile, new SvgParameters());
private NetworkAreaDiagram() {
}

public void draw(Path svgFile, SvgParameters svgParameters) {
draw(svgFile, svgParameters, new LayoutParameters());
public static void draw(Network network, Path svgFile) {
draw(network, svgFile, new NadParameters(), VoltageLevelFilter.NO_FILTER);
}

public void draw(Path svgFile, SvgParameters svgParameters, LayoutParameters layoutParameters) {
draw(svgFile, svgParameters, layoutParameters, new TopologicalStyleProvider(network));
public static void draw(Network network, Writer writer) {
draw(network, writer, new NadParameters(), VoltageLevelFilter.NO_FILTER);
}

public void draw(Path svgFile, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider) {
draw(svgFile, svgParameters, layoutParameters, styleProvider, new DefaultLabelProvider(network, svgParameters));
public static void draw(Network network, Path svgFile, String voltageLevelId, int depth) {
draw(network, svgFile, new NadParameters(), VoltageLevelFilter.createVoltageLevelDepthFilter(network, voltageLevelId, depth));
}

public void draw(Path svgFile, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider) {
draw(svgFile, svgParameters, layoutParameters, styleProvider, labelProvider, new BasicForceLayoutFactory());
public static void draw(Network network, Writer writer, String voltageLevelId, int depth) {
draw(network, writer, new NadParameters(), VoltageLevelFilter.createVoltageLevelDepthFilter(network, voltageLevelId, depth));
}

public void draw(Path svgFile, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider, LayoutFactory layoutFactory) {
draw(svgFile, svgParameters, layoutParameters, styleProvider, labelProvider, layoutFactory, new IntIdProvider());
public static void draw(Network network, Path svgFile, List<String> voltageLevelIds) {
draw(network, svgFile, new NadParameters(), VoltageLevelFilter.createVoltageLevelsFilter(network, voltageLevelIds));
}

public void draw(Path svgFile, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider, LayoutFactory layoutFactory,
IdProvider idProvider) {
Objects.requireNonNull(svgFile);
Objects.requireNonNull(layoutParameters);
Objects.requireNonNull(svgParameters);
Objects.requireNonNull(styleProvider);
Objects.requireNonNull(layoutFactory);
Objects.requireNonNull(idProvider);

Graph graph = new NetworkGraphBuilder(network, voltageLevelFilter, idProvider).buildGraph();
layoutFactory.create().run(graph, layoutParameters);
new SvgWriter(svgParameters, styleProvider, labelProvider).writeSvg(graph, svgFile);
public static void draw(Network network, Writer writer, List<String> voltageLevelIds) {
draw(network, writer, new NadParameters(), VoltageLevelFilter.createVoltageLevelsFilter(network, voltageLevelIds));
}

public void draw(Writer writer) {
draw(writer, new SvgParameters());
public static void draw(Network network, Path svgFile, List<String> voltageLevelIds, int depth) {
draw(network, svgFile, new NadParameters(), VoltageLevelFilter.createVoltageLevelsDepthFilter(network, voltageLevelIds, depth));
}

public void draw(Writer writer, SvgParameters svgParameters) {
draw(writer, svgParameters, new LayoutParameters());
public void draw(Network network, Writer writer, Predicate<VoltageLevel> voltageLevelFilter) {
draw(network, writer, new NadParameters(), voltageLevelFilter);
}

public void draw(Writer writer, SvgParameters svgParameters, LayoutParameters layoutParameters) {
draw(writer, svgParameters, layoutParameters, new TopologicalStyleProvider(network));
public static void draw(Network network, Path svgFile, NadParameters param, Predicate<VoltageLevel> voltageLevelFilter) {
genericDraw(network, svgFile, param, voltageLevelFilter);
}

public void draw(Writer writer, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider) {
draw(writer, svgParameters, layoutParameters, styleProvider, new DefaultLabelProvider(network, svgParameters));
public static void draw(Network network, Writer writer, NadParameters param, Predicate<VoltageLevel> voltageLevelFilter) {
genericDraw(network, writer, param, voltageLevelFilter);
}

public void draw(Writer writer, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider) {
draw(writer, svgParameters, layoutParameters, styleProvider, labelProvider, new BasicForceLayoutFactory());
}
private static void genericDraw(Network network, Object object, NadParameters param, Predicate<VoltageLevel> voltageLevelFilter) {
Objects.requireNonNull(network);
Objects.requireNonNull(object);
Objects.requireNonNull(param);
Objects.requireNonNull(voltageLevelFilter);

public void draw(Writer writer, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider, LayoutFactory layoutFactory) {
draw(writer, svgParameters, layoutParameters, styleProvider, labelProvider, layoutFactory, new IntIdProvider());
}
Graph graph = new NetworkGraphBuilder(network, voltageLevelFilter, param.getIdProviderFactory().create()).buildGraph();
param.getLayoutFactory().create().run(graph, param.getLayoutParameters());
SvgWriter svgWriter = new SvgWriter(param.getSvgParameters(), param.getStyleProviderFactory().create(network), param.createLabelProvider(network));

public void draw(Writer writer, SvgParameters svgParameters, LayoutParameters layoutParameters,
StyleProvider styleProvider, LabelProvider labelProvider, LayoutFactory layoutFactory,
IdProvider idProvider) {
Graph graph = new NetworkGraphBuilder(network, voltageLevelFilter, idProvider).buildGraph();
layoutFactory.create().run(graph, layoutParameters);
new SvgWriter(svgParameters, styleProvider, labelProvider).writeSvg(graph, writer);
if (object instanceof Path svgFile) {
svgWriter.writeSvg(graph, svgFile);
} else if (object instanceof Writer writer) {
svgWriter.writeSvg(graph, writer);
} else {
throw new PowsyblException("Second argument is an instance of an unexpected class");
}
}

public String drawToString(SvgParameters svgParameters) {
public String drawToString(Network network, SvgParameters svgParameters) {
try (StringWriter writer = new StringWriter()) {
draw(writer, svgParameters);
NadParameters nadParameters = new NadParameters().setSvgParameters(svgParameters);
draw(network, writer, nadParameters, VoltageLevelFilter.NO_FILTER);
return writer.toString();
} catch (IOException e) {
throw new UncheckedIOException(e);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
/**
* Copyright (c) 2022, RTE (http://www.rte-france.com)
So-Fras marked this conversation as resolved.
Show resolved Hide resolved
* 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/.
*/
package com.powsybl.nad.layout;

import com.powsybl.nad.model.*;
Expand All @@ -6,6 +12,10 @@
import java.util.*;
import java.util.stream.Stream;

/**
*
* @author Florian Dupuy <florian.dupuy at rte-france.com>
*/
public abstract class AbstractLayout implements Layout {

private Map<String, Point> initialNodePositions = Collections.emptyMap();
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
/**
* Copyright (c) 2023, 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.nad.svg.iidm;

import com.powsybl.nad.build.iidm.IdProvider;

/**
*
* @author Sophie Frasnedo <sophie.frasnedo at rte-france.com>
*/
@FunctionalInterface
public interface IdProviderFactory {
IdProvider create();

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/**
* Copyright (c) 2023, 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.nad.svg.iidm;

import com.powsybl.iidm.network.Network;
import com.powsybl.nad.svg.LabelProvider;
import com.powsybl.nad.svg.SvgParameters;

/**
*
* @author Sophie Frasnedo <sophie.frasnedo at rte-france.com>
*/
@FunctionalInterface
public interface LabelProviderFactory {
LabelProvider create(Network network, SvgParameters svgParameters);

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
/**
* Copyright (c) 2023, 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.nad.svg.iidm;

import com.powsybl.iidm.network.Network;
import com.powsybl.nad.svg.StyleProvider;

/**
*
* @author Sophie Frasnedo <sophie.frasnedo at rte-france.com>
*/
@FunctionalInterface
public interface StyleProviderFactory {
StyleProvider create(Network network);
}
Original file line number Diff line number Diff line change
@@ -1,7 +1,18 @@
package com.powsybl.nad.svg.metadata;

/**
* Copyright (c) 2022, 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/.
*/
import javax.xml.stream.XMLStreamReader;

/**
*
* @author Florian Dupuy <florian.dupuy at rte-france.com>
*/

public class BusNodeMetadata extends AbstractMetadataItem {
private static final String ELEMENT_NAME = "busNode";

Expand Down
Loading