com.powsybl.ucte.util.UcteAliasesCreation Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of powsybl-ucte-util Show documentation
Show all versions of powsybl-ucte-util Show documentation
Utility classes for UCTE formatted network and files
/*
* Copyright (c) 2020, 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/.
*/
package com.powsybl.ucte.util;
import com.powsybl.iidm.network.*;
import com.powsybl.ucte.network.UcteElementId;
import java.util.HashSet;
import java.util.Optional;
import java.util.Set;
import static com.powsybl.ucte.network.UcteElementId.parseUcteElementId;
/**
* @author Sebastien Murgey {@literal }
*/
public final class UcteAliasesCreation {
private static final String ALIAS_TRIPLET_TEMPLATE = "%s %s %s";
private static final String ELEMENT_NAME_PROPERTY_KEY = "elementName";
private UcteAliasesCreation() {
throw new AssertionError("Utility class should not be instantiated");
}
public static void createAliases(Network network) {
Set duplicatedAliases = new HashSet<>();
network.getBranchStream().forEach(branch -> {
if (branch instanceof TieLine) {
TieLine tieLine = (TieLine) branch;
tieLine.addAlias(tieLine.getHalf1().getId());
tieLine.addAlias(tieLine.getHalf2().getId());
addHalfElementNameAliases(tieLine, duplicatedAliases);
}
addElementNameAlias(branch, duplicatedAliases);
});
network.getSwitchStream().forEach(switchEl -> addElementNameAlias(switchEl, duplicatedAliases));
network.getDanglingLineStream().forEach(dl -> addElementNameAlias(dl, duplicatedAliases));
}
private static void addElementNameAlias(Identifiable> identifiable, Set duplicatedAliases) {
String elementNameProperty = identifiable.getProperty(ELEMENT_NAME_PROPERTY_KEY);
if (elementNameProperty != null && !elementNameProperty.isEmpty()) {
Optional ucteElementIdOptional = parseUcteElementId(identifiable.getId());
if (ucteElementIdOptional.isPresent()) {
UcteElementId ucteElementId = ucteElementIdOptional.get();
safeAddAlias(identifiable, duplicatedAliases, String.format(ALIAS_TRIPLET_TEMPLATE, ucteElementId.getNodeCode1(), ucteElementId.getNodeCode2(), elementNameProperty));
}
}
}
private static void addHalfElementNameAliases(TieLine tieLine, Set duplicatedAliases) {
String elementName1Property = tieLine.getProperty(ELEMENT_NAME_PROPERTY_KEY + "_1");
if (elementName1Property != null && !elementName1Property.isEmpty()) {
Optional ucteElementIdOptional = parseUcteElementId(tieLine.getHalf1().getId());
if (ucteElementIdOptional.isPresent()) {
UcteElementId ucteElementId = ucteElementIdOptional.get();
safeAddAlias(tieLine, duplicatedAliases, String.format(ALIAS_TRIPLET_TEMPLATE, ucteElementId.getNodeCode1(), ucteElementId.getNodeCode2(), elementName1Property));
}
}
String elementName2Property = tieLine.getProperty(ELEMENT_NAME_PROPERTY_KEY + "_2");
if (elementName2Property != null && !elementName2Property.isEmpty()) {
Optional ucteElementIdOptional = parseUcteElementId(tieLine.getHalf2().getId());
if (ucteElementIdOptional.isPresent()) {
UcteElementId ucteElementId = ucteElementIdOptional.get();
safeAddAlias(tieLine, duplicatedAliases, String.format(ALIAS_TRIPLET_TEMPLATE, ucteElementId.getNodeCode1(), ucteElementId.getNodeCode2(), elementName2Property));
}
}
}
private static void safeAddAlias(Identifiable> identifiable, Set duplicatedAliases, String alias) {
if (duplicatedAliases.contains(alias)) {
return;
}
Identifiable> alreadyAssignedIdentifiable = identifiable.getNetwork().getIdentifiable(alias);
if (alreadyAssignedIdentifiable != null && alreadyAssignedIdentifiable != identifiable) {
if (!alreadyAssignedIdentifiable.getId().equals(alias)) {
alreadyAssignedIdentifiable.removeAlias(alias);
}
duplicatedAliases.add(alias);
return;
}
identifiable.addAlias(alias);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy