reclose.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747
  1. /*************************************************************************
  2. * 版权所有:
  3. * 文件版本: V1.00
  4. * 文件名称: reclose.c
  5. * 生成日期: 2007年10月15日
  6. * 作 者: 保护部 MWD
  7. * 功 能: 重合闸模块
  8. 包含: 重合闸数据准备、
  9. 检同期数据准备、
  10. 抽取电压数据判别、
  11. 闭锁重合闸判别、
  12. 充电、
  13. 重合闸启动、
  14. 重合闸检定、
  15. 重合逻辑
  16. **************************************************************************/
  17. #define __RECLOSE_C
  18. #include "head.h"
  19. /**********************************************************************
  20. 定义全局变量
  21. ***********************************************************************/
  22. /*------------------------------ 函数声明 -------------------------------------
  23. */
  24. static void AR_DataSet(int sw);
  25. static void AR_Recharge(int sw,DWORD dStep);
  26. static void AR_Disable(int sw);
  27. static void AR_Start(int sw,DWORD dStep);
  28. static void AR_Logic(int sw,DWORD dStep);
  29. static void AR_Reset(int sw,DWORD dStep);
  30. static void ARTQ_DataSet(int sw);
  31. /**************************************************************************
  32. 函数名称: AutoReclose
  33. 函数版本:1.00
  34. 作者: 硬件部
  35. 创建日期:2010.4.28
  36. 函数功能说明:重合闸功能块
  37. 输入参数:
  38. 输出参数:
  39. 返回值:
  40. ***************************************************************************/
  41. void AutoReclose(int sw,DWORD dStep)
  42. {
  43. AR_DataSet(sw); // 重合闸数据准备
  44. ARTQ_DataSet(sw);
  45. AR_Recharge(sw,dStep); // 重合闸充电
  46. AR_Disable(sw); // 重合闸闭锁
  47. AR_Start(sw,dStep); // 重合闸启动
  48. AR_Logic(sw,dStep); // 重合闸逻辑
  49. AR_Reset(sw,dStep); // 重合闸复归
  50. return;
  51. }
  52. void ARTQ_DataSet(int sw)
  53. {
  54. TCH_T *pSW=&g_tRelay[sw].tCHZ;
  55. TSETSW *pSet = &pRunSet->tSwSet[sw];
  56. bool bDa=false;
  57. bool bDu=false;
  58. long deltaA;
  59. qs16 ang2=0;
  60. TRELAY_T *pR=&g_tRelay[sw];
  61. static int print_flag=0;
  62. if(pRunSet->pt2vol==PUB_AC_UAB1)ang2=0;
  63. else if(pRunSet->pt2vol==PUB_AC_UBC1)ang2=-120*65536;
  64. else if(pRunSet->pt2vol==PUB_AC_UCA1)ang2=120*65536;
  65. else if(pRunSet->pt2vol==PUB_AC_UAB2)ang2=0;
  66. else if(pRunSet->pt2vol==PUB_AC_UBC2)ang2=-120*65536;
  67. else if(pRunSet->pt2vol==PUB_AC_UCA2)ang2=120*65536;
  68. pSW->sta.bFlag.bMxYY = OverRelay(g_ui[PUB_AC_UAB1].m2[0], pSet->dU_chz_yy,pSet->dU_chz_yy,false);
  69. pSW->sta.bFlag.bMxWY = LowRelay(g_ui[PUB_AC_UAB1].m2[0], pSet->dU_chz_wy,pSet->dU_chz_wy,false);
  70. pSW->sta.bFlag.bUxYY = OverRelay(g_ui[pRunSet->pt2vol].m2[0], pSet->dU_chz_yy,pSet->dU_chz_yy,false);
  71. pSW->sta.bFlag.bUxWY = LowRelay(g_ui[pRunSet->pt2vol].m2[0], pSet->dU_chz_wy,pSet->dU_chz_wy,false);
  72. deltaA=CalcAngSub(g_ui[PUB_AC_UAB1].ri.r,g_ui[PUB_AC_UAB1].ri.i,g_ui[pRunSet->pt2vol].ri.r,g_ui[pRunSet->pt2vol].ri.i);
  73. //deltaA = _AbsL(deltaA+ang2);//
  74. //deltaA = _AbsL((g_ui[PUB_AC_UAB1].p -ang1)- (g_ui[pRunSet->pt2vol].p-ang2));
  75. //bDa=((_AbsL(deltaA) < pSet->dA_chz_deltaAng)?true:false)&&pSW->sta.bFlag.bMxYY&&pSW->sta.bFlag.bUxYY; //角差满足要求
  76. bDa=((_AbsL(deltaA+ang2) < pSet->dA_chz_deltaAng)?true:false)&&pSW->sta.bFlag.bMxYY&&pSW->sta.bFlag.bUxYY; //角差满足要求
  77. bDu=(_AbsL(g_ui[PUB_AC_UAB1].fz -g_ui[pRunSet->pt2vol].fz)<pSet->dU_chz_deltaU)?true:false; //压差满足要求
  78. pSW->sta.bFlag.bTQMZ=
  79. #ifdef CHZ_JWY_LM
  80. (pSet->bTT_chz_tq || pSet->bTT_chz_mwy || pSet->bTT_chz_lwy) //同期合闸
  81. #else
  82. (pSet->bTT_chz_tq||pSet->bTT_chz_wy) //同期合闸
  83. #endif
  84. &&pSW->sta.bFlag.bMxYY //母线有压
  85. &&pSW->sta.bFlag.bUxYY //线路有压
  86. &&bDu //压差满足
  87. &&bDa //角差满足
  88. &&!tPT.uPT1DX.bFlag.bPTYC //无PT 异常
  89. &&!tPT.uPT2DX.bFlag.bPTYC; //无PT 异常
  90. pSW->sta.bFlag.bMWYMZ=
  91. #ifdef CHZ_JWY_LM
  92. (pSet->bTT_chz_mwy&&pSW->sta.bFlag.bMxWY&&pSW->sta.bFlag.bUxYY) //母线无压&&线路有压
  93. #else
  94. (pSet->bTT_chz_wy) //无压合闸
  95. #endif
  96. &&pSW->sta.bFlag.bMxWY //母线有压
  97. &&!tPT.uPT1DX.bFlag.bPTYC; //无PT 异常
  98. pSW->sta.bFlag.bUWYMZ=
  99. #ifdef CHZ_JWY_LM
  100. (pSet->bTT_chz_lwy&&pSW->sta.bFlag.bUxWY&&pSW->sta.bFlag.bMxYY) //线路无压&&母线有压
  101. #else
  102. (pSet->bTT_chz_wy) //无压合闸
  103. #endif
  104. &&pSW->sta.bFlag.bUxWY //线路无压
  105. &&!tPT.uPT2DX.bFlag.bPTYC; //无PT 异常
  106. pSW->sta.bFlag.bCHMZ=pSW->sta.bFlag.bTQMZ //同期满足
  107. ||pSW->sta.bFlag.bMWYMZ //母线无压满足
  108. ||pSW->sta.bFlag.bUWYMZ //线路无压满足
  109. #ifdef CHZ_JWY_LM
  110. ||((!pSet->bTT_chz_tq)&&(!pSet->bTT_chz_mwy)&&(!pSet->bTT_chz_lwy))
  111. #else
  112. ||((!pSet->bTT_chz_tq)&&(!pSet->bTT_chz_wy))
  113. #endif
  114. ;
  115. if(pR->tCHZ.sta.bFlag.bCHQD)
  116. {
  117. if(!pSW->sta.bFlag.bTQMZ&&(print_flag++%(1*200))==0)//1S
  118. {
  119. if((!bDa)&&(pSet->bTT_chz_tq))
  120. rt_printf("角差不满足 pt1=%d pt2=%d ang2=%d 角差=%d 相位补偿后角差=%d dz=%d pt2vol=%d\r\n",(g_ui[PUB_AC_UAB1].p)/65536,(g_ui[pRunSet->pt2vol].p)/65536,ang2/65536,deltaA/65536,_AbsL(deltaA+ang2)/65536,pSet->dA_chz_deltaAng/65536,pRunSet->pt2vol);
  121. #ifndef CHZ_JWY_LM
  122. if((!bDu)&&(pSet->bTT_chz_wy))
  123. rt_printf("压差不满足\r\n");
  124. #endif
  125. }
  126. }
  127. }
  128. /**************************************************************************
  129. 函数名称:AR_DataSet
  130. 函数版本:1.00
  131. 函数版本:1.00
  132. 作者: 硬件部
  133. 创建日期:2010.4.28
  134. 函数功能说明:重合闸数据准备
  135. 输入参数:无
  136. 输出参数:
  137. 返回值: 无
  138. ***************************************************************************/
  139. static void AR_DataSet(int sw)
  140. {
  141. u16 wNo;
  142. TRELAY_T *pR=&g_tRelay[sw];
  143. TCH_T *pSW =&pR->tCHZ;
  144. TSETSW *pSet = &pRunSet->tSwSet[sw];
  145. wNo=0;
  146. if(pSW->wAR_ActTimes < MAX_AR_TIMES) // 根据重合次数,设置时间继电器
  147. {
  148. wNo = pSW->wAR_ActTimes;
  149. }
  150. InitTR_Time(&pSW->tTCHJD_ARDelay, pSet->dT_chz[wNo], 0 ); //重合闸延时
  151. InitTR_Time(&pSW->tTCHFAIL_TW, pSet->dT_chz[wNo]+T_1s, 0 ); //重合闸延时
  152. }
  153. /**************************************************************************
  154. 函数名称: AR_Disable
  155. 函数版本:1.00
  156. 作者: 保护产品部
  157. 创建日期:2007.10.11
  158. 函数功能说明:重合闸闭锁判别,刷新"闭锁重合闸"标
  159. 输入参数:
  160. 输出参数:
  161. 返回值:
  162. ***************************************************************************/
  163. static void AR_Disable(int sw)
  164. {
  165. TRELAY_T *pR=&g_tRelay[sw];
  166. TCH_T *pSW =& pR->tCHZ;
  167. pSW->sta.bFlag.bBSCH = pR->tOC[BH_GL1].sta.bFlag.bBSCH // 过流闭锁重合闸
  168. || pR->tOC[BH_GL2].sta.bFlag.bBSCH //
  169. || pR->tOC[BH_GL3].sta.bFlag.bBSCH //
  170. || pR->tOC[BH_LX1].sta.bFlag.bBSCH //
  171. || pR->tOC[BH_LX2].sta.bFlag.bBSCH //
  172. #ifdef DISP_SET_LX3
  173. || pR->tOC[BH_LX3].sta.bFlag.bBSCH //
  174. #endif
  175. ||pR->tLostVot.uLostVot.bFlag.bTz // 失压跳闸闭锁重合
  176. ||pR->tXXTZ.uZOV.bFlag.bTz
  177. #ifdef PRO_AL_LOCK_HZ
  178. ||(pR->tDYJL.sta.bFlag.bTz && pRunSet->bTT_JLlockCHZ)
  179. ||(pR->tPLJL.sta.bFlag.bTz && pRunSet->bTT_JLlockCHZ)
  180. #else
  181. ||pR->tDYJL.sta.bFlag.bTz
  182. ||pR->tPLJL.sta.bFlag.bTz
  183. #endif
  184. ||pR->run_stu.bsch
  185. #ifndef PRO_UZ_START_REC//云浮要求零序电压能启动重合闸
  186. ||pR->tOVER_U0TZ.uZOV.bFlag.bTz
  187. #endif
  188. ||pR->tU0TZ.uZOV.bFlag.bTz //; // 零压分闸闭锁重合
  189. ||pR->run_stu.chzbs; //二次闭锁202004
  190. }
  191. /**************************************************************************
  192. 函数名称: AR_Recharge
  193. 函数版本:1.00
  194. 函数版本:1.00
  195. 作者: 硬件部
  196. 创建日期:2010.4.28
  197. 函数功能说明:重合闸充电,刷新"重合闸充电完成"标
  198. 输入参数:
  199. 输出参数:
  200. 返回值:
  201. ***************************************************************************/
  202. static void AR_Recharge(int sw,DWORD dStep)
  203. {
  204. TRELAY_T *pR=&g_tRelay[sw];
  205. TCH_T *pSW =&pR->tCHZ;
  206. TSETSW *pSet = &pRunSet->tSwSet[sw];
  207. bool bHCD1,bHCD2,bHCD3,bHCD4;
  208. #ifdef PRO_UZ_START_REC//云浮要求零序电压能启动重合闸
  209. bool bHCD5=false;
  210. RunTR(&pSW->tTCH_UO_BS, pR->tOVER_U0TZ.uZOV.bFlag.bQD && pSet->bTT_3U0Tz && pR->tSWST.uSWST.bFlag.bTZWZ, dStep);//有零序电压且跳位
  211. bHCD5 = pSW->tTCH_UO_BS.boolTrip;
  212. #endif
  213. // 放电条件
  214. RunTR(&pSW->tTCHFAIL_TW, pR->tSWST.uSWST.bFlag.bTZWZ, dStep); // 三相跳位延时
  215. bHCD1 = pSW->tTCHFAIL_TW.boolTrip; // 放电标志1:三相跳位时间到
  216. bHCD2 = (pR->tSWST.uSWST.bFlag.bTZWZ || pR->uBHDZ.bFlag.bBHT) //此处保护跳标志,是有100ms保持的信号
  217. && (!pSW->sta.bFlag.bCDWC); // 放电标志2:充电未完成,跳位或保护动作
  218. bHCD3 = pR->uRmtSW.bHandTz // 手动跳闸
  219. #ifdef SELF_OPEN_RELEASE
  220. || pR->uRmtSW.bSwTz // 开关拉杆跳闸
  221. #endif
  222. || pR->uRmtSW.bYTExecute // 遥控跳闸
  223. || pR->uBHDZ.bFlag.bTZSB // 跳闸失败
  224. || pR->tSWST.uSWST.bFlag.bTWYL // 跳位有流
  225. || (pR->tSWST.uSWST.bFlag.bWCN &&(!pSW->sta.bFlag.bCHQD)) // 弹簧未储能告警 正超广州样机重合闸启动后,收到弹簧未储能信号,重合闸不放电
  226. || pSW->sta.bFlag.bBSCH // 重合闸闭锁条件
  227. #ifdef GD_AREA_ECZD_2020
  228. ||(pSet->bTT_chz_wy && (tPT.uPT1DX.bFlag.bPTYC || tPT.uPT2DX.bFlag.bPTYC)) //无PT 异常; //检无压投入时,PT断线重合闸放电
  229. #endif
  230. || pR->tSWST.uSWST.bFlag.bIBSCHZ //大电流重合闸闭锁
  231. ||pR->tSWST.uSWST.bFlag.bKZHL; //控制回路断线检查
  232. //|| pSW->sta.bFlag.bCHFD; // 重合闸动作放电202004
  233. pSW->sta.bFlag.bFDBZ = (!BH_ALL_EN(sw)) // 总保护未投入
  234. || (!KZ_OUT_ALL_EN(sw)) // 控制出口未投入
  235. || (!pSet->bTT_CHZ) // 软压板: 重合闸未投入
  236. || (!pRunSet->bTT_CHZ_YB) // 重合闸软压板未投入
  237. || (!pR->run_stu.chzyb) // 重合闸硬压板未投入
  238. || bHCD1
  239. || bHCD2
  240. || bHCD3
  241. #ifdef PRO_UZ_START_REC
  242. || bHCD5
  243. #endif
  244. #ifdef FUNC_DRIVE_JY
  245. || gb_drive.b_bh_reclose
  246. #endif
  247. ;
  248. //放电清开放时间
  249. #ifdef FUN_CHZ_TOPEN
  250. if(pSW->sta.bFlag.bFDBZ)
  251. {
  252. pSW->sta.bFlag.bCHZOP=false;
  253. ResetTR(&pSW->tTCHOPENTime);
  254. }
  255. #endif
  256. if(pR->tSWST.uSWST.bFlag.bIBSCHZ&&pSW->sta.bFlag.bCDWC)
  257. {
  258. if(soe_check(EV_HI_CHZ_LOCK+sw*EV_SW_NUM)==false)
  259. {
  260. soe_record_ev( EV_HI_CHZ_LOCK+sw*EV_SW_NUM, 1, 0,0,0); // 重合闸闭锁
  261. }
  262. }
  263. else
  264. {
  265. if(!pR->tSWST.uSWST.bFlag.bIBSCHZ)
  266. {
  267. if(soe_check(EV_HI_CHZ_LOCK+sw*EV_SW_NUM)==true)
  268. {
  269. soe_record_ev( EV_HI_CHZ_LOCK+sw*EV_SW_NUM, 0, 0,0,0); // 重合闸闭锁
  270. }
  271. }
  272. }
  273. // 充电条件
  274. bHCD4 = !pSW->sta.bFlag.bFDBZ // 重合放电标
  275. && (((!pR->uBHQD.bFlag.bZQD) && pR->tSWST.uSWST.bFlag.bHZWZ ) // 非保护启动 && 合闸位置
  276. || pSW->sta.bFlag.bCDWC); // 充电完成自保持
  277. RunTR(&pSW->tTCHCD15s0s, bHCD4, dStep); // 充电15秒
  278. pSW->sta.bFlag.bCDWC = pSW->tTCHCD15s0s.boolTrip;
  279. if(pSW->sta.bFlag.bCDWC)
  280. {
  281. g_run_stu.cd|=(1<<sw);
  282. if(pSW->wAR_ActTimes>=pSet->d_chz_times)
  283. {
  284. g_run_stu.cd&=~(1<<sw);
  285. }
  286. if(soe_check(EV_ARCD+sw*EV_SW_NUM)==false) // 充电标志
  287. {
  288. soe_record_ev( EV_ARCD+sw*EV_SW_NUM,1, 0,0,0 );
  289. }
  290. #ifdef FUN_CHZ_TOPEN
  291. //终止重合返回
  292. if(soe_check(EV_CHZ_TOPEN+sw*EV_SW_NUM)==true)
  293. {
  294. soe_record_ev(EV_CHZ_TOPEN+sw*EV_SW_NUM, 0, 0,0,0); // 终止重合闸过程
  295. }
  296. #endif
  297. }
  298. else
  299. {
  300. #ifdef FUNC_DRIVE_JY
  301. if(BH_ALL_EN(sw))
  302. {
  303. gb_drive.b_drive_success = false; //充电未完成时,传动分后手合不允许报传动成功
  304. }
  305. #endif
  306. g_run_stu.cd&=~(1<<sw);
  307. if(soe_check(EV_ARCD+sw*EV_SW_NUM)==true) // // 充电标志
  308. {
  309. soe_record_ev( EV_ARCD+sw*EV_SW_NUM,0, 0,0,0 );
  310. }
  311. }
  312. }
  313. /**************************************************************************
  314. 函数名称: AR_Start
  315. 函数版本:1.00
  316. 函数版本:1.00
  317. 作者: 硬件部
  318. 创建日期:2010.4.28
  319. 函数功能说明:重合闸启动,刷新"三相偷跳启动重合闸"和"三跳启动重合闸"标
  320. 输入参数:
  321. 输出参数:
  322. 返回值:
  323. ***************************************************************************/
  324. static void AR_Start(int sw,DWORD dStep)
  325. {
  326. bool bCHQD_CHQD; // 三相启动重合闸
  327. TRELAY_T *pR=&g_tRelay[sw];
  328. TCH_T *pSW =&pR->tCHZ;
  329. TSETSW *pSet = &pRunSet->tSwSet[sw];
  330. bool bCQD1,bCQD2,bCQD3,bCQD4,bCQD5,bCQD6;
  331. // 不对应启动
  332. // 开关位置从合闸位置切换至分闸位置完成后,保留50ms展宽
  333. RunTR(&pSW->tTCHQDHW0ms50ms, pR->tSWST.uSWST.bFlag.bHZWZ, dStep);
  334. bCQD1 = pSW->tTCHQDHW0ms50ms.boolTrip;
  335. // 偷跳条件准备
  336. bCQD2 = pSet->bTT_TTCH_TT && bCQD1 && (!pR->tSWST.uSWST.bFlag.bHZWZ);
  337. // 保护启动
  338. // 保护动作后至保护动作返回,保留50ms展宽
  339. RunTR(&pSW->tTCHQD0ms50ms, pR->uBHDZ.bFlag.bBHTrip, dStep);
  340. bCQD3 = pSW->tTCHQD0ms50ms.boolTrip;
  341. // 重合已启动或保护启动,用于闭锁不对应启动
  342. bCQD4 = pSW->sta.bFlag.bCHQD || bCQD3;
  343. // 此处保护跳信号,是实时信号,即保护已返回
  344. bCQD5 = bCQD3 && (!pR->uBHDZ.bFlag.bBHTrip);
  345. // 重合启动自保持
  346. // 重合闸出口条件,用于防止重合闸合闸过程中,TWJ没有返回时,再次误发启动重合闸报文。
  347. bCQD6 = pSW->sta.bFlag.bCDWC // 重合充电完成
  348. && pSW->sta.bFlag.bCHQD // 三相启动重合闸
  349. && (!pSW->sta.bFlag.bCHCK); // 重合闸出口,取反
  350. // 偷跳启动重合闸
  351. pSW->sta.bFlag.bTTQD = pSW->sta.bFlag.bCDWC // 重合闸充电完成
  352. && bCQD2 // 偷跳判断完成
  353. && (!bCQD4); // 重合未启动,无保护跳过程
  354. // 三跳启动重合闸
  355. pSW->sta.bFlag.bTLQD = pSW->sta.bFlag.bCDWC // 重合闸充电完成
  356. &&bCQD5 // 有保护跳过程,而且保护已经返回,即故障已经解除
  357. && (!pSW->sta.bFlag.bCHQD); // 三相启动重合闸未启动
  358. // 三相启动重合闸
  359. bCHQD_CHQD = (((pSW->wAR_ActTimes<pSet->d_chz_times)&& // 重合次数未满 202004
  360. (pSW->sta.bFlag.bTTQD // 偷跳启动重合闸
  361. || pSW->sta.bFlag.bTLQD // 三跳启动重合闸
  362. || bCQD6)) // 三相启动重合闸
  363. #ifdef FUNC_DRIVE_JY
  364. || gb_drive.b_bh_reclose
  365. #endif
  366. );
  367. if( bCHQD_CHQD )
  368. {
  369. if( !pSW->sta.bFlag.bCHQD ) //重合开出标尚未置位
  370. {
  371. pSW->sta.bFlag.bCHQD = true; //此标志会一直维持到重合闸出口或充电标志放电
  372. pSW->sta.bFlag.bQDFG=true; //整组复归时有效202004
  373. soe_record_ev(EV_AR_START+sw*EV_SW_NUM, 1, 0,0,0);//重合启动SOE
  374. //rcd_start(sw,RECORD_TYPE_CHZ, RECORD_LEN_TZQD); //录波类型:跳闸类
  375. }
  376. }
  377. else
  378. {
  379. if( pSW->sta.bFlag.bCHQD )
  380. {
  381. pSW->sta.bFlag.bCHQD = false;
  382. soe_record_ev(EV_AR_START+sw*EV_SW_NUM,0 ,0,0,0);
  383. }
  384. }
  385. #ifdef FUN_CHZ_TOPEN
  386. //重合开放计时
  387. pSW->sta.bFlag.bCHZOP = bCHQD_CHQD||pSW->sta.bFlag.bCHZOP;
  388. RunTR(&pSW->tTCHOPENTime, pSW->sta.bFlag.bCHZOP, dStep); //重合开放延时
  389. if(pSW->tTCHOPENTime.boolTrip)//重合闸开放时间到复归
  390. {
  391. pSW->sta.wfFlag=0;
  392. pR->tCHZ.wAR_ActTimes=0;
  393. rt_printf("重合闸开放时间到:整组复归!\r\n");
  394. ResetTR(&pR->tCHZ.tTCHJD_ARDelay);//延时
  395. ResetTR(&pR->tCHZ.tTCHJD_HJS);//后加速延时
  396. ResetTR(&pSW->tTCHFAIL_TW);//重合失败
  397. ResetTR(&pSW->tTCHOKTime);//重合成功
  398. ResetTR(&pSW->tTCHBSDelay);//重合闭锁延时
  399. ResetTR(&pSW->tTCHJBSTime); //重合闭锁时间
  400. ResetTR(&pSW->tTCHCD15s0s); //重合充电时间
  401. #ifdef PRO_UZ_START_REC
  402. ResetTR(&pSW->tTCH_UO_BS); //U0闭锁确认
  403. #endif
  404. //soe
  405. if(soe_check(EV_CHZ_TOPEN+sw*EV_SW_NUM)==false)
  406. {
  407. soe_record_ev(EV_CHZ_TOPEN+sw*EV_SW_NUM, 1, 0,0,0); // 终止重合闸过程
  408. }
  409. }
  410. #endif
  411. }
  412. /**************************************************************************
  413. 函数名称: AR_Logic
  414. 函数版本:1.00
  415. 函数版本:1.00
  416. 作者: 硬件部
  417. 创建日期:2010.4.28
  418. 函数功能说明:重合闸逻辑判断
  419. 输入参数:
  420. 输出参数:
  421. 返回值:
  422. ***************************************************************************/
  423. static void AR_Logic(int sw,DWORD dStep)
  424. {
  425. bool bWCN;
  426. TRELAY_T *pR=&g_tRelay[sw];
  427. TCH_T *pSW =&pR->tCHZ;
  428. TSETSW *pSet = &pRunSet->tSwSet[sw];
  429. bool bHZL1,bHZL2,bHZL3,bHZL4,bHZL5,bHZL6,bHZL8;
  430. #ifdef PRO_AL_LOCK_HZ
  431. bool bYYOK,bFreqOK;
  432. DWORD freq0,freq1;
  433. bool bVABL_OK,bVABH_OK,bVBCL_OK,bVBCH_OK;
  434. #endif
  435. // 重合闸条件准备
  436. bHZL1 = (BH_ALL_EN(sw) // 总投退
  437. && pSet->bTT_CHZ // 软压板: 重合闸投
  438. && pRunSet->bTT_CHZ_YB // 软压板: 重合闸投
  439. && pR->run_stu.chzyb // 重合闸硬压板投入
  440. && ((pSW->sta.bFlag.bCHQD // 三相启动重合闸
  441. && pSW->sta.bFlag.bCDWC) // 重合闸充电完成
  442. #ifdef FUNC_DRIVE_JY
  443. || gb_drive.b_bh_reclose
  444. #endif
  445. ));
  446. #ifdef PRO_AL_LOCK_HZ
  447. if(pRunSet->bTT_StartCHZ_judgeVolt)
  448. {
  449. bVABL_OK = OverRelay(g_sw_pub.m2_max[2], pSet->dU_jl_ddy, pSet->dU_reclose_ddy_fh, pSW->CHZ_Judge_V_F.bVABLOK) ;
  450. bVABH_OK = LowRelay(g_sw_pub.m2_max[2], pSet->dU_jl_gdy, pSet->dU_reclose_gdy_fh, pSW->CHZ_Judge_V_F.bVABHOK) ;
  451. pSW->CHZ_Judge_V_F.bVABLOK = bVABL_OK;
  452. pSW->CHZ_Judge_V_F.bVABHOK = bVABH_OK;
  453. bVBCL_OK = OverRelay(g_sw_pub.m2_max[3], pSet->dU_jl_ddy, pSet->dU_reclose_ddy_fh, pSW->CHZ_Judge_V_F.bVBCLOK) ;
  454. bVBCH_OK = LowRelay(g_sw_pub.m2_max[3], pSet->dU_jl_gdy, pSet->dU_reclose_gdy_fh, pSW->CHZ_Judge_V_F.bVBCHOK) ;
  455. pSW->CHZ_Judge_V_F.bVBCLOK = bVBCL_OK;
  456. pSW->CHZ_Judge_V_F.bVBCHOK = bVBCH_OK;
  457. if((bVABL_OK && bVABH_OK) && (bVBCL_OK && bVBCH_OK)) //需双侧电压均满足条件才允许重合闸
  458. {
  459. bYYOK = true;
  460. }
  461. else
  462. {
  463. bYYOK = false;
  464. }
  465. }
  466. else
  467. {
  468. bYYOK = true;
  469. }
  470. if(pRunSet->bTT_StartCHZ_judgeFreq)
  471. {
  472. freq0 = freq_get(0)*65536;
  473. freq1 = freq_get(1)*65536;
  474. if(((freq0 >= pRunSet->tSwSet[sw].dU_jl_dhz) && (freq0 <= pRunSet->tSwSet[sw].dU_jl_ghz))
  475. && ((freq1 >= pRunSet->tSwSet[sw].dU_jl_dhz) && (freq1 <= pRunSet->tSwSet[sw].dU_jl_ghz))) //需双侧频率均满足条件才允许重合闸
  476. {
  477. bFreqOK = true;
  478. }
  479. else
  480. {
  481. bFreqOK = false;
  482. }
  483. }
  484. else
  485. {
  486. bFreqOK = true;
  487. }
  488. RunTR(&pSW->tTCHJD_ARDelay, bHZL1 && bYYOK && bFreqOK, dStep); //重合延时
  489. #else
  490. RunTR(&pSW->tTCHJD_ARDelay, bHZL1, dStep); //重合延时
  491. #endif
  492. bHZL2 = pSW->tTCHJD_ARDelay.boolTrip&& pSW->sta.bFlag.bCHMZ;
  493. // 弹簧未储能下降沿展宽30ms
  494. bWCN = pR->run_stu.wcn && pSet->bTT_WCN;
  495. RunTR(&pSW->tTCHJD_0ms30ms, bWCN, dStep);
  496. bHZL3 = pSW->tTCHJD_0ms30ms.boolTrip;
  497. // 重合闸条件准备好,弹簧储能OK,重合闸出口
  498. pSW->sta.bFlag.bCHCK = (!bHZL3) && bHZL2;
  499. // 重合闸开出自保持
  500. bHZL4 = pSW->sta.bFlag.bHz || pSW->sta.bFlag.bCHCK;
  501. // 重合开出持续200ms
  502. RunTR(&pSW->tTCHJD_200ms0ms, bHZL4, dStep);
  503. bHZL5 = pSW->tTCHJD_200ms0ms.boolTrip;
  504. // 重合闸开出,经过200ms后开出解除
  505. pSW->sta.bFlag.bHz =bHZL4 && (!bHZL5);
  506. // 重合闸指令发出后,且开关已经跳闸完成
  507. bHZL6 = pSW->sta.bFlag.bHz || pSW->sta.bFlag.bHZL7;
  508. pSW->sta.bFlag.bHZL7 = pR->tSWST.uSWST.bFlag.bTZWZ && bHZL6;
  509. // 开放后加速允许有效延时200ms展宽
  510. RunTR(&pSW->tTCHJD_HJS, pSW->sta.bFlag.bHZL7, dStep);
  511. bHZL8 = pSW->tTCHJD_HJS.boolTrip;
  512. pSW->sta.bFlag.bCHJS = pSW->tTCHJD_HJS.boolTrip
  513. && (!pR->tSWST.uSWST.bFlag.bTZWZ);
  514. //出口及发信
  515. if(pSW->sta.bFlag.bHz)
  516. {
  517. if(!pSW->sta.bFlag.bEvent) //重合开出标尚未置位
  518. {
  519. //亮重合动作灯
  520. pSW->sta.bFlag.bCHZLed = true;
  521. pSW->wAR_ActTimes++; //重合动作次数
  522. pSW->sta.bFlag.bEvent = true;
  523. //pSW->uCHFG.wfFlag=0; //每次重合出口后,清重合复归标志 修改时注意,此处需对标志字特殊处理
  524. pSW->sta.bFlag.bCHDZ=false; //重合闸动作
  525. pSW->sta.bFlag.bBYSD=false; //重合闸闭锁时间到
  526. pSW->sta.bFlag.bCHFD=false; //重合闸动作放电
  527. pSW->sta.bFlag.bCHBS=false; //重合闸闭锁
  528. pSW->sta.bFlag.bCK=false; //放电条件1
  529. if(pSW->wAR_ActTimes==1)
  530. {
  531. soe_record_ev(EV_AR1+sw*EV_SW_NUM, 1, 0,0,0); //重合动作SOE
  532. }
  533. else if(pSW->wAR_ActTimes==2)
  534. {
  535. soe_record_ev(EV_AR2+sw*EV_SW_NUM, 1, 0,0,0); //重合动作SOE
  536. }
  537. else if(pSW->wAR_ActTimes==3)
  538. {
  539. soe_record_ev(EV_AR3+sw*EV_SW_NUM, 1, 0,0,0); //重合动作SOE
  540. }
  541. rcd_start(sw,RECORD_TYPE_CHZ,RECORD_LEN_TZQD);
  542. ResetTR(&pSW->tTCHFAIL_TW); // 重合出口后,重新复归时间继电器
  543. ResetTR(&pSW->tTCHOKTime); //重合成功时间继电器,在重合出口后重新计数
  544. ResetTR(&pSW->tTCHBSDelay); //闭锁重合延时继电器重新计数
  545. ResetTR(&pSW->tTCHJBSTime); //闭锁重合延时继电器重新计数
  546. //RunTR(&pSW->tTCHJBSTime, 1, 1); //重合闸动作后,该计时器计时,在确认时间内有保护动作,置重合闸闭锁标志
  547. #ifdef FUNC_DRIVE_JY
  548. gb_drive.b_bh_reclose = false;
  549. #endif
  550. }
  551. }
  552. else
  553. {
  554. if( pSW->sta.bFlag.bEvent ) //重合开出标尚未置位
  555. {
  556. pSW->sta.bFlag.bEvent = false;
  557. if(soe_check(EV_AR1+sw*EV_SW_NUM))
  558. {
  559. soe_record_ev(EV_AR1+sw*EV_SW_NUM, 0, 0,0,0 ); //重合1动作SOE返回
  560. }
  561. if(soe_check(EV_AR2+sw*EV_SW_NUM))
  562. {
  563. soe_record_ev(EV_AR2+sw*EV_SW_NUM, 0, 0,0,0 ); //重合2动作SOE返回
  564. }
  565. if(soe_check(EV_AR3+sw*EV_SW_NUM))
  566. {
  567. soe_record_ev(EV_AR3+sw*EV_SW_NUM, 0, 0,0,0 ); //重合2动作SOE返回
  568. }
  569. }
  570. }
  571. }
  572. /**************************************************************************
  573. 函数名称: AR_Reset
  574. 函数版本:1.00
  575. 函数版本:1.00
  576. 作者: 硬件部
  577. 创建日期:2010.4.28
  578. 函数功能说明:重合闸复归逻辑
  579. 输入参数:
  580. 输出参数:
  581. 返回值:
  582. ***************************************************************************/
  583. static void AR_Reset(int sw,DWORD dStep)
  584. {
  585. TRELAY_T *pR=&g_tRelay[sw];
  586. TCH_T *pSW =&pR->tCHZ;
  587. TSETSW *pSet = &pRunSet->tSwSet[sw];
  588. bool bFD1,bCHBS1,bCHBS2;
  589. // 重合闸出口自锁202004
  590. pSW->sta.bFlag.bCHDZ = (pSW->sta.bFlag.bCHCK || pSW->sta.bFlag.bCHDZ);
  591. // 二次重合闭锁(未到最后一次重合) 202004
  592. RunTR(&pSW->tTCHBSDelay, (pSW->sta.bFlag.bCHDZ && pSW->wAR_ActTimes<pSet->d_chz_times), dStep);
  593. pSW->sta.bFlag.bBYSD = pSW->tTCHBSDelay.boolTrip;
  594. bCHBS1= (pSW->sta.bFlag.bCHDZ && pSW->wAR_ActTimes<pSet->d_chz_times)
  595. &&(!pSW->sta.bFlag.bBYSD); // 重合闸闭锁时间未到
  596. //重合闭锁(最后一次)
  597. //重合闸动作后,该计时器计时,在确认时间内有保护动作,置重合闸闭锁标志
  598. RunTR(&pSW->tTCHJBSTime, (pSW->sta.bFlag.bCHDZ && pSW->wAR_ActTimes>=pSet->d_chz_times), dStep);
  599. bCHBS2= pSW->tTCHJBSTime.boolTrip;
  600. //重合闸闭锁
  601. pSW->sta.bFlag.bCHBS = pR->uBHDZ.bFlag.bBHT
  602. &&(bCHBS1||bCHBS2);
  603. if(pSW->sta.bFlag.bCHBS )
  604. {
  605. if(soe_check(EV_ARBS+sw*EV_SW_NUM)==false)
  606. {
  607. led_set_sw(sw,SW_LED_CHZBS, LED_ON);//重合闸闭锁灯与充电灯功能相反
  608. soe_record_ev( EV_ARBS+sw*EV_SW_NUM, 1, 0,0,0); // 重合闸闭锁
  609. g_tRelay[sw].run_stu.chzbs=true;
  610. }
  611. ResetTR(&pSW->tTCHJBSHw);
  612. ResetTR(&pSW->tTCHJBSTime);
  613. ResetTR(&pSW->tTCHOKTime);
  614. ResetTR(&pSW->tTCHBSDelay);
  615. pSW->sta.bFlag.bCHDZ=false;
  616. }
  617. //复归
  618. // 重合出口后,经过重合闸确认时间,无保护动作,即复归,完成该次重合过程202004
  619. // 如果在确认时间内,重合闭锁时间外,有保护动作,即进入下一计数重合
  620. pSW->sta.bFlag.bCK = ((!pR->uBHDZ.bFlag.bBHT)
  621. && (pSW->sta.bFlag.bCHCK || pSW->sta.bFlag.bCK)); //重合出口及自保持
  622. RunTR(&pSW->tTCHOKTime, pSW->sta.bFlag.bCK, dStep);
  623. bFD1 = pSW->tTCHOKTime.boolTrip;
  624. if(bFD1)
  625. {
  626. if(pR->tCHZ.wAR_ActTimes)
  627. rt_printf_time("重合闸复归\r\n");
  628. pSW->sta.bFlag.bCHDZ=false;
  629. pR->tCHZ.wAR_ActTimes=0;
  630. ResetTR(&pR->tCHZ.tTCHJD_HJS);
  631. ResetTR(&pSW->tTCHOKTime);
  632. ResetTR(&pSW->tTCHBSDelay);
  633. ResetTR(&pSW->tTCHJBSTime); //重合成功时间继电器,在重合出口后重新计数
  634. #ifdef FUN_CHZ_TOPEN
  635. pSW->sta.bFlag.bCHZOP=false;
  636. ResetTR(&pSW->tTCHOPENTime);
  637. #endif
  638. }
  639. // 手动/自动复归条件:(1)重合闸闭锁(2)重合已启动,但充电标志已清零
  640. if(g_tRelay[sw].run_stu.chzbs //闭锁
  641. || (!pSW->sta.bFlag.bCDWC && pSW->sta.bFlag.bQDFG))//已启动重合计时,又被放电
  642. {
  643. pSW->sta.bFlag.bQDFG = false;
  644. }
  645. }
  646. /***************************************endfile**********************************************************/