protect.h 9.4 KB

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