eis/eqpalg/algs/roller3.h

93 lines
2.5 KiB
C
Raw Normal View History

#pragma once
/**
* @file roller3.h
* @brief
* @author your name (you@domain.com)
* @version 0.1
* @date 2026-01-12
*
* Copyright: Baosight Co. Ltd.
* DO NOT COPY/USE WITHOUT PERMISSION
*
*/
#include <array>
#include <eqpalg/algs/exp_base.h>
#include <eqpalg/define/public.h>
#include <map>
#include <utility>
namespace HoldState {
enum class AlarmState { None = 0, DownLower, UpHigher };
enum class AlarmType { Warn = 0, Error };
struct StateInfo {
TimePoint last_start_time = std::chrono::system_clock::now(); ///<上次记录时间
AlarmState last_alarm_tate =
AlarmState::None; ///<报警状态 未报警,超下限,超上限
AlarmType alarm_type = AlarmType::Error; ///<报警类型
};
} // namespace HoldState
using std::string;
class Roller3 : public ExpBase {
public:
Roller3(const string &name, const mix_cc::json &rule_json,
const string &ruleId, size_t exp_type);
virtual ~Roller3();
public:
int init() override;
virtual AlarmInfo mon_proc() override;
std::vector<AlarmInfo> exec_task(mix_cc::time_range_t time_range) override;
private:
double limit_error_; ///<报警限幅
double limit_warn_; ///<警告限幅
double median_; ///<中位数
vector<double> deviations_; ///<偏差
vector<double> values_; ///<最新的值
vector<int> tag_seq_; ///< tag序号
string tags_exp_;
int value_num_ = 0; ///<对比的数据项个数
vector<int>
is_zero_list_; ///<数据是否为0的标记0-否1-是需要剔除为0的数据项
std::map<int, HoldState::StateInfo> state_info_map_; ///<各个数据项的报警情况跟踪
private:
int init_X_exp();
void print_load_content();
/**
* @brief
* @param expr My Param doc
* @return vector<int>
*/
vector<int> extractTagNumbers(const string &expr);
/**
* @brief
* @param data My Param doc
* @return double
*/
double calculateMedian(std::vector<double> data);
/**
* @brief maxmax数据的下标和值
*/
std::pair<int, double> findMaxWithIndex(const std::vector<double> &vec);
/**
* @brief Get the up down object
* @param value My Param doc
* @param is_up
* @return double
*/
double get_up_down(const double &value, bool is_up);
/**
* @brief
* @param value
* @return AlarmState None = 0, DownLower, median_
*/
HoldState::AlarmState detect_up_down(const double &value);
};