All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.powsybl.openloadflow.ac.equations.HvdcAcEmulationSide1ActiveFlowEquationTerm Maven / Gradle / Ivy

/**
 * 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/.
 * SPDX-License-Identifier: MPL-2.0
 */
package com.powsybl.openloadflow.ac.equations;

import com.powsybl.openloadflow.equations.Variable;
import com.powsybl.openloadflow.equations.VariableSet;
import com.powsybl.openloadflow.network.LfBus;
import com.powsybl.openloadflow.network.LfHvdc;

import java.util.Objects;

/**
 * @author Anne Tilloy {@literal }
 */
public class HvdcAcEmulationSide1ActiveFlowEquationTerm extends AbstractHvdcAcEmulationFlowEquationTerm {

    public HvdcAcEmulationSide1ActiveFlowEquationTerm(LfHvdc hvdc, LfBus bus1, LfBus bus2, VariableSet variableSet) {
        super(hvdc, bus1, bus2, variableSet);
    }

    private double p1(double ph1, double ph2) {
        double rawP = rawP(ph1, ph2);
        // if converterStation1 is controller, then p1 is positive, otherwise it is negative
        return isController(rawP) ? boundedP(rawP) : -getAbsActivePowerWithLosses(boundedP(rawP), lossFactor1, lossFactor2);
    }

    private static boolean isController(double rawP) {
        return rawP >= 0;
    }

    private boolean isInOperatingRange(double rawP) {
        return rawP < pMaxFromCS1toCS2 && rawP > -pMaxFromCS2toCS1;
    }

    protected double dp1dph1(double ph1, double ph2) {
        double rawP = rawP(ph1, ph2);
        if (isInOperatingRange(rawP)) {
            return (isController(rawP) ? 1 : getVscLossMultiplier()) * k; // derivative of cable loss is neglected
        } else {
            return 0;
        }
    }

    protected double dp1dph2(double ph1, double ph2) {
        return -dp1dph1(ph1, ph2);
    }

    @Override
    public double eval() {
        return p1(ph1(), ph2());
    }

    @Override
    public double der(Variable variable) {
        Objects.requireNonNull(variable);
        if (variable.equals(ph1Var)) {
            return dp1dph1(ph1(), ph2());
        } else if (variable.equals(ph2Var)) {
            return dp1dph2(ph1(), ph2());
        } else {
            throw new IllegalStateException("Unknown variable: " + variable);
        }
    }

    @Override
    protected String getName() {
        return "ac_emulation_p_1";
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy