BusbarSectionConversion.java
/**
* 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.cgmes.conversion.elements;
import com.powsybl.cgmes.conversion.Context;
import com.powsybl.cgmes.model.CgmesNames;
import com.powsybl.iidm.network.Bus;
import com.powsybl.iidm.network.BusbarSection;
import com.powsybl.iidm.network.BusbarSectionAdder;
import com.powsybl.iidm.network.VoltageLevel;
import com.powsybl.triplestore.api.PropertyBag;
import static com.powsybl.cgmes.conversion.Conversion.PROPERTY_BUSBAR_SECTION_TERMINALS;
/**
* @author Luma Zamarre��o {@literal <zamarrenolm at aia.es>}
*/
public class BusbarSectionConversion extends AbstractConductingEquipmentConversion {
public BusbarSectionConversion(PropertyBag bbs, Context context) {
super(CgmesNames.BUSBAR_SECTION, bbs, context);
}
@Override
public boolean valid() {
// Always try to convert busbar sections, even if located at invalid nodes or voltage levels
return true;
}
@Override
public void convert() {
if (context.nodeBreaker()) {
BusbarSectionAdder bbsAdder = voltageLevel().getNodeBreakerView().newBusbarSection()
.setId(iidmId())
.setName(iidmName())
.setEnsureIdUnicity(context.config().isEnsureIdAliasUnicity());
bbsAdder.setNode(iidmNode());
BusbarSection bbs = bbsAdder.add();
addAliasesAndProperties(bbs);
convertedTerminals(bbs.getTerminal());
} else {
// If we are reading CGMES input data as bus/branch,
// we just keep track of this busbar section terminal
// to use in case of an updated export
addBusbarSectionTerminalToBus();
}
}
private void addBusbarSectionTerminalToBus() {
// Some isolated busbar sections may not have a topological node.
// This means that we can not determine the voltage level of the busbar section in bus/branch model,
// So we need to check if the voltage level is present before trying to access the bus
// voltageLevel() assumes voltage level is present, throws an exception if not available
// voltageLevel(1) returns the optional voltage level of the first terminal
Bus bus = voltageLevel(1).map(VoltageLevel::getBusBreakerView).map(bbv -> bbv.getBus(busId())).orElse(null);
if (bus != null) {
String busbarSectionTerminals = bus.getProperty(PROPERTY_BUSBAR_SECTION_TERMINALS, "");
if (!busbarSectionTerminals.isEmpty()) {
busbarSectionTerminals += ",";
}
busbarSectionTerminals += terminalId();
bus.setProperty(PROPERTY_BUSBAR_SECTION_TERMINALS, busbarSectionTerminals);
}
}
}