protect.h 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. /******************************************************************************
  2. 版权所有:
  3. 文件名称: protect.h
  4. 文件版本: 01.01
  5. 创建作者: xxxxxx
  6. 创建日期: 2012-03-28
  7. 功能说明: 保护整组处理过程
  8. 其它说明:
  9. 修改记录:
  10. */
  11. #ifndef _PROTECT_H
  12. #define _PROTECT_H
  13. /*------------------------------- 头文件 --------------------------------------
  14. */
  15. /*------------------------------- 宏定义 --------------------------------------
  16. */
  17. // 控制出口总压板
  18. #define JZS_ALL_EN(sw) (g_tRelay[sw].run_stu.jzs_tt && pRunSet->tSwSet[sw].btt_gnyb_jzs)
  19. #define KZ_OUT_ALL_EN(sw) (pRunSet->tSwSet[sw].btt_yxyb_gnzck && !JZS_ALL_EN(sw))
  20. // 保护总投退
  21. #if defined YB_AUTO_SELECT && !defined GD_AREA_ECZD_2020
  22. #define FUN_ALL_EN(sw) (pRunSet->tSwSet[sw].btt_yxyb_gnztt && fa_fun_true(sw))
  23. #elif defined GD_AREA_ZHONGSHAN_2020
  24. #define FUN_ALL_EN(sw) (g_run_stu.bhall && pRunSet->tSwSet[sw].btt_yxyb_gnztt && g_tRelay[sw].run_stu.bhztt && fa_fun_true(sw))
  25. #else
  26. #define FUN_ALL_EN(sw) (g_run_stu.bhall && pRunSet->tSwSet[sw].btt_yxyb_gnztt && g_tRelay[sw].run_stu.bhztt)
  27. #endif
  28. #if defined GD_AREA_ZHONGSHAN || defined GD_AREA_ZHONGSHAN_2020 // 中山要求通信异常,全系统均异常
  29. // 分布式 FA总投退
  30. #define BH_GOOSE_EN_YB(sw) (FUN_ALL_EN(sw) && g_tRelay[sw].run_stu.fa_g_tt && pRunSet->tSwSet[sw].btt_gnyb_dfa && pRunSet->tSwSet[sw].tGocSet.bTT_gooseFA)
  31. #define BH_GOOSE_EN(sw) (BH_GOOSE_EN_YB(sw) && (!tFAg.bComErr))
  32. #define BH_GOOSE_COMMERR(sw) (BH_GOOSE_EN_YB(sw) && (tFAg.bComErr))
  33. #define BH_ALL_EN(sw) (FUN_ALL_EN(sw) && pRunSet->tSwSet[sw].btt_gnyb_cg && ((g_tRelay[sw].run_stu.cgbhtt && (!BH_GOOSE_EN_YB(sw))) || (BH_GOOSE_EN_YB(sw) && pRunSet->tSwSet[sw].tGocSet.bsw_fz)))
  34. #define FA_ALL_EN(sw) (FUN_ALL_EN(sw) && pRunSet->tSwSet[sw].btt_gnyb_fa && ((g_tRelay[sw].run_stu.fatt && (!BH_GOOSE_EN_YB(sw))) || (BH_GOOSE_COMMERR(sw) && !pRunSet->tSwSet[sw].tGocSet.bsw_fz)))
  35. #else
  36. #ifdef YB_AUTO_SELECT
  37. #define BH_GOOSE_EN_YB(sw) (FUN_ALL_EN(sw) && goose_yb_enable(sw) && pRunSet->tSwSet[sw].tGocSet.bTT_gooseFA)
  38. #define BH_GOOSE_EN(sw) (BH_GOOSE_EN_YB(sw))
  39. #define BH_GOOSE_COMMERR(sw) (false)
  40. #define BH_ALL_2(sw) (FUN_ALL_EN(sw) && bh_yb_enable(sw) && (!BH_GOOSE_EN(sw)))
  41. #define BH_ALL_EN(sw) (BH_ALL_2(sw) || JZS_ALL_EN(sw))
  42. #define FA_ALL_EN(sw) (FUN_ALL_EN(sw) && fa_yb_enable(sw) && (!BH_GOOSE_EN(sw)))
  43. #else
  44. #define BH_GOOSE_EN_YB(sw) (FUN_ALL_EN(sw) && g_tRelay[sw].run_stu.fa_g_tt && pRunSet->tSwSet[sw].btt_gnyb_dfa && pRunSet->tSwSet[sw].tGocSet.bTT_gooseFA)
  45. #define BH_GOOSE_EN(sw) (BH_GOOSE_EN_YB(sw))
  46. #define BH_GOOSE_COMMERR(sw) (false)
  47. #define BH_ALL_2(sw) (FUN_ALL_EN(sw) && pRunSet->tSwSet[sw].btt_gnyb_cg && g_tRelay[sw].run_stu.cgbhtt && (!BH_GOOSE_EN(sw)))
  48. #define BH_ALL_EN(sw) (BH_ALL_2(sw) || JZS_ALL_EN(sw))
  49. #define FA_ALL_EN(sw) (FUN_ALL_EN(sw) && pRunSet->tSwSet[sw].btt_gnyb_fa && g_tRelay[sw].run_stu.fatt && (!BH_GOOSE_EN(sw)))
  50. #endif
  51. #endif
  52. // 重合闸压板
  53. #define CHZ_ALL_EN(sw) (pRunSet->tSwSet[sw].btt_gnyb_zdchz && g_tRelay[sw].run_stu.chzyb && !g_tRelay[sw].run_stu.bsch)
  54. // 同期合闸软压板
  55. #define TYTQ_ALL_EN(sw) (!FUN_ALL_EN(sw) || !pRunSet->tSwSet[sw].btt_gnyb_tqhz)
  56. // 解列压板
  57. #define JL_ALL_EN(sw) (FUN_ALL_EN(sw) && pRunSet->tSwSet[sw].btt_gnyb_zdjl)
  58. // 定值时间判断
  59. #define BH_WAVETIME_EN(dSetTime) ((dSetTime >= (T_10ms * 10)) ? 1 : 0)
  60. // 取相量模值
  61. #define SQR(a,b) (a*a + b*b)
  62. // 采样区存储采样点数
  63. #define SAMLENGTH (CFG_ADC_DOTS_PER_CHANNEL-1)
  64. #define ANGLE_P180 ( 11796480)
  65. #define ANGLE_N180 (-11796480)
  66. #define ANGLE_P360 ( 23592960)
  67. #define ANGLE_N40 (-2621440)
  68. #define ANGLE_P130 ( 8519680)
  69. #define ANGLE_P140 ( 9175040)
  70. #define ANGLE_N50 (-3276800)
  71. #define ANGLE_P20 ( 1310720)
  72. #define ANGLE_P10 ( 655360)
  73. #define ANGLE_N170 (-11141120)
  74. #define ANGLE_N160 (-10485760)
  75. #define ANGF180 (180*65535) //180度
  76. #define ANGN180 ((-180)*65535) //-180度
  77. #define ANG360 (360 << 16) //360度
  78. #define ANG225 (225 << 16) //225度
  79. #define ANG315 (315 << 16) //315度
  80. #define ANG120 (120 << 16) //120度
  81. #define TAN5 375760949 //tan5度*2^32
  82. #define TAN10 757308616 //tan10度*2^32
  83. #define TAN25 2002776141 //tan25度*2^32
  84. #define TAN30 2479700525 //tan30度*2^32
  85. #define TAN35 3007368477 //tan35度*2^32
  86. /*------------------------------ 类型结构 -------------------------------------
  87. */
  88. // 保护整组处理标志结构定义
  89. struct protect_stu
  90. {
  91. u32 sw; // 保护当前处理的开关
  92. u32 t_rcd_bh; // 用于5ms巡检,记录上一次轮巡时刻
  93. u8 update; // 上电
  94. bool bARSTFLT; //整组自动复归事故总202004
  95. };
  96. // 保护启动标志状态标志
  97. typedef union UBHQD
  98. {
  99. DWORD dfBHQDLogic;
  100. struct
  101. {
  102. DWORD bZQD :1; // 总启动
  103. DWORD bQD25ms:1; // 启动一个周波
  104. DWORD bTBQD:1; // 突变量电流启动
  105. DWORD bFZQD:1; // 幅值启动
  106. DWORD bBHQD:1; // 保护启动
  107. DWORD bZZFG:1; // 整组复归
  108. #ifdef CUSTOMIZE_BZT //备自投
  109. WORD bBZTQD:1; //备自投启动
  110. #endif
  111. }bFlag;
  112. }UBHQD;
  113. // 保护动作跳闸标志
  114. typedef union UBHDZ
  115. {
  116. WORD dfBHDZLogic;
  117. struct
  118. {
  119. WORD bBHDZ:1; // 保护动作总标志
  120. WORD bBHTZ:1; // 保护动作总标志
  121. WORD bSYTz:1; // 失压跳闸
  122. WORD bBHTrip:1; // 保护跳闸总标志
  123. WORD bTZOut:1; // 跳闸出口
  124. WORD bTZSB:1; // 跳闸失败
  125. WORD bHZOut:1; // 合闸出口
  126. WORD bBHT:1; // 保护跳
  127. WORD bBHH:1; // 保护合
  128. #ifdef SELF_OPEN_RELEASE
  129. WORD bBHTKeep:1; // 保护跳保持标志
  130. #endif
  131. }bFlag;
  132. }UBHDZ;
  133. // 保护启动标志状态标志
  134. typedef union UOCDIR
  135. {
  136. WORD wfFlag;
  137. struct
  138. {
  139. WORD Iazx:1; // Ia正向
  140. WORD Ibzx:1; // Ib正向
  141. WORD Iczx:1; // Ic正向
  142. }bFlag;
  143. }UOCDIR;
  144. // 遥控、手动分合闸
  145. typedef struct URMTSW
  146. {
  147. bool bYTExecute; // 遥控跳闸
  148. bool bYHExecute; // 遥控合闸
  149. bool bHandHz; // 手动合闸
  150. bool bHandTz; // 手动分闸
  151. #ifdef SELF_OPEN_RELEASE
  152. bool bSwTz; // 开关本体分闸
  153. #endif
  154. bool bTQHz; // 同期合闸标志
  155. bool bYHExecute_fa;
  156. bool bYTExecute_fa;
  157. bool bHandHz_fa; // 手动合闸
  158. bool bHandTz_fa; // 手动分闸
  159. bool bYH_fajs_flag; // 遥控合闸解锁标志
  160. bool bTz_Doing; // 合闸
  161. bool bHz_Doing; // 分闸
  162. #ifdef FUNC_REBOOT_BS_HA_JS_3S
  163. bool b_bsha; // 重新上电后的手分/遥分闭锁合闸标志
  164. #endif
  165. }URMTSW;
  166. typedef struct TRELAY_T // 开关逻辑结构体定义
  167. {
  168. u8 zqd; // 总启动标志,可由突变量或幅值启动置位
  169. u8 fzqd; // 幅值启动标志
  170. u8 fzdz; // 幅值动作标志
  171. u8 fzzzdz; // 幅值整组动作标志
  172. u8 tblqd; // 突变时启动标志
  173. u8 tbldz; // 突变量动作标志
  174. u8 tblzzdz; // 突变量整组动作标志
  175. u16 gz_process; // 故障处理流程
  176. u32 t_rcd_qd; // 记录启动时刻,因为每个开关的启动时刻不同,所以跟开关对接 dTfault
  177. u32 t_rcd_gz; // 用于故障处理过程,记录上一次轮巡时刻 dTRcd0
  178. u32 us_tbl; // 突变量统计初始时间
  179. u32 us_fz; // 幅值统计初始时间
  180. bool bBSHZ; //短时间内分闸次数到,闭锁合闸
  181. bool bBSTZ; // 闭锁跳闸
  182. bool bARSTFLT; //开关自动复归事故总202004
  183. TFDL_T tFdl[6];
  184. TOC_T tOC[BHOC_NUMBER]; // 过流保护相关
  185. TCH_T tCHZ; // 重合闸
  186. UGLFSX uGLFSX; //过流反时限标志字
  187. FSXCS FsxcsGL; //过流反时限继电器人口参数
  188. #ifdef CUSTOMIZE_BZT //备自投
  189. TBZT_T tBzt;
  190. #endif
  191. // TVOL_T tU0GZ; // 零压故障
  192. TLOSTVOT_T tLostVot; //失压标志
  193. TU0_T tU0TZ; //合后零压跳闸
  194. TU0_T tXXTZ; //选线跳闸
  195. TU0_T tOVER_U0TZ; //过零序电压跳闸
  196. TJL_T tDYJL; //电压解列
  197. TJL_T tPLJL; //频率解列
  198. TTQHZ_T tTQHz; //同期合闸标志
  199. TSDHZ_T tSDHZ; //上电合闸标志
  200. TGOC_T tgoc; //方向过流goose
  201. TSWST tSWST; // 开关运行状态识别
  202. RUN_STU_SW run_stu;
  203. UBHQD uBHQD; // 保护启动标志字
  204. UBHDZ uBHDZ; // 保护动作标志字
  205. URMTSW uRmtSW; // 遥控分、合闸
  206. THZBS_T thzbs;
  207. TIMERELAY tMb_yuk_time;
  208. TIMERELAY tTZZFG_5S0ms; // 无故障延时5s
  209. TIMERELAY tTrip_BHT40MS; // 跳闸脉冲计时器,跳闸开出最短时间40MS
  210. TIMERELAY tTripfail_2s; // 跳闸脉冲计时器,跳闸开出最短时间100MS
  211. TIMERELAY tTripfail_hz; // 跳闸脉冲计时器,跳闸开出最短时间100MS
  212. #ifdef SELF_OPEN_RELEASE
  213. TIMERELAY tTripBHTKeep; // 保护跳保持继电器
  214. #endif
  215. struct rt_stat tbl_stat; // 用于突变量启动统计
  216. struct rt_stat tbldz_stat; // 用于突变量动作统计
  217. struct rt_stat tblzzdz_stat; // 用于突变量整组动作统计
  218. struct rt_stat fz_stat; // 用于幅值启动统计
  219. struct rt_stat fzdz_stat; // 用于幅值动作统计
  220. struct rt_stat fzzzdz_stat; // 用于幅值整组动作统计
  221. #ifdef FUN_JDXX
  222. JDXX_DEF tJD; //小电流接地
  223. #endif
  224. YC_REFRESH_EN bYcRefresh;
  225. }TRELAY_T;
  226. extern TRELAY_T g_tRelay[];
  227. /*------------------------------ 变量声明 -------------------------------------
  228. */
  229. extern struct protect_stu g_protect; // 保护整组处理过程
  230. /*------------------------------ 函数声明 -------------------------------------
  231. */
  232. int protect_init(void);
  233. int protect_polling(void);
  234. int protect_tbl_qd(void);
  235. int protect_amp_qd_js(int sw);
  236. int protect_amp_lx_js(int sw);
  237. int protect_stat_reset(void);
  238. int protect_printf_process(void);
  239. int protect_amp_lx_js(int sw);
  240. void sw_op_fail(DWORD dStep);
  241. #ifdef YB_AUTO_SELECT
  242. bool fa_yb_enable(int sw);
  243. bool goose_yb_enable(int sw);
  244. bool bh_yb_enable(int sw);
  245. #endif
  246. //#ifdef GD_AREA_ZHONGSHAN_2020 //中山要求硬压板和软压板要一一对应
  247. #if defined GD_AREA_ZHONGSHAN_2020 || defined YB_AUTO_SELECT
  248. bool fa_fun_true(int sw);
  249. #endif
  250. #ifdef FUNC_DRIVE
  251. void quit_drive(void);
  252. #endif
  253. #endif //_APP_H
  254. /*------------------------------ 文件结束 -------------------------------------
  255. */