powersync-plugins-modbus/libnymea-sunspec/models/sunspecreactivecurrentmodel.h

137 lines
4.6 KiB
C++

// SPDX-License-Identifier: LGPL-3.0-or-later
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Copyright (C) 2013 - 2024, nymea GmbH
* Copyright (C) 2024 - 2025, chargebyte austria GmbH
*
* This file is part of libnymea-sunspec.
*
* libnymea-sunspec is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3
* of the License, or (at your option) any later version.
*
* libnymea-sunspec is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with libnymea-sunspec. If not, see <https://www.gnu.org/licenses/>.
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#ifndef SUNSPECREACTIVECURRENTMODEL_H
#define SUNSPECREACTIVECURRENTMODEL_H
#include <QObject>
#include "sunspecmodel.h"
class SunSpecConnection;
class SunSpecReactiveCurrentModel : public SunSpecModel
{
Q_OBJECT
public:
enum Argramod {
ArgramodEdge = 0,
ArgramodCenter = 1
};
Q_ENUM(Argramod)
enum Modena {
ModenaEnabled = 0x1
};
Q_DECLARE_FLAGS(ModenaFlags, Modena)
Q_FLAG(Modena)
explicit SunSpecReactiveCurrentModel(SunSpecConnection *connection, quint16 modbusStartRegister, quint16 modelLength, SunSpecDataPoint::ByteOrder byteOrder, QObject *parent = nullptr);
~SunSpecReactiveCurrentModel() override;
QString name() const override;
QString description() const override;
QString label() const override;
/* Indicates if gradients trend toward zero at the edges of the deadband or trend toward zero at the center of the deadband. */
Argramod arGraMod() const;
QModbusReply *setArGraMod(Argramod arGraMod);
/* The gradient used to increase capacitive dynamic current. A value of 0 indicates no additional reactive current support. [%ARtg/%dV] */
float arGraSag() const;
QModbusReply *setArGraSag(float arGraSag);
/* The gradient used to increase inductive dynamic current. A value of 0 indicates no additional reactive current support. [%ARtg/%dV] */
float arGraSwell() const;
QModbusReply *setArGraSwell(float arGraSwell);
/* Activate dynamic reactive current model */
ModenaFlags modEna() const;
QModbusReply *setModEna(ModenaFlags modEna);
/* The time window used to calculate the moving average voltage. [Secs] */
quint16 filTms() const;
QModbusReply *setFilTms(quint16 filTms);
/* The lower delta voltage limit for which negative voltage deviations less than this value no dynamic vars are produced. [% VRef] */
float dbVMin() const;
QModbusReply *setDbVMin(float dbVMin);
/* The upper delta voltage limit for which positive voltage deviations less than this value no dynamic current produced. [% VRef] */
float dbVMax() const;
QModbusReply *setDbVMax(float dbVMax);
/* Block zone voltage which defines a lower voltage boundary below which no dynamic current is produced. [% VRef] */
float blkZnV() const;
QModbusReply *setBlkZnV(float blkZnV);
/* Hysteresis voltage used with BlkZnV. [% VRef] */
float hysBlkZnV() const;
QModbusReply *setHysBlkZnV(float hysBlkZnV);
/* Block zone time the time before which reactive current support remains active regardless of how low the voltage drops. [mSecs] */
quint16 blkZnTmms() const;
QModbusReply *setBlkZnTmms(quint16 blkZnTmms);
/* Hold time during which reactive current support continues after the average voltage has entered the dead zone. [mSecs] */
quint16 holdTmms() const;
QModbusReply *setHoldTmms(quint16 holdTmms);
/* Scale factor for the gradients. */
qint16 arGraSf() const;
/* Scale factor for the voltage zone and limit settings. */
qint16 vRefPctSf() const;
quint16 pad() const;
protected:
quint16 m_fixedBlockLength = 14;
void initDataPoints();
void processBlockData() override;
private:
Argramod m_arGraMod;
float m_arGraSag = 0;
float m_arGraSwell = 0;
ModenaFlags m_modEna;
quint16 m_filTms = 0;
float m_dbVMin = 0;
float m_dbVMax = 0;
float m_blkZnV = 0;
float m_hysBlkZnV = 0;
quint16 m_blkZnTmms = 0;
quint16 m_holdTmms = 0;
qint16 m_arGraSf = 0;
qint16 m_vRefPctSf = 0;
quint16 m_pad = 0;
};
QDebug operator<<(QDebug debug, SunSpecReactiveCurrentModel *model);
#endif // SUNSPECREACTIVECURRENTMODEL_H