You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

340 lines
17 KiB
C

/*****************************************************************************
* file include/pd_main.h
* author YuLiang
* version 1.0.0
* date 07-Feb-2023
* brief This file provides all the headers of the partial discharge functions.
******************************************************************************
* Attention
*
* <h2><center>&copy; COPYRIGHT(c) 2021 LandPower</center></h2>
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. Neither the name of LandPower nor the names of its contributors may be used to
* endorse or promote products derived from this software without specific
* prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
******************************************************************************/
#ifndef __PD_MAIN_H__
#define __PD_MAIN_H__
#ifdef CFG_DEV_TYPE_LAND_PD
/* Includes ------------------------------------------------------------------*/
#include "cmd.h"
/* Define --------------------------------------------------------------------*/
#define PD_DAU_SUM 2
#define PD_DAU_PORT_SUM 8
#define PD_PORT_SUM 16
#define PD_PORT_PROMPT_LEN 64 // DAU 端口节点前标长度.
#define PD_DEV_NUM_LEN 16
#define PD_DEV_TYPE_LEN 8
#define PD_POWER_FRE 50
#define PD_PHASE_NUM 128
#define PD_PRPS_NUM 6400
#define PD_PRPS_DATA_LEN 12800
#define PD_GIS_MIN_VALUE (-800) // 特高频局放的采集数值下限 -800 (-80.0dBm).
#define DEBUG_DAU_FILE "PDMonitor_DAU"
#define UPGRADE_SOFTWARE "upgrade.sw"
/* Exported types ------------------------------------------------------------*/
/* 用于命令行模式节点注册配置保存函数 */
typedef int pd_port_cmd_save_config_f(vty_t*, uint8_t, uint8_t);
/* 向服务器发送消息的类型. */
typedef enum
{
PD_SEND_TYPE_PRPS = 1,
PD_SEND_TYPE_TREND,
PD_SEND_TYPE_EVENT,
PD_SEND_TYPE_COUNT
} PD_SEND_TYPE_E;
/* 端口类型. */
typedef enum
{
PD_PORT_TYPE_UHF = 1,
PD_PORT_TYPE_AE,
PD_PORT_TYPE_TEV,
PD_PORT_TYPE_HF,
PD_PORT_TYPE_COUNT
} PD_PORT_TYPE_E;
/* 设备配置的主备类型. */
typedef enum
{
PD_DAU_MODE_AUTO = 0,
PD_DAU_MODE_MASTER,
PD_DAU_MODE_SLAVE,
PD_DAU_MODE_COUNT
} PD_DAU_MODE_E;
/* 设备配置的滤波类型. */
typedef enum
{
PD_FILTER_TYPE_HF = 3,
PD_FILTER_TYPE_LF = 6,
PD_FILTER_TYPE_FR = 9,
PD_FILTER_TYPE_FF = 12
} PD_FILTER_TYPE_E;
/* 端口类型. */
typedef enum
{
PD_SEN_TYPE_NONE = 0,
PD_SEN_TYPE_SIG,
PD_SEN_TYPE_NOISE,
PD_SEN_TYPE_SIG_NOISE,
PD_SEN_TYPE_COUNT
} PD_SEN_TYPE_E;
/* 设备配置的滤波类型. */
typedef enum
{
PD_SYNC_PT = 1,
PD_SYNC_POWER = 2,
PD_SYNC_OUTSIDE = 4,
} PD_SYNC_MODE_E;
/* 端口节点配置优先级 */
typedef enum
{
PD_PORT_CMD_PRI_DAU = 0,
PD_PORT_CMD_PRI_COUNT
} PD_PORT_CMD_PRI_E;
/* 1s prps 数据结构体. */
typedef struct {
int16_t avg_o; // 通道原始信号 (降噪前) 的平均值.
int16_t max; // 通道的最大值.
int16_t avg; // 通道的平均值.
uint32_t cnt; // 通道的计数值.
int32_t phase_sum[PD_PHASE_NUM]; // 通道的周波放电相位累加值.
int16_t phase_max[PD_PHASE_NUM]; // 通道的周波相位最大值.
int16_t phase_avg[PD_PHASE_NUM]; // 通道的周波相位平均值.
uint16_t phase_cnt[PD_PHASE_NUM]; // 通道的周波相位计数值 .
int16_t data[PD_PRPS_NUM]; // 通道数据.
uint8_t is_valid; // prps 数据是否有效.
} pd_prps_data_t;
typedef struct {
uint32_t index; // 数据编号.
uint32_t utc; // UTC 时标.
uint32_t is_denoise; // 是否降噪的标记: 1-已经降噪 0-原始没有降噪.
void *reserve; // 与 GIS5.0 设备的结构体同步.
pd_prps_data_t data[PD_DAU_SUM][PD_DAU_PORT_SUM]; // 16 个通道的数据.
} pd_prps_t;
typedef struct {
uint32_t index; // 数据编号: 0 - (2^32-1) 循环.
uint32_t utc; // UTC 时标.
uint8_t vport; // 通道编号.
uint8_t level; // 事件等级.
uint8_t type; // 放电类型识别结果: 每种放电类型的比较的概率.
uint8_t second; // 当前事件记录的时间秒数.
int16_t max; // 通道的最大值.
int32_t avg; // 通道的平均值.
int32_t cnt; // 通道的计数值.
float type_per[8]; // 放电类型识别结果.
uint16_t PositionEfficiency; // 定位信息: 有效性 0: 无效 1有效.
uint16_t PositionOtherChNum; // 定位信息: 对端传感器通道号 范围 [1-16].
uint32_t PositionDistance; // 定位信息: 距离本传感器的距离.
uint32_t RatioOutValue; // 定位信息: 实际比率 配对上 / 超过阀值的计数.
int32_t phase_sum[PD_PHASE_NUM]; // 通道的周波相位累加值.
int16_t phase_max[PD_PHASE_NUM]; // 通道的周波相位最大值.
int16_t phase_avg[PD_PHASE_NUM]; // 通道的周波相位平均值.
int32_t phase_cnt[PD_PHASE_NUM]; // 通道的周波相位计数值.
int16_t data[PD_PRPS_NUM]; // 通道 n 的测量数据.
} pd_event_t;
typedef struct {
int16_t max; // 通道的最大值.
int64_t avg; // 通道的平均值.
int32_t cnt; // 通道的计数值.
float phase; // 放电相位 .
float noise; // 趋势数据中的底噪值: 单位 dBm .
uint32_t event_cnt; // 趋势数据中的的事件数量记录.
int64_t phase_sum[PD_PHASE_NUM]; // 通道的周波放电相位累加值.
int16_t phase_max[PD_PHASE_NUM]; // 通道的周波相位最大值.
int16_t phase_avg[PD_PHASE_NUM]; // 通道的周波相位平均值.
int32_t phase_cnt[PD_PHASE_NUM]; // 通道的周波相位计数值.
} pd_trend_data_t;
typedef struct {
uint32_t index; // 数据编号: 0 - (2^32-1) 循环.
uint32_t utc; // UTC 时标.
pd_trend_data_t data[PD_DAU_SUM][PD_DAU_PORT_SUM]; // 通道 0 - 15 的计算及测量数据.
} pd_trend_t;
typedef struct {
pd_prps_t *denoise; // PRPS 数据指针.
pd_prps_t real; // 实时数据指针.
pd_event_t event[PD_DAU_SUM][PD_DAU_PORT_SUM]; // 端口事件指针.
pd_trend_t trend; // 趋势数据.
} pd_data_t;
typedef struct {
uint32_t type;
void *data;
} pd_csg_msg_t;
typedef struct {
uint8_t vport; // 通道编号.
uint8_t filter; // 滤波器类型 1: 低频段 2: 全频段 3: 窄频段 4: 高频段
uint8_t sensor_type; // 0: 无配置; 1: UHF信号传感器; 2: UHF噪声传感器 ; 3: UHF信号传感器, 关联噪声降噪.
uint8_t phase_sequence; // 对应相序 1A 2B 3C.
uint16_t NearSensor1_Number; //关联监测点1
uint16_t NearSensor1_Distance; //与监测点1距离
uint16_t Signal1_AttenuationRatio; //衰减 dBm/m 20200717
uint16_t NearSensor2_Number; //关联监测点2
uint16_t NearSensor2_Distance; //与监测点2距离
uint16_t Signal2_AttenuationRatio; //衰减 dBm/m 20200717
uint16_t NearSensor3_Number; //关联监测点3
uint16_t NearSensor3_Distance; //与监测点3距离
uint16_t Signal3_AttenuationRatio; //衰减 dBm/m 20200717
uint16_t NearSensor4_Number; //关联监测点4
uint16_t NearSensor4_Distance; //与监测点4距离
uint16_t Signal4_AttenuationRatio; //衰减 dBm/m 20200717
int16_t event_threshold; // 事件触发阀值 0.1dBm.
uint16_t event_counter; // 事件次数阀值.
int16_t env_noise; // 环境底噪, 单位: dBm 0~100 100-自动降噪.
int16_t noise_reduction; // 降噪水平, 单位: 0.1dBm.
int16_t UpperLimitOfDischargeAmplitude; //放电幅值上限 未使用
int16_t WaveTriggerThreshold; //波形触发阀值 -32768~32768
uint16_t PrescalerSampleValue; //通道采样抽点数值 未使用
uint16_t reserved1;
uint32_t SamplePointsTotalTriggered; //脉冲波形一次完整记录的采样点数 未使用
uint32_t RecordStartAdr; //波形记录本通道的SDR/DDR的缓冲区起始地址 未使用
uint32_t RecordStopAdr; //波形记录本通道的SDR/DDR的缓冲区结束地址 未使用
uint32_t sample_rate; //数据采样频率 Hz
uint32_t BeforeTriggerTime; //触发前采样时间 10ns
uint32_t AfterTriggerTime; //触发后采样时间 10ns
uint32_t storage_event; //事件存储文件数量阈值
uint32_t storage_wave; //波形存储文件数量阈值
uint8_t reserved[4]; //预留
}pd_port_config_old_t;
typedef struct{
uint8_t power_frequency; // 工频频率 未使用
uint8_t sync_mode; // 同步方式 1: PT 同步 2: 电源同步(默认) 4: 外接信号同步.
uint8_t TimingSyncMode; // 对时方式 1:网卡对时 2:GPS对时 4:外部对时 8:FPGA内部对时
uint8_t real_period; // 定时数据上送周期, 单位: 分钟.
uint8_t trend_period; // 趋势数据上送周期, 单位: 分钟.
uint8_t heartbeat_period; // 心跳包周期.
uint16_t NumberWindowsOfPhase; // 相位窗数 //未使用
uint32_t SyncTime; // 对时数据 //未使用
uint16_t AlarmPeriod; // 报警观察周期 //未使用
uint16_t TimePrpsStrategy; // 定时数据存储策略 0 全部存储 1 未上传存储.
uint32_t storage_trend; // 趋势存储文件数量阈值.
uint32_t StorageAlarm; // 告警存储文件数量阈值.
uint32_t StorageRun; // 运行状态存储文件数量阈值.
uint32_t storage_real; // 定时PRPS存储文件数量阈值.
uint32_t limit_event_time; // 事件频繁判断时间.
uint32_t limit_event_cnt; // 事件频繁判断个数.
uint32_t limit_event_interval; // 事件频繁后存储间隔.
uint32_t is_prps_save; // 实时PRPS存储使能.
uint8_t Reserved[52]; // 预留 .
}pd_config_old_t;
/* 局放配置. */
typedef struct {
pd_port_config_old_t config; // 为了兼容原先的协议.
uint8_t is_concern; // 是否被关注, 在实时波形中使用..
uint8_t r_noise_reduction; // 是否启动关联降噪, 在实时波形中使用..
uint8_t auto_noise_reduction; // 是否自动降噪, 在实时波形中使用..
uint8_t manual_noise_reduction; // 手动降噪, 单位: 0.1dBm, 在实时波形中使用..
uint8_t filter_cfg; // 端口配置的滤波类型, 在实时波形中使用.
} pd_port_config_t;
typedef struct{
uint8_t dev_num[PD_DEV_NUM_LEN]; // 设备编号.
uint8_t dev_type[PD_DEV_TYPE_LEN]; // 设备型号.
uint32_t factory_date; // 出厂日期.
uint32_t deployment_date; // 部署日期.
uint32_t ipv4; // 本机 IP.
uint8_t ipv6[16]; // 预留 IPV6 , 未使用.
uint8_t mac[MAC_ADDR_LEN]; // MAC地址.
uint8_t LocalIP2[4]; // 本机 IP, 未使用.
uint8_t LocalIP2_V6[16]; // 预留 IPV6 , 未使用.
uint8_t LocalMacAddress2[6]; // MAC 地址, 未使用.
uint32_t server_ipv4; // 服务器 IP.
uint8_t server_ipv6[16]; // 预留 IPV6, 未使用.
uint8_t ServerIP2[4]; // 服务器 IP, 未使用.
uint8_t ServerIP2_V6[16]; // 预留 IPV6 , 未使用.
uint16_t server_port; // 服务器端口号.
uint16_t ServerIP2_Port; // 服务器端口号, 未使用.
uint8_t port_type[PD_PORT_SUM]; // 采集通道类型 , 1 表示特高频局放 2 表示超声局放 3 表示 TEV 4 表示高频.
uint8_t Reserved[12]; // 预留.
uint32_t runTime; // 运行时间, 未使用.
uint32_t devVoltage; // 设备电压, 未使用.
uint32_t devTemperature; // 设备温度, 未使用.
uint32_t devSleepTime; // 设备休眠时长, 未使用.
uint32_t devPasswd; // 设备密码, 未使用.
uint8_t batteryVoltage; // 电池电压, 未使用.
uint8_t linkStatus; // 通讯状态, 未使用.
}pd_factory_old_t;
typedef struct {
pd_factory_old_t factory;
pd_config_old_t config;
pd_port_config_t port_config[PD_DAU_SUM][PD_DAU_PORT_SUM]; // 端口配置.
uint32_t concern_bitmap;
} pd_config_t;
typedef struct {
uint8_t sync;
} pd_state_t;
/* Exported macro ------------------------------------------------------------*/
/* Extern global variables ---------------------------------------------------*/
extern pd_data_t pd_data;
extern pd_config_t pd_config;
extern pd_state_t pd_state;
extern cmd_node_t pd_port_node;
/* Extern functions ----------------------------------------------------------*/
extern int32_t pd_main(void);
extern int32_t pd_port_cmd_config_register(int32_t pri, pd_port_cmd_save_config_f *func);
extern void pd_sync_mode_set(void);
extern void pd_sync_state_get(void);
extern void pd_wdg_clr(void);
extern void pd_prps_show(void);
extern void pd_show(void);
#endif
#endif
/************************ (C) COPYRIGHT LandPower ***** END OF FILE ****/