/*************************************************************************** * Copyright (C) 2011-2016 by Maxim Kochetkov * * fido_max@inbox.ru * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; version 2 of the License. * * * * This program 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 General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ #ifndef DA_BVT_H #define DA_BVT_H #include "da.h" namespace FT3 { enum eKA_BVT_TT { TT_FAILURE = 0, TT_NORMAL = 1, TT_WARNING = 2, TT_ERROR = 3, TT_OFF= 4 }; enum eKA_BVT_State { KA_BVT_Error = 0x0, KA_BVT_Normal = 0x1 }; class KA_BVT: public DA { public: //Methods KA_BVT(TMdPrm& prm, uint16_t id, uint16_t n, bool has_params); ~KA_BVT(); uint16_t ID; uint16_t count_n; uint16_t config; void AddChannel(uint8_t iid); uint16_t GetState(void); uint16_t PreInit(void); uint16_t SetParams(void); uint16_t RefreshParams(void); uint16_t PostInit(void); uint16_t RefreshData(void); uint16_t HandleEvent(int64_t, uint8_t *); uint8_t cmdGet(uint16_t prmID, uint8_t * out); uint8_t cmdSet(uint8_t * req, uint8_t addr); uint16_t setVal(TVal &val); string getStatus(void); void saveIO(void); void loadIO(bool force = false); void saveParam(void); void loadParam(void); void tmHandler(void); class SKATTchannel { public: SKATTchannel(uint8_t iid, DA* owner) : da(owner), id(iid), State(TSYS::strMess("state_%d", id + 1), TSYS::strMess(_("State %d"), id + 1)), Value(TSYS::strMess("value_%d", id + 1), TSYS::strMess(_("Value %d"), id + 1)), Period(TSYS::strMess("period_%d", id + 1), TSYS::strMess(_("Measure period %d"), id + 1)), Sens(TSYS::strMess("sens_%d", id + 1), TSYS::strMess(_("Sensitivity %d"), id + 1)), MinS(TSYS::strMess("minS_%d", id + 1), TSYS::strMess(_("Sensor minimum %d"), id + 1)), MaxS(TSYS::strMess("maxS_%d", id + 1), TSYS::strMess(_("Sensor maximum %d"), id + 1)), MinPV(TSYS::strMess("minPV_%d", id + 1), TSYS::strMess(_("PV minimum %d"), id + 1)), MaxPV(TSYS::strMess("maxPV_%d", id + 1), TSYS::strMess(_("PV maximum %d"), id + 1)), MinW(TSYS::strMess("minW_%d", id + 1), TSYS::strMess(_("Warning minimum %d"), id + 1)), MaxW(TSYS::strMess("maxW_%d", id + 1), TSYS::strMess(_("Warning maximum %d"), id + 1)), MinA(TSYS::strMess("minA_%d", id + 1), TSYS::strMess(_("Alarm minimum %d"), id + 1)), MaxA(TSYS::strMess("maxA_%d", id + 1), TSYS::strMess(_("Alarm maximum %d"), id + 1)), Factor(TSYS::strMess("factor_%d", id + 1), TSYS::strMess(_("Range factor %d"), id + 1)), Adjust(TSYS::strMess("adjust_%d", id + 1), TSYS::strMess(_("Adjustment %d"), id + 1)) { } DA* da; uint8_t id; ui8Data State, Period; flData Value, Sens, MinS, MaxS, MinPV, MaxPV, MinW, MaxW, MinA, MaxA, Factor, Adjust; void UpdateTTParam(uint16_t ID, uint8_t cl); uint8_t SetNewTTParam(uint8_t addr, uint16_t prmID, uint8_t *val); }; vector data; int lnkSize() { if(with_params) { return data.size() * 14; } else { return data.size() * 2; } } int lnkId(const string &id) { if(with_params) { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * 14; if(data[i_l].Value.lnk.prmName == id) return i_l * 14 + 1; if(data[i_l].Period.lnk.prmName == id) return i_l * 14 + 2; if(data[i_l].Sens.lnk.prmName == id) return i_l * 14 + 3; if(data[i_l].MinS.lnk.prmName == id) return i_l * 14 + 4; if(data[i_l].MaxS.lnk.prmName == id) return i_l * 14 + 5; if(data[i_l].MinPV.lnk.prmName == id) return i_l * 14 + 6; if(data[i_l].MaxPV.lnk.prmName == id) return i_l * 14 + 7; if(data[i_l].MinW.lnk.prmName == id) return i_l * 14 + 8; if(data[i_l].MaxW.lnk.prmName == id) return i_l * 14 + 9; if(data[i_l].MinA.lnk.prmName == id) return i_l * 14 + 10; if(data[i_l].MaxA.lnk.prmName == id) return i_l * 14 + 11; if(data[i_l].Factor.lnk.prmName == id) return i_l * 14 + 12; if(data[i_l].Adjust.lnk.prmName == id) return i_l * 14 + 13; } } else { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) { return i_l * 2; } if(data[i_l].Value.lnk.prmName == id) { return i_l * 2 + 1; } } } return -1; } SLnk &lnk(int num) { int k; if(with_params) { k = 14; } else { k = 2; } switch(num % k) { case 0: return data[num / k].State.lnk; case 1: return data[num / k].Value.lnk; case 2: return data[num / k].Period.lnk; case 3: return data[num / k].Sens.lnk; case 4: return data[num / k].MinS.lnk; case 5: return data[num / k].MaxS.lnk; case 6: return data[num / k].MinPV.lnk; case 7: return data[num / k].MaxPV.lnk; case 8: return data[num / k].MinW.lnk; case 9: return data[num / k].MaxW.lnk; case 10: return data[num / k].MinA.lnk; case 11: return data[num / k].MaxA.lnk; case 12: return data[num / k].Factor.lnk; case 13: return data[num / k].Adjust.lnk; } } private: bool with_params; vector chan_err; }; class B_BVT: public DA { public: //Methods B_BVT(TMdPrm& prm, uint16_t id, uint16_t n, bool has_params, bool has_k, bool has_rate); ~B_BVT(); uint16_t ID; uint16_t count_n; void AddChannel(uint8_t iid); uint16_t Task(uint16_t); uint16_t HandleEvent(int64_t, uint8_t *); uint8_t cmdGet(uint16_t prmID, uint8_t * out); uint8_t cmdSet(uint8_t * req, uint8_t addr); uint16_t setVal(TVal &val); string getStatus(void); void saveIO(void); void loadIO(bool force = false); void tmHandler(void); class STTchannel { public: STTchannel(uint8_t iid, DA* owner) : da(owner), id(iid), State(TSYS::strMess("state_%d", id + 1), TSYS::strMess(_("State %d"), id + 1)), Value(TSYS::strMess("value_%d", id + 1), TSYS::strMess(_("Value %d"), id + 1)), Period(TSYS::strMess("period_%d", id + 1), TSYS::strMess(_("Measure period %d"), id + 1)), Sens(TSYS::strMess("sens_%d", id + 1), TSYS::strMess(_("Sensitivity %d"), id + 1)), MinS(TSYS::strMess("minS_%d", id + 1), TSYS::strMess(_("Sensor minimum %d"), id + 1)), MaxS(TSYS::strMess("maxS_%d", id + 1), TSYS::strMess(_("Sensor maximum %d"), id + 1)), MinPV(TSYS::strMess("minPV_%d", id + 1), TSYS::strMess(_("PV minimum %d"), id + 1)), MaxPV(TSYS::strMess("maxPV_%d", id + 1), TSYS::strMess(_("PV maximum %d"), id + 1)), MinW(TSYS::strMess("minW_%d", id + 1), TSYS::strMess(_("Warning minimum %d"), id + 1)), MaxW(TSYS::strMess("maxW_%d", id + 1), TSYS::strMess(_("Warning maximum %d"), id + 1)), MinA(TSYS::strMess("minA_%d", id + 1), TSYS::strMess(_("Alarm minimum %d"), id + 1)), MaxA(TSYS::strMess("maxA_%d", id + 1), TSYS::strMess(_("Alarm maximum %d"), id + 1)), Factor(TSYS::strMess("factor_%d", id + 1), TSYS::strMess(_("Range factor %d"), id + 1)), Dimension(TSYS::strMess("dimens_%d", id + 1), TSYS::strMess(_("Dimension %d"), id + 1)), CorFactor(TSYS::strMess("corfactor_%d", id + 1), TSYS::strMess(_("Correcting factor %d"), id + 1)), Rate(TSYS::strMess("rate_%d", id + 1), TSYS::strMess(_("Rate of change %d"), id + 1)), Calcs(TSYS::strMess("calcs_%d", id + 1), TSYS::strMess(_("Calcs count %d"), id + 1)), RateSens(TSYS::strMess("ratesens_%d", id + 1), TSYS::strMess(_("Rate sensitivity %d"), id + 1)), RateLimit(TSYS::strMess("ratelimit_%d", id + 1), TSYS::strMess(_("Rate limit %d"), id + 1)) { } DA* da; uint8_t id; ui8Data State, Period, Dimension, Calcs; flData Value, Sens, MinS, MaxS, MinPV, MaxPV, MinW, MaxW, MinA, MaxA, Factor, CorFactor, Rate, RateSens, RateLimit; }; vector data; int lnkSize() { if(with_params) { if(with_k) { if(with_rate) { return data.size() * 19; } else { return data.size() * 15; } } else { return data.size() * 14; } } else { return data.size() * 2; } } int lnkId(const string &id) { if(with_rate) { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * 19; if(data[i_l].Value.lnk.prmName == id) return i_l * 19 + 1; if(data[i_l].Period.lnk.prmName == id) return i_l * 19 + 2; if(data[i_l].Sens.lnk.prmName == id) return i_l * 19 + 3; if(data[i_l].MinS.lnk.prmName == id) return i_l * 19 + 4; if(data[i_l].MaxS.lnk.prmName == id) return i_l * 19 + 5; if(data[i_l].MinPV.lnk.prmName == id) return i_l * 19 + 6; if(data[i_l].MaxPV.lnk.prmName == id) return i_l * 19 + 7; if(data[i_l].MinW.lnk.prmName == id) return i_l * 19 + 8; if(data[i_l].MaxW.lnk.prmName == id) return i_l * 19 + 9; if(data[i_l].MinA.lnk.prmName == id) return i_l * 19 + 10; if(data[i_l].MaxA.lnk.prmName == id) return i_l * 19 + 11; if(data[i_l].Factor.lnk.prmName == id) return i_l * 19 + 12; if(data[i_l].Dimension.lnk.prmName == id) return i_l * 19 + 13; if(data[i_l].CorFactor.lnk.prmName == id) return i_l * 19 + 14; if(data[i_l].Rate.lnk.prmName == id) return i_l * 19 + 15; if(data[i_l].Calcs.lnk.prmName == id) return i_l * 19 + 16; if(data[i_l].RateSens.lnk.prmName == id) return i_l * 19 + 17; if(data[i_l].RateLimit.lnk.prmName == id) return i_l * 19 + 18; } } else { if(with_k) { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * 15; if(data[i_l].Value.lnk.prmName == id) return i_l * 15 + 1; if(data[i_l].Period.lnk.prmName == id) return i_l * 15 + 2; if(data[i_l].Sens.lnk.prmName == id) return i_l * 15 + 3; if(data[i_l].MinS.lnk.prmName == id) return i_l * 15 + 4; if(data[i_l].MaxS.lnk.prmName == id) return i_l * 15 + 5; if(data[i_l].MinPV.lnk.prmName == id) return i_l * 15 + 6; if(data[i_l].MaxPV.lnk.prmName == id) return i_l * 15 + 7; if(data[i_l].MinW.lnk.prmName == id) return i_l * 15 + 8; if(data[i_l].MaxW.lnk.prmName == id) return i_l * 15 + 9; if(data[i_l].MinA.lnk.prmName == id) return i_l * 15 + 10; if(data[i_l].MaxA.lnk.prmName == id) return i_l * 15 + 11; if(data[i_l].Factor.lnk.prmName == id) return i_l * 15 + 12; if(data[i_l].Dimension.lnk.prmName == id) return i_l * 15 + 13; if(data[i_l].CorFactor.lnk.prmName == id) return i_l * 15 + 14; } } else { if(with_params) { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) return i_l * 14; if(data[i_l].Value.lnk.prmName == id) return i_l * 14 + 1; if(data[i_l].Period.lnk.prmName == id) return i_l * 14 + 2; if(data[i_l].Sens.lnk.prmName == id) return i_l * 14 + 3; if(data[i_l].MinS.lnk.prmName == id) return i_l * 14 + 4; if(data[i_l].MaxS.lnk.prmName == id) return i_l * 14 + 5; if(data[i_l].MinPV.lnk.prmName == id) return i_l * 14 + 6; if(data[i_l].MaxPV.lnk.prmName == id) return i_l * 14 + 7; if(data[i_l].MinW.lnk.prmName == id) return i_l * 14 + 8; if(data[i_l].MaxW.lnk.prmName == id) return i_l * 14 + 9; if(data[i_l].MinA.lnk.prmName == id) return i_l * 14 + 10; if(data[i_l].MaxA.lnk.prmName == id) return i_l * 14 + 11; if(data[i_l].Factor.lnk.prmName == id) return i_l * 14 + 12; if(data[i_l].Dimension.lnk.prmName == id) return i_l * 14 + 13; } } else { for(int i_l = 0; i_l < data.size(); i_l++) { if(data[i_l].State.lnk.prmName == id) { return i_l * 2; } if(data[i_l].Value.lnk.prmName == id) { return i_l * 2 + 1; } } } } } return -1; } SLnk &lnk(int num) { int k; if(with_rate) { k = 19; } else { if(with_k) { k = 15; } else { if(with_params) { k = 14; } else { k = 2; } } } switch(num % k) { case 0: return data[num / k].State.lnk; case 1: return data[num / k].Value.lnk; case 2: return data[num / k].Period.lnk; case 3: return data[num / k].Sens.lnk; case 4: return data[num / k].MinS.lnk; case 5: return data[num / k].MaxS.lnk; case 6: return data[num / k].MinPV.lnk; case 7: return data[num / k].MaxPV.lnk; case 8: return data[num / k].MinW.lnk; case 9: return data[num / k].MaxW.lnk; case 10: return data[num / k].MinA.lnk; case 11: return data[num / k].MaxA.lnk; case 12: return data[num / k].Factor.lnk; case 13: return data[num / k].Dimension.lnk; case 14: return data[num / k].CorFactor.lnk; case 15: return data[num / k].Rate.lnk; case 16: return data[num / k].Calcs.lnk; case 17: return data[num / k].RateSens.lnk; case 18: return data[num / k].RateLimit.lnk; } } private: bool with_params; bool with_k; bool with_rate; vector chan_err; }; } //End namespace #endif //DA_BVT_H