UnitsLib.c 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035
  1. /*************************************************************************
  2. * 版权所有:
  3. * 文件版本: V1.00
  4. * 文件名称: DILogic.c
  5. * 生成日期: 2008年11月15日
  6. * 作 者:
  7. * 功 能: 开入逻辑功能
  8. * 更新信息:
  9. * 更新日志1:
  10. * 日期:
  11. * 修改者:
  12. * 修改内容:
  13. * 修改原因:
  14. * 更新日志2:
  15. **************************************************************************/
  16. #include "head.h"
  17. /******************************************************************************
  18. 函数名称: ProtectRelayInit
  19. 函数版本: 01.01
  20. 创建作者:
  21. 创建日期: 2013-08-08
  22. 函数说明: 上电时初始化保护相关的定时器,包括定值设置的、固定的
  23. 参数说明:
  24. 返回值:
  25. 修改记录:
  26. */
  27. void ProtectRelayInit(void)
  28. {
  29. int sw,i;
  30. for(sw=0;sw<g_sw_num;sw++)
  31. {
  32. TRELAY_T *pR=&g_tRelay[ sw];
  33. TSETSW *pSet = &pRunSet->tSwSet[sw];
  34. int i;
  35. #ifdef CUSTOMIZE_BZT //备自投
  36. BztTimerInit(sw);
  37. #endif
  38. for(i=0;i<BHOC_NUMBER;i++)
  39. {
  40. TOC_T *poc=&pR->tOC[i];
  41. #ifdef YX_RESET_TIME
  42. InitTR(&poc->tTzEvRstTime, tRunPara.dTEventRst, 0); // 遥信复归时间
  43. InitTR(&poc->tGjEvRstTime, tRunPara.dTEventRst, 0); // 遥信复归时间
  44. #endif
  45. InitTR(&poc->tQDTime, pSet->toc[i].dT, PRO_RET_TIME); //CorrectTR(&poc->tQDTime);
  46. InitTR(&poc->tXBTime, T_20ms, 0);
  47. InitTR(&poc->tXBQD25ms, T_25ms*2, 0);
  48. InitTR(&poc->tFz25ms, T_25ms, 0);
  49. if(i>=BH_OVI)
  50. {
  51. InitTR(&poc->tQDTime, pSet->toc[i].dT, WRN_RET_TIME); // 过载及重载,返回时间为1秒
  52. }
  53. }
  54. {
  55. TGOC_T *poc=&pR->tgoc;
  56. GOC_SET *pgset=&pSet->tGocSet;
  57. DWORD dTsytime;
  58. dTsytime=((pgset->dTgzgl>pgset->dTsdlost)?pgset->dTgzgl:pgset->dTsdlost)+T_300ms;
  59. if(pRunSet->bTT_goose_send_after)
  60. {
  61. InitTR(&poc->tTZX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  62. InitTR(&poc->tTFX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  63. InitTR(&poc->tTWX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  64. InitTR(&poc->tTLX_300ms, pgset->dTlx, pRunSet->dT_sendext); //
  65. }
  66. else
  67. {
  68. InitTR(&poc->tTZX_300ms, T_5ms, pRunSet->dT_sendext); //
  69. InitTR(&poc->tTFX_300ms, T_5ms, pRunSet->dT_sendext); //
  70. InitTR(&poc->tTWX_300ms, T_5ms, pRunSet->dT_sendext); //
  71. InitTR(&poc->tTLX_300ms, T_5ms, pRunSet->dT_sendext); //
  72. }
  73. InitTR(&poc->tTGLBS_300ms, T_5ms, pRunSet->dT_sendext); //
  74. InitTR(&poc->tglFz25ms, T_25ms, 0);
  75. InitTR(&poc->tlxFz25ms, T_25ms, 0);
  76. InitTR(&poc->tglQD25ms, T_25ms, 0);
  77. InitTR(&poc->tlxQD25ms, T_25ms, 0);
  78. InitTR(&poc->tTHz1s, T_1s, 0);
  79. InitTR(&poc->tgoose15ms_gzgl, pRunSet->dT_goosecheck, 0); //
  80. InitTR(&poc->tqccd.tCDTime,pRunSet->dT_cd, 0);
  81. InitTR(&poc->tqccd.tWYTime,pRunSet->dT_glfd, 0);
  82. InitTR(&poc->tglcd.tCDTime,pRunSet->dT_cd, 0);
  83. InitTR(&poc->tglcd.tWYTime,pRunSet->dT_glfd, 0);
  84. if(pRunSet->dT_cd==0)
  85. {
  86. InitTR(&poc->tllcd.tCDTime,T_1s*15, 0);
  87. }
  88. else
  89. {
  90. InitTR(&poc->tllcd.tCDTime,pRunSet->dT_cd, 0);
  91. }
  92. InitTR(&poc->tllcd.tWYTime,pRunSet->dT_llfd, 0);
  93. if(pRunSet->bTT_goose_send_after)
  94. {
  95. InitTR(&poc->tglQDTime, pgset->dTgl+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  96. InitTR(&poc->tlxQDTime, pgset->dTlx+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  97. }
  98. else
  99. {
  100. InitTR(&poc->tglQDTime, ((pgset->dTgl>pRunSet->dT_goosecheck)?pgset->dTgl:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  101. InitTR(&poc->tlxQDTime, ((pgset->dTlx>pRunSet->dT_goosecheck)?pgset->dTlx:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  102. }
  103. InitTR(&poc->tgzglTime, pgset->dTgzgl, 0); //
  104. InitTR(&poc->tsdlostTime, pgset->dTsdlost, 0); //
  105. InitTR(&poc->terrlostTime, pgset->dTgzgl, 0); //
  106. InitTR(&poc->tllhzTime, pgset->dTll, 0); //
  107. InitTR(&poc->tllQdTime, pgset->dTll+((pgset->dTgzgl>pgset->dTsdlost)?pgset->dTgzgl:pgset->dTsdlost)+T_1s, 0); //
  108. InitTR(&poc->tglslowTime, 0,pgset->dTgl+T_1s); //
  109. InitTR(&poc->tlxslowTime, 0,pgset->dTlx+T_1s); //
  110. #if defined GD_AREA_ZHONGSHAN || defined GD_AREA_ZHONGSHAN_2020
  111. InitTR(&poc->tgl2Fz25ms, T_25ms, 0);
  112. InitTR(&poc->tgl2QD25ms, T_25ms, 0);
  113. InitTR(&poc->tgl2slowTime, 0,pgset->dTgl2+T_1s); //#ifdef GD_AREA_GDDKY_TEST
  114. if(pRunSet->bTT_goose_send_after)
  115. {
  116. InitTR(&poc->tgl2QDTime, pgset->dTgl2+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  117. InitTR(&poc->tTZX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  118. InitTR(&poc->tTFX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  119. InitTR(&poc->tTWX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  120. }
  121. else
  122. {
  123. InitTR(&poc->tgl2QDTime, ((pgset->dTgl2>pRunSet->dT_goosecheck)?pgset->dTgl2:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  124. InitTR(&poc->tTZX2_300ms, T_5ms, pRunSet->dT_sendext); //
  125. InitTR(&poc->tTFX2_300ms, T_5ms, pRunSet->dT_sendext); //
  126. InitTR(&poc->tTWX2_300ms, T_5ms, pRunSet->dT_sendext); //
  127. }
  128. #endif
  129. InitTR(&poc->tTzcheckTime, pRunSet->dT_TZSB, 0); //开关失灵判断时间
  130. InitTR(&poc->tHzcheckTime, pRunSet->dT_HZSB, 0); //开关失灵判断时间
  131. InitTR(&poc->ttzsbextTime, 0,pRunSet->dT_sendext); // 跳闸失败(开关失灵)展宽时间
  132. InitTR(&poc->tgzglokextTime, 0,pRunSet->dT_sendext); // 发送展宽 300毫秒
  133. InitTR(&poc->tgzglokForbitTime, 0,pRunSet->dT_frobit); //发送故障隔离成功后闭锁时间
  134. InitTR(&poc->tCYY3sdelayms, T_1s*3,dTsytime);
  135. InitTR(&poc->tgoosedelayms_ll, dTsytime+pRunSet->dT_TZSB*2, 0);
  136. InitTR(&poc->tllWY1Time, T_100ms, T_100ms);
  137. InitTR(&poc->tllWY2Time, T_100ms, T_100ms);
  138. InitTR(&poc->tllYY1Time, T_100ms, T_100ms+T_20ms);
  139. InitTR(&poc->tllYY2Time, T_100ms, T_100ms+T_20ms);
  140. InitTR(&poc->textbsTime, 0, pRunSet->dT_sendext+T_100ms);
  141. }
  142. //重合闸
  143. InitTR(&pR->tCHZ.tTCHQDHW0ms50ms, 0,T_10ms*5); //合闸位置下降沿展宽50ms
  144. InitTR(&pR->tCHZ.tTCHQD0ms50ms, 0,T_10ms*5 ); //跳闸开出下降沿展宽50ms
  145. InitTR(&pR->tCHZ.tTCHJD_0ms30ms, 0,T_10ms*3 ); //弹簧未储能下降沿展宽30ms
  146. InitTR(&pR->tCHZ.tTCHJD_200ms0ms, T_200ms,0 ); //重合开出宽度
  147. InitTR(&pR->tCHZ.tTCHCD15s0s, pSet->dT_chz_cd,0 ); //充电15秒
  148. InitTR(&pR->tCHZ.tTCHJD_ARDelay, pSet->dT_chz[0],0 ); //重合闸延时
  149. InitTR(&pR->tCHZ.tTCHFAIL_TW, pSet->dT_chz[0]+T_1s, 0 ); //三相跳位延时: 重合失败返回时间
  150. InitTR(&pR->tCHZ.tTCHBSDelay, pSet->dT_chz_bs,0 ); //重合闭锁延时
  151. InitTR(&pR->tCHZ.tTCHOKTime, pSet->dT_chz_ok,0 ); //重合闭锁延时
  152. //InitTR(&pR->tCHZ.tTCHJD_HJS, 0, T_1s); // zwg20151019,后加速有效展宽,从200ms改为1s,方便测试
  153. InitTR(&pR->tCHZ.tTCHJD_HJS, 0, T_300ms ); // 2020-07-23 分位持续检测时间改为1s,按照广东标准2020 手合开放检测时间,将3s时间改为0.3s,即分闸持续1S以上,手合0.3秒内可启动后加速
  154. InitTR(&pR->tCHZ.tTCHJBSTime, 0,pSet->dT_chz_ok ); //重合闭锁时间
  155. InitTR(&pR->tCHZ.tTCHJBSHw, T_100ms, 0); // 开关合位100ms确认
  156. #ifdef PRO_UZ_START_REC
  157. InitTR(&pR->tCHZ.tTCH_UO_BS, T_100ms, 0 ); //;零序电压重合闭锁延时
  158. #endif
  159. #ifdef FUN_CHZ_TOPEN
  160. InitTR(&pR->tCHZ.tTCHOPENTime, pSet->dT_chz_Topen, 0 ); //;重合开放时间
  161. #endif
  162. #ifdef SELF_OPEN_RELEASE
  163. InitTR(&pR->tTripBHTKeep, 0, tRunPara.wYXFD*T_5ms/5+T_40ms);
  164. #endif
  165. // 保护跳闸脉宽
  166. InitTR(&pR->tTrip_BHT40MS, 0, T_40ms); //跳闸脉冲最短时间40ms ,以前为100ms,在做多次重合闸是,若时间整定为100ms左右,会有异常
  167. //配网功能定值
  168. InitTR(&pR->tSDHZ.tOnXSTime, pSet->dT_X,0);
  169. InitTR(&pR->tSDHZ.tOnYSTime, pSet->dT_Y,0);
  170. InitTR(&pR->tSDHZ.tOnZSTime, T_100ms*35,0); // 3.5秒
  171. InitTR(&pR->tSDHZ.tOnXLTime, pSet->dT_XL,0);
  172. InitTR(&pR->tSDHZ.tOnYLTime, pSet->dT_Y,0);
  173. #ifdef GD_AREA_ZHONGSHAN_2020
  174. InitTR(&pR->tSDHZ.tOnLLCDYLTime, pSet->dT_LL_CD,0);
  175. #endif
  176. InitTR(&pR->tSDHZ.tOnBSTZTime, pSet->dT_fa_bsTz,0);
  177. InitTR(&pR->tSDHZ.tOnZLTime, T_100ms*35,0); // 3.5秒
  178. InitTR(&pR->tSDHZ.tOnOCingTime, pSet->dT_fa_ocing,pSet->dT_Y);
  179. InitTR(&pR->tSDHZ.tOnLXingTime, pSet->dT_fa_lxing,pSet->dT_Y);
  180. InitTR(&pR->tSDHZ.tOnJSTime, pRunSet->dT_ldjs, 0); ////初始化单侧来电解锁计时器
  181. #ifdef GD_AREA_ZHONGSHAN_2020
  182. InitTR(&pR->tSDHZ.tOnY_JSTime, 0, 0);
  183. #elif defined GD_AREA_ECZD_2020 || defined GD_AREA_ZHONGSHAN
  184. InitTR(&pR->tSDHZ.tOnY_JSTime, T_1s*6, 0);
  185. #else
  186. InitTR(&pR->tSDHZ.tOnY_JSTime, T_1s*3, 0);
  187. #endif
  188. #if defined GD_AREA_ZHONGSHAN_2020 || defined GD_AREA_ECZD_2020 || defined GD_AREA_ZHONGSHAN
  189. #if defined GD_AREA_ECZD_2020
  190. #if defined FUNC_SET_FA_JS
  191. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, pRunSet->dT_FA_JS, 0);
  192. #elif defined GD_AREA_ECZD_MAOMING
  193. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, 3*T_1s, 0);
  194. #else
  195. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, 5*T_10ms, 0);
  196. #endif
  197. #else
  198. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, T_1s*6, 0);
  199. #endif
  200. #else
  201. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, T_1s, 0);
  202. #endif
  203. #ifdef FA_OC_COUNT
  204. InitTR(&pR->tSDHZ.tFaOcCountTime, pSet->fa_oc_conut_time, 0);
  205. #endif
  206. if(pSet->toc[FA_GL].dT>T_FA_TZ_MIN_TIME)
  207. {
  208. InitTR(&pR->tSDHZ.tGZJYRstGLTime,pSet->toc[FA_GL].dT,pSet->dT_Y);
  209. }
  210. else
  211. {
  212. InitTR(&pR->tSDHZ.tGZJYRstGLTime,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  213. }
  214. if(pSet->toc[FA_GL_II].dT>T_FA_TZ_MIN_TIME)
  215. {
  216. InitTR(&pR->tSDHZ.tGZJYRstGL_II_Time,pSet->toc[FA_GL_II].dT,pSet->dT_Y);
  217. }
  218. else
  219. {
  220. InitTR(&pR->tSDHZ.tGZJYRstGL_II_Time,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  221. }
  222. if(pSet->toc[FA_GL2].dT>T_FA_TZ_MIN_TIME)
  223. InitTR(&pR->tSDHZ.tGZJYRstGL2Time,pSet->toc[FA_GL2].dT,T_20ms);
  224. else
  225. InitTR(&pR->tSDHZ.tGZJYRstGL2Time,T_FA_TZ_MIN_TIME,T_20ms);
  226. if(pSet->toc[FA_LX].dT>T_FA_TZ_MIN_TIME)
  227. {
  228. InitTR(&pR->tSDHZ.tGZJYRstJDTime,pSet->toc[FA_LX].dT,pSet->dT_Y);
  229. }
  230. else
  231. {
  232. InitTR(&pR->tSDHZ.tGZJYRstJDTime,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  233. }
  234. if(pSet->toc[FA_LX2].dT>T_FA_TZ_MIN_TIME)
  235. InitTR(&pR->tSDHZ.tGZJYRstJD2Time,pSet->toc[FA_LX2].dT,pSet->dT_Y);
  236. else
  237. InitTR(&pR->tSDHZ.tGZJYRstJD2Time,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  238. InitTR(&pR->tSDHZ.tL_RELAYONL3s, pSet->dT_Y, 0);
  239. InitTR(&pR->tSDHZ.tHzS100ms,0, T_200ms);
  240. InitTR(&pR->tSDHZ.tUDBS100ms,T_100ms, 0);
  241. InitTR(&pR->tSDHZ.tUABS25ms,pSet->dT_fa_YY, T_25ms*2);
  242. InitTR(&pR->tSDHZ.tUBCS25ms,pSet->dT_fa_YY, T_25ms*2);
  243. #ifdef FUNC_NYY_NWY
  244. InitTR(&pR->tSDHZ.tUABS_NYY_NWY_50ms,T_25ms*2, T_25ms*2);
  245. InitTR(&pR->tSDHZ.tUBCS_NYY_NWY_50ms,T_25ms*2, T_25ms*2);
  246. InitTR(&pR->tSDHZ.tUABL_NYY_NWY_50ms,T_25ms*2, T_25ms*2);
  247. InitTR(&pR->tSDHZ.tUBCL_NYY_NWY_50ms,T_25ms*2, T_25ms*2);
  248. #endif
  249. InitTR(&pR->tSDHZ.tUFABL80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  250. InitTR(&pR->tSDHZ.tUFBCL80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  251. InitTR(&pR->tSDHZ.tUFDBTime,pRunSet->dT_XCY, 0);
  252. InitTR(&pR->tSDHZ.tUABL25ms,pSet->dT_fa_YY, T_25ms*2);
  253. InitTR(&pR->tSDHZ.tUBCL25ms,pSet->dT_fa_YY, T_25ms*2);
  254. InitTR(&pR->tSDHZ.tUFABS80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  255. InitTR(&pR->tSDHZ.tUFBCS80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  256. InitTR(&pR->tSDHZ.tUFABS25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  257. InitTR(&pR->tSDHZ.tUFBCS25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  258. InitTR(&pR->tSDHZ.tUFABL25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  259. InitTR(&pR->tSDHZ.tUFBCL25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  260. #ifdef FA_PL_PJ
  261. InitTR(&pR->tSDHZ.tFREQAB25ms_SCY,T_25ms*2, T_25ms*2);
  262. InitTR(&pR->tSDHZ.tFREQBC25ms_SCY,T_25ms*2, T_25ms*2);
  263. InitTR(&pR->tSDHZ.tFREQAB25ms_LCY,T_25ms*2, T_25ms*2);
  264. InitTR(&pR->tSDHZ.tFREQBC25ms_LCY,T_25ms*2, T_25ms*2);
  265. InitTR(&pR->tSDHZ.tFREQSAB25ms,T_25ms, T_25ms*2);
  266. InitTR(&pR->tSDHZ.tFREQSBC25ms,T_25ms, T_25ms*2);
  267. InitTR(&pR->tSDHZ.tFREQLAB25ms,T_25ms, T_25ms*2);
  268. InitTR(&pR->tSDHZ.tFREQLBC25ms,T_25ms, T_25ms*2);
  269. #endif
  270. InitTR(&pR->tSDHZ.tOpsiteYY100ms,0, 0);
  271. InitTR(&pR->tSDHZ.tPowerYY100ms,0, 0);
  272. InitTR(&pR->tSDHZ.tHw100ms100ms,T_100ms,T_100ms);
  273. InitTR(&pR->tSDHZ.tTw100ms100ms,T_100ms,T_100ms);
  274. InitTR(&pR->tSDHZ.tHz0ms1s,0,tRunPara.wFAHZT*T_5ms/5+T_1s);
  275. InitTR(&pR->tSDHZ.tTz0ms1s,0,tRunPara.wFAFZT*T_5ms/5+T_1s);
  276. InitTR(&pR->tSDHZ.tHz0ms2s,pRunSet->dT_HZSB,0);
  277. InitTR(&pR->tSDHZ.tTz0ms2s,pRunSet->dT_TZSB,0);
  278. InitTR(&pR->tSDHZ.tTSDHzHJS, 0, pSet->dT_Y); //上电合闸加速判断
  279. InitTR(&pR->tU0TZ.tZOVTime, pSet->dT_OverU0, T_20ms);
  280. InitTR(&pR->tOVER_U0TZ.tZOVTime, pSet->dBHTOverU0, T_20ms);
  281. //InitTR(&pR->tGdy.tQDTime, pSet->dT_gy, T_20ms);
  282. InitTR(&pR->tLostVot.tCYY25ms0ms, T_25ms, 0);
  283. InitTR(&pR->tLostVot.tLostVotTime, pSet->dT_Z, T_20ms);
  284. InitTR(&pR->tLostVot.tLostVLockTime,0,pSet->dT_fa_bsTz);
  285. InitTR(&pR->tTQHz.tTQTime,pSet->dT_tq,0); //同期
  286. InitTR(&pR->tTQHz.tTQQDTime,0, pRunSet->dT_tq_fh);
  287. //解列
  288. InitTR(&pR->tDYJL.tDdyTime, pSet->dT_jl_ddy, T_20ms); //CorrectTR(&pR->tDYJL.tDdyTime); CorrectTR(&pR->tDYJL.tDdyTime);
  289. InitTR(&pR->tDYJL.tGdyTime, pSet->dT_jl_gdy, T_20ms); //CorrectTR(&pR->tDYJL.tGdyTime); CorrectTR(&pR->tDYJL.tGdyTime);
  290. InitTR(&pR->tDYJL.tHighTime, pSet->dT_jl_ggdy, T_20ms); //CorrectTR(&pR->tDYJL.tHighTime); CorrectTR(&pR->tDYJL.tHighTime);
  291. InitTR(&pR->tDYJL.tLowTime, pSet->dT_jl_gddy, T_20ms);
  292. InitTR(&pR->tPLJL.tDhzTime, pSet->dT_jl_dhz, T_40ms); //CorrectTR(&pR->tPLJL.tDhzTime); CorrectTR(&pR->tPLJL.tDhzTime);
  293. InitTR(&pR->tPLJL.tHighTime, pSet->dT_jl_ghz, T_40ms); //CorrectTR(&pR->tPLJL.tHighTime); CorrectTR(&pR->tPLJL.tHighTime);
  294. InitTR(&pR->tPLJL.tLowTime, pSet->dT_jl_lowhz, T_40ms);//CorrectTR(&pR->tPLJL.tLowTime); CorrectTR(&pR->tPLJL.tLowTime);
  295. InitTR(&pR->tDYJL.thcbs1_0ms_100ms, 0, T_100ms); // 滑差闭锁延迟返回继电器
  296. InitTR(&pR->tDYJL.thcbs2_0ms_100ms, 0, T_100ms);
  297. InitTR(&pR->tPLJL.thcbs1_0ms_100ms, 0, T_100ms);
  298. InitTR(&pR->tPLJL.thcbs2_0ms_100ms, 0, T_100ms);
  299. //手合加速
  300. //#if defined GD_AREA_MAIN_2020 || defined GD_AREA_ECZD_2020
  301. InitTR(&pR->tSWST.tTRunST_20s1s, T_1s, T_300ms ); // 2020-07-23 分位持续检测时间改为1s,按照广东标准2020 手合开放检测时间,将3s时间改为0.3s,即分闸持续1S以上,手合0.3秒内可启动后加速
  302. //#else
  303. // InitTR(&pR->tSWST.tTRunST_20s1s, T_1s, T_1s*3 ); // 2020-3-19 分位持续检测时间改为1s,手合开放检测时间按行业标准,将1s时间改为3s,即分闸持续1S以上,手合三秒内可启动后加速
  304. //#endif
  305. #if defined GD_AREA_ECZD_2020 ||defined GD_AREA_MAIN_2020
  306. InitTR(&pR->tSWST.tSHz3s10ms, T_1s, T_10ms);
  307. #else
  308. InitTR(&pR->tSWST.tSHz3s10ms, T_1s*3, T_10ms);
  309. #endif
  310. InitTR(&pR->tSWST.tSTz3s10ms, T_1s*3, T_10ms);
  311. InitTR(&pR->tSWST.tSf3s, T_1s*3, 0);
  312. InitTR(&pR->tSWST.tTTWYL_10S1S,T_1s*10, T_1s);
  313. InitTR(&pR->tSWST.tTWCNGJ1s, pRunSet->dWCN_T, WRN_RET_TIME);
  314. InitTR(&pR->tSWST.tTKZHLGJ1s, T_1s*10, WRN_RET_TIME);
  315. InitTR(&pR->tSWST.tIBSCHZ, T_25ms, WRN_RET_TIME);// T_1s
  316. InitTR(&pR->tTripfail_2s, pRunSet->dT_TZSB, 0); //跳闸失败时间继电器
  317. InitTR(&pR->tTripfail_hz, 0 , pRunSet->dT_TZSB); //跳闸失败时间继电器
  318. InitTR(&pR->tSWST.tCTXXYC, T_1s*3, WRN_RET_TIME); // CT相序异常
  319. InitTR(&pR->tSWST.tCTYC, T_1s*10, WRN_RET_TIME); // CT断线
  320. InitTR(&pR->tSWST.tBatChk, T_1s*3, WRN_RET_TIME); // 电池电压低
  321. InitTR(&pR->tSWST.tBatOver, T_1s*3, WRN_RET_TIME);
  322. InitTR(&pR->tMb_yuk_time, T_1s*5, 0);
  323. InitTR(&pR->tTZZFG_5S0ms, pRunSet->dT_ZZFG, 0); //无故障延时5s
  324. InitTR(&pR->thzbs.tBSHZTime, pSet->dT_hzbs, T_20ms); // 分闸次数过多,闭锁合闸
  325. InitTR(&pR->thzbs.tTw100ms100ms,T_100ms,T_100ms);
  326. for(i=0;i<8;i++)
  327. {
  328. if(pRunSet->bTT_FDLTz[i])
  329. {
  330. InitTR(&pR->tFdl[i].tFdlTime,pRunSet->dTFDL[i], PRO_RET_TIME);
  331. }
  332. else
  333. {
  334. InitTR(&pR->tFdl[i].tFdlTime,pRunSet->dTFDL[i], WRN_RET_TIME);
  335. }
  336. }
  337. fresh_set_soe(EV_TYPE_S, !g_tRelay[sw].run_stu.fa_ls,true,sw);
  338. fresh_set_soe(EV_TYPE_L, g_tRelay[sw].run_stu.fa_ls,true,sw);
  339. //自供电功能投入
  340. {
  341. //bool bll;
  342. //bll=(g_tRelay[sw].run_stu.fa_ls&&pRunSet->tSwSet[sw].bTT_FA&&FA_ALL_EN(sw))
  343. // ||(g_tRelay[sw].tgoc.tllcd.sta.bFlag.bCD&&BH_GOOSE_EN(sw));
  344. //fresh_set_soe(EV_FA_LL_EN,(g_tRelay[sw].tgoc.tllcd.sta.bFlag.bCD&&BH_GOOSE_EN(sw)),true,sw);
  345. }
  346. //soft_yb set
  347. fresh_set_soe(EV_KZ_YB, pRunSet->bTT_KZ_YB, true,sw);
  348. fresh_set_soe(EV_EDIT_YB, pRunSet->bTT_EDIT_YB, true,sw);
  349. #if defined GD_AREA_MAIN_2020 || defined GD_AREA_ECZD_2020
  350. fresh_set_soe(EV_CHZ_YB,CHZ_ALL_EN(sw) , true,sw);//重合闸投入
  351. #else
  352. fresh_set_soe(EV_CHZ_YB,!CHZ_ALL_EN(sw) , true,sw);//停用重合闸
  353. #endif
  354. #ifdef GD_AREA_MAIN_2020
  355. fresh_set_soe(EV_BH_YB, !FUN_ALL_EN(sw), true,sw); //停用保护和FA
  356. #else
  357. fresh_set_soe(EV_BH_YB, FUN_ALL_EN(sw), true,sw);
  358. #endif
  359. #if defined BHFAGS_YB_YK || defined GD_AREA_ZHONGSHAN || defined GD_AREA_ZHONGSHAN_2020 || defined GD_AREA_ECZD_2020
  360. fresh_set_soe(EV_BH_YBTT, BH_ALL_EN(sw), true,sw);
  361. fresh_set_soe(EV_FA_YBTT, FA_ALL_EN(sw), true,sw);
  362. fresh_set_soe(EV_GOOSE_YBTT, BH_GOOSE_EN(sw), true,sw);
  363. #endif
  364. fresh_set_soe(EV_TQ_YBTT,TYTQ_ALL_EN(sw),true,sw);
  365. fresh_set_soe(EV_JL_YBTT,JL_ALL_EN(sw),true,sw);// 自动解列软压板
  366. #ifdef FUNC_DRIVE_JY
  367. InitTR(&gb_drive.tDriveUa1Time,pSet->dT_drive_ua1, 0);
  368. InitTR(&gb_drive.tDriveUa2Time,pSet->dT_drive_ua2, 0);
  369. InitTR(&gb_drive.tDriveU0Time,pSet->dT_drive_u0, 0);
  370. InitTR(&gb_drive.tDriveITime,pSet->dT_drive_i, 0);
  371. InitTR(&gb_drive.tDriveI0Time,pSet->dT_drive_i0, 0);
  372. InitTR(&gb_drive.tDriveAgainTime,pSet->dT_drive_again, 0);
  373. InitTR(&gb_drive.tDriveFaBSTime,T_25ms*2, 0);
  374. #endif
  375. #ifdef FUNC_DRIVE
  376. InitTR(&gb_drive.tQDTime_hz,pRunSet->tSwSet[sw].dT_Drive_hz, 0);
  377. InitTR(&gb_drive.tQDTime_fz,pRunSet->tSwSet[sw].dT_Drive_fz, 0);
  378. InitTR(&gb_drive.tQDTime_fz_end,pRunSet->tSwSet[sw].dT_fz_end, 0);
  379. InitTR(&gb_drive.tQDTime_hz_end,pRunSet->tSwSet[sw].dT_hz_end, 0);
  380. #endif
  381. #ifdef FUNC_REBOOT_BS_HA_JS_3S
  382. InitTR(&pR->tSDHZ.tHW_JS_HA_3STime, T_1s*3, 0);
  383. #endif
  384. }
  385. for(i=0;i<VOL_NUMBER;i++)
  386. {
  387. InitTR(&g_tVol[i].tQDTime,pRunSet->tVolSet[i].dTVol, WRN_RET_TIME);
  388. InitTR(&g_tVol[i].tCYYTime,T_40ms, 0);
  389. InitTR(&g_tVol[i].tWaveYYTime,T_40ms, 0);
  390. }
  391. InitTR(&g_rmt_op.tTULK3STime, T_1s*3, 0);
  392. InitTR(&g_tJLSDTime,pRunSet->dSDYX_T, T_1s*5);
  393. InitTR(&tPT.tTPT1DXTime,T_1s*10, WRN_RET_TIME);
  394. InitTR(&tPT.tTPT2DXTime,T_1s*10, WRN_RET_TIME);
  395. SetTR_TRTT(&tPT.tTPT1DXTime, WRN_RET_TIME);
  396. SetTR_TRTT(&tPT.tTPT2DXTime, WRN_RET_TIME);
  397. InitTR(&tPT.tBatOnTime,T_1s*2, WRN_RET_TIME);
  398. InitTR(&tPT.tTPT1XXYC,T_1s*3, WRN_RET_TIME);
  399. InitTR(&tPT.tTPT2XXYC,T_1s*3, WRN_RET_TIME);
  400. #ifdef IEC_NOLINK_NO_CALLYX
  401. InitTR(&g_link_comm.tLinkBreak,T_1s*60*3, 0);
  402. #endif
  403. #ifdef FUN_JDXX
  404. jdxx_relayinit();
  405. #endif
  406. }
  407. /******************************************************************************
  408. 函数名称: ProtectRelayInit1
  409. 函数版本: 01.01
  410. 创建作者:
  411. 创建日期: 2013-08-08
  412. 函数说明: 在保护巡检时有定值修改,重新初始化与保护相关的定时器,使修改后的延时有效
  413. 参数说明:
  414. 返回值:
  415. 修改记录:
  416. */
  417. void ProtectRelayInit1(void)
  418. {
  419. int sw,i;
  420. for(sw=0;sw<g_sw_num;sw++)
  421. {
  422. TRELAY_T *pR=&g_tRelay[ sw];
  423. TSETSW *pSet = &pRunSet->tSwSet[sw];
  424. int i;
  425. #ifdef CUSTOMIZE_BZT //备自投
  426. BztTimerChange(sw);
  427. #endif
  428. for(i=0;i<BHOC_NUMBER;i++)
  429. {
  430. TOC_T *poc=&pR->tOC[i];
  431. #ifdef YX_RESET_TIME
  432. InitTR(&poc->tTzEvRstTime, tRunPara.dTEventRst, 0); // 遥信复归时间
  433. InitTR(&poc->tGjEvRstTime, tRunPara.dTEventRst, 0); // 遥信复归时间
  434. #endif
  435. InitTR_Time(&poc->tQDTime, pSet->toc[i].dT, PRO_RET_TIME);
  436. InitTR_Time(&poc->tXBTime, pSet->toc[i].dT, PRO_RET_TIME);
  437. InitTR(&poc->tXBQD25ms, T_25ms*2, 0);
  438. if(i>=BH_OVI)
  439. {
  440. InitTR_Time(&poc->tQDTime, pSet->toc[i].dT, WRN_RET_TIME); // 过载及重载,返回时间为1秒
  441. }
  442. }
  443. {
  444. TGOC_T *poc=&pR->tgoc;
  445. GOC_SET *pgset=&pSet->tGocSet;
  446. DWORD dTsytime;
  447. dTsytime=((pgset->dTgzgl>pgset->dTsdlost)?pgset->dTgzgl:pgset->dTsdlost)+T_300ms;
  448. if(pRunSet->bTT_goose_send_after)
  449. {
  450. InitTR_Time(&poc->tTZX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  451. InitTR_Time(&poc->tTFX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  452. InitTR_Time(&poc->tTWX_300ms, pgset->dTgl, pRunSet->dT_sendext); //
  453. InitTR_Time(&poc->tTLX_300ms, pgset->dTlx, pRunSet->dT_sendext); //
  454. }
  455. else
  456. {
  457. InitTR_Time(&poc->tTZX_300ms, T_5ms, pRunSet->dT_sendext); //
  458. InitTR_Time(&poc->tTFX_300ms, T_5ms, pRunSet->dT_sendext); //
  459. InitTR_Time(&poc->tTWX_300ms, T_5ms, pRunSet->dT_sendext); //
  460. InitTR_Time(&poc->tTLX_300ms, T_5ms, pRunSet->dT_sendext); //
  461. }
  462. InitTR_Time(&poc->tTGLBS_300ms, T_5ms, pRunSet->dT_sendext); //
  463. InitTR_Time(&poc->tgoose15ms_gzgl, pRunSet->dT_goosecheck, 0); //
  464. InitTR_Time(&poc->tqccd.tCDTime,pRunSet->dT_cd, 0);
  465. InitTR_Time(&poc->tqccd.tWYTime,pRunSet->dT_glfd, 0);
  466. InitTR_Time(&poc->tglcd.tCDTime,pRunSet->dT_cd, 0);
  467. InitTR_Time(&poc->tglcd.tWYTime,pRunSet->dT_glfd, 0);
  468. if(pRunSet->dT_cd==0)
  469. {
  470. InitTR_Time(&poc->tllcd.tCDTime,T_1s*15, 0);
  471. }
  472. else
  473. {
  474. InitTR_Time(&poc->tllcd.tCDTime,pRunSet->dT_cd, 0);
  475. }
  476. InitTR_Time(&poc->tllcd.tWYTime,pRunSet->dT_llfd, 0);
  477. if(pRunSet->bTT_goose_send_after)
  478. {
  479. InitTR_Time(&poc->tglQDTime, pgset->dTgl+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  480. InitTR_Time(&poc->tlxQDTime, pgset->dTlx+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  481. }
  482. else
  483. {
  484. InitTR_Time(&poc->tglQDTime, ((pgset->dTgl>pRunSet->dT_goosecheck)?pgset->dTgl:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  485. InitTR_Time(&poc->tlxQDTime, ((pgset->dTlx>pRunSet->dT_goosecheck)?pgset->dTlx:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  486. }
  487. InitTR_Time(&poc->tgzglTime, pgset->dTgzgl, 0); //
  488. InitTR_Time(&poc->tsdlostTime, pgset->dTsdlost, 0); //
  489. InitTR_Time(&poc->terrlostTime, pgset->dTgzgl, 0); //
  490. InitTR_Time(&poc->tllhzTime, pgset->dTll, 0); //
  491. InitTR_Time(&poc->tllQdTime, pgset->dTll+((pgset->dTgzgl>pgset->dTsdlost)?pgset->dTgzgl:pgset->dTsdlost)+T_1s, 0); //
  492. InitTR_Time(&poc->tglslowTime, 0,pgset->dTgl+T_1s); //
  493. InitTR_Time(&poc->tlxslowTime, 0,pgset->dTlx+T_1s); //
  494. #if defined GD_AREA_ZHONGSHAN || defined GD_AREA_ZHONGSHAN_2020
  495. if(pRunSet->bTT_goose_send_after)
  496. {
  497. InitTR_Time(&poc->tgl2QDTime, pgset->dTgl2+pRunSet->dT_goosecheck, PRO_RET_TIME); //
  498. InitTR_Time(&poc->tTZX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  499. InitTR_Time(&poc->tTFX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  500. InitTR_Time(&poc->tTWX2_300ms, pgset->dTgl2, pRunSet->dT_sendext); //
  501. }
  502. else
  503. {
  504. InitTR_Time(&poc->tgl2QDTime, ((pgset->dTgl2>pRunSet->dT_goosecheck)?pgset->dTgl2:pRunSet->dT_goosecheck), PRO_RET_TIME); //
  505. InitTR_Time(&poc->tTZX2_300ms, T_5ms, pRunSet->dT_sendext); //
  506. InitTR_Time(&poc->tTFX2_300ms, T_5ms, pRunSet->dT_sendext); //
  507. InitTR_Time(&poc->tTWX2_300ms, T_5ms, pRunSet->dT_sendext); //
  508. }
  509. InitTR_Time(&poc->tglslowTime, 0,pgset->dTgl2+T_1s); //
  510. #endif
  511. InitTR_Time(&poc->tTzcheckTime, pRunSet->dT_TZSB, 0); //开关失灵判断时间
  512. InitTR_Time(&poc->tHzcheckTime, pRunSet->dT_HZSB, 0); //开关失灵判断时间
  513. InitTR_Time(&poc->ttzsbextTime, 0,pRunSet->dT_sendext); // 跳闸失败(开关失灵)展宽时间
  514. InitTR_Time(&poc->tgzglokextTime, 0,pRunSet->dT_sendext); // 发送展宽 300毫秒
  515. InitTR_Time(&poc->tgzglokForbitTime, 0,pRunSet->dT_frobit); //发送故障隔离成功后闭锁时间
  516. InitTR_Time(&poc->tCYY3sdelayms, T_1s*3,dTsytime);
  517. InitTR_Time(&poc->tgoosedelayms_ll, dTsytime+pRunSet->dT_TZSB*2, 0);
  518. InitTR_Time(&poc->textbsTime, 0, pRunSet->dT_sendext+T_100ms);
  519. }
  520. //重合闸
  521. InitTR_Time(&pR->tCHZ.tTCHCD15s0s, pSet->dT_chz_cd,0 ); //充电15秒
  522. InitTR_Time(&pR->tCHZ.tTCHJD_ARDelay, pSet->dT_chz[0],0 ); //重合闸延时
  523. InitTR_Time(&pR->tCHZ.tTCHFAIL_TW, pSet->dT_chz[0]+T_1s, 0 ); //三相跳位延时: 重合失败返回时间
  524. InitTR_Time(&pR->tCHZ.tTCHBSDelay, pSet->dT_chz_bs,0 ); //重合闭锁延时
  525. InitTR_Time(&pR->tCHZ.tTCHOKTime, pSet->dT_chz_ok,0 ); //重合闭锁延时
  526. InitTR_Time(&pR->tCHZ.tTCHJBSTime, 0,pSet->dT_chz_ok ); //重合闭锁时间
  527. #ifdef PRO_UZ_START_REC
  528. InitTR(&pR->tCHZ.tTCH_UO_BS, T_100ms, 0 ); // 零序电压重合闭锁延时
  529. #endif
  530. #ifdef FUN_CHZ_TOPEN
  531. InitTR(&pR->tCHZ.tTCHOPENTime, pSet->dT_chz_Topen, 0 ); //;重合开放时间
  532. #endif
  533. //配网功能定值
  534. InitTR_Time(&pR->tSDHZ.tOnXSTime, pSet->dT_X,0);
  535. InitTR_Time(&pR->tSDHZ.tOnYSTime, pSet->dT_Y,0);
  536. InitTR_Time(&pR->tSDHZ.tOnXLTime, pSet->dT_XL,0);
  537. InitTR_Time(&pR->tSDHZ.tOnYLTime, pSet->dT_Y,0);
  538. #ifdef GD_AREA_ZHONGSHAN_2020
  539. InitTR_Time(&pR->tSDHZ.tOnLLCDYLTime, pSet->dT_LL_CD,0);
  540. #endif
  541. InitTR_Time(&pR->tSDHZ.tOnBSTZTime, pSet->dT_fa_bsTz,0);
  542. InitTR_Time(&pR->tSDHZ.tOnJSTime, pRunSet->dT_ldjs, 0); ////初始化单侧来电解锁计时器
  543. #if defined GD_AREA_ZHONGSHAN_2020 || defined GD_AREA_ECZD_2020 || defined GD_AREA_ZHONGSHAN
  544. #if defined GD_AREA_ECZD_2020
  545. #if defined FUNC_SET_FA_JS
  546. InitTR_Time(&pR->tSDHZ.tOnHW_FA_JSTime, pRunSet->dT_FA_JS, 0);
  547. #elif defined GD_AREA_ECZD_MAOMING
  548. InitTR(&pR->tSDHZ.tOnHW_FA_JSTime, 3*T_1s, 0);
  549. #else
  550. InitTR_Time(&pR->tSDHZ.tOnHW_FA_JSTime, 5*T_10ms, 0);
  551. #endif
  552. #else
  553. InitTR_Time(&pR->tSDHZ.tOnHW_FA_JSTime, T_1s*6, 0);
  554. #endif
  555. #else
  556. InitTR_Time(&pR->tSDHZ.tOnHW_FA_JSTime, T_1s, 0);
  557. #endif
  558. InitTR_Time(&pR->tSDHZ.tOnOCingTime, pSet->dT_fa_ocing,pSet->dT_Y);
  559. InitTR_Time(&pR->tSDHZ.tOnLXingTime, pSet->dT_fa_lxing,pSet->dT_Y);
  560. #ifdef GD_AREA_ZHONGSHAN_2020
  561. InitTR_Time(&pR->tSDHZ.tOnY_JSTime, 0, 0);
  562. #elif defined GD_AREA_ECZD_2020 || defined GD_AREA_ZHONGSHAN
  563. InitTR_Time(&pR->tSDHZ.tOnY_JSTime, T_1s*6, 0);
  564. #else
  565. InitTR_Time(&pR->tSDHZ.tOnY_JSTime, T_1s*3, 0);
  566. #endif
  567. #ifdef FA_OC_COUNT
  568. InitTR_Time(&pR->tSDHZ.tFaOcCountTime, pSet->fa_oc_conut_time, 0);
  569. #endif
  570. #if 0
  571. if(pSet->toc[FA_GL].dT>T_10ms*3)
  572. {
  573. InitTR_Time(&pR->tSDHZ.tGZJYRstGLTime,pSet->toc[FA_GL].dT-T_10ms*3,pSet->dT_Y);
  574. }
  575. else
  576. {
  577. InitTR_Time(&pR->tSDHZ.tGZJYRstGLTime,0,pSet->dT_Y);
  578. }
  579. if(pSet->toc[FA_GL2].dT>T_10ms*3)
  580. InitTR_Time(&pR->tSDHZ.tGZJYRstGL2Time,pSet->toc[FA_GL2].dT-T_10ms*3,pSet->dT_Y);
  581. else
  582. InitTR_Time(&pR->tSDHZ.tGZJYRstGL2Time,0,pSet->dT_Y);
  583. if(pSet->toc[FA_LX].dT>T_10ms*3)
  584. {
  585. InitTR_Time(&pR->tSDHZ.tGZJYRstJDTime,pSet->toc[FA_LX].dT-T_10ms*3,pSet->dT_Y);
  586. }
  587. else
  588. {
  589. InitTR_Time(&pR->tSDHZ.tGZJYRstJDTime,0,pSet->dT_Y);
  590. }
  591. if(pSet->toc[FA_LX2].dT>T_10ms*3)
  592. InitTR_Time(&pR->tSDHZ.tGZJYRstJD2Time,pSet->toc[FA_LX2].dT-T_10ms*3,pSet->dT_Y);
  593. else
  594. InitTR_Time(&pR->tSDHZ.tGZJYRstJD2Time,0,pSet->dT_Y);
  595. #else
  596. if(pSet->toc[FA_GL].dT>T_FA_TZ_MIN_TIME)
  597. InitTR_Time(&pR->tSDHZ.tGZJYRstGLTime,pSet->toc[FA_GL].dT,pSet->dT_Y);
  598. else
  599. InitTR_Time(&pR->tSDHZ.tGZJYRstGLTime,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  600. if(pSet->toc[FA_GL_II].dT>T_FA_TZ_MIN_TIME)
  601. InitTR_Time(&pR->tSDHZ.tGZJYRstGL_II_Time,pSet->toc[FA_GL_II].dT,pSet->dT_Y);
  602. else
  603. InitTR_Time(&pR->tSDHZ.tGZJYRstGL_II_Time,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  604. if(pSet->toc[FA_GL2].dT>T_FA_TZ_MIN_TIME)
  605. InitTR_Time(&pR->tSDHZ.tGZJYRstGL2Time,pSet->toc[FA_GL2].dT,T_20ms);
  606. else
  607. InitTR_Time(&pR->tSDHZ.tGZJYRstGL2Time,T_FA_TZ_MIN_TIME,T_20ms);
  608. if(pSet->toc[FA_LX].dT>T_FA_TZ_MIN_TIME)
  609. InitTR_Time(&pR->tSDHZ.tGZJYRstJDTime,pSet->toc[FA_LX].dT,pSet->dT_Y);
  610. else
  611. InitTR_Time(&pR->tSDHZ.tGZJYRstJDTime,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  612. if(pSet->toc[FA_LX2].dT>T_FA_TZ_MIN_TIME)
  613. InitTR_Time(&pR->tSDHZ.tGZJYRstJD2Time,pSet->toc[FA_LX2].dT,pSet->dT_Y);
  614. else
  615. InitTR_Time(&pR->tSDHZ.tGZJYRstJD2Time,T_FA_TZ_MIN_TIME,pSet->dT_Y);
  616. #endif
  617. InitTR_Time(&pR->tSDHZ.tUABS25ms,pSet->dT_fa_YY, T_25ms*2);
  618. InitTR_Time(&pR->tSDHZ.tUBCS25ms,pSet->dT_fa_YY, T_25ms*2);
  619. InitTR_Time(&pR->tSDHZ.tUABL25ms,pSet->dT_fa_YY, T_25ms*2);
  620. InitTR_Time(&pR->tSDHZ.tUBCL25ms,pSet->dT_fa_YY, T_25ms*2);
  621. InitTR_Time(&pR->tSDHZ.tL_RELAYONL3s, pSet->dT_Y, 0);
  622. InitTR_Time(&pR->tSDHZ.tUFABL80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  623. InitTR_Time(&pR->tSDHZ.tUFBCL80ms,pRunSet->dT_XCY, pSet->dT_Y-T_1s);
  624. InitTR_Time(&pR->tSDHZ.tUFDBTime,pRunSet->dT_XCY, 0);
  625. InitTR_Time(&pR->tSDHZ.tUFABS80ms,pRunSet->dT_XCY, pSet->dT_X);
  626. InitTR_Time(&pR->tSDHZ.tUFBCS80ms,pRunSet->dT_XCY, pSet->dT_X);
  627. InitTR_Time(&pR->tSDHZ.tUFABS25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  628. InitTR_Time(&pR->tSDHZ.tUFBCS25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  629. InitTR_Time(&pR->tSDHZ.tUFABL25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  630. InitTR_Time(&pR->tSDHZ.tUFBCL25ms,T_25ms, pRunSet->dT_XCY+T_1s);
  631. #ifdef FA_PL_PJ
  632. InitTR(&pR->tSDHZ.tFREQAB25ms_SCY,T_25ms*2, T_25ms*2);
  633. InitTR(&pR->tSDHZ.tFREQBC25ms_SCY,T_25ms*2, T_25ms*2);
  634. InitTR(&pR->tSDHZ.tFREQAB25ms_LCY,T_25ms*2, T_25ms*2);
  635. InitTR(&pR->tSDHZ.tFREQBC25ms_LCY,T_25ms*2, T_25ms*2);
  636. InitTR(&pR->tSDHZ.tFREQSAB25ms,T_25ms, T_25ms*2);
  637. InitTR(&pR->tSDHZ.tFREQSBC25ms,T_25ms, T_25ms*2);
  638. InitTR(&pR->tSDHZ.tFREQLAB25ms,T_25ms, T_25ms*2);
  639. InitTR(&pR->tSDHZ.tFREQLBC25ms,T_25ms, T_25ms*2);
  640. #endif
  641. InitTR_Time(&pR->tSDHZ.tHz0ms1s,0,tRunPara.wFAHZT*T_5ms/5+T_1s);
  642. InitTR_Time(&pR->tSDHZ.tTz0ms1s,0,tRunPara.wFAFZT*T_5ms/5+T_1s);
  643. InitTR_Time(&pR->tSDHZ.tHz0ms2s,pRunSet->dT_HZSB,0);
  644. InitTR_Time(&pR->tSDHZ.tTz0ms2s,pRunSet->dT_TZSB,0);
  645. InitTR_Time(&pR->tSDHZ.tTSDHzHJS, 0, pSet->dT_Y); //上电合闸加速判断
  646. InitTR_Time(&pR->tU0TZ.tZOVTime, pSet->dT_OverU0, T_20ms);
  647. InitTR_Time(&pR->tOVER_U0TZ.tZOVTime, pSet->dBHTOverU0, T_20ms);
  648. //解列
  649. InitTR_Time(&pR->tDYJL.tDdyTime, pSet->dT_jl_ddy, T_20ms);
  650. InitTR_Time(&pR->tDYJL.tGdyTime, pSet->dT_jl_gdy, T_20ms);
  651. InitTR_Time(&pR->tDYJL.tHighTime, pSet->dT_jl_ggdy, T_20ms);
  652. InitTR_Time(&pR->tDYJL.tLowTime, pSet->dT_jl_gddy, T_20ms);
  653. InitTR_Time(&pR->tPLJL.tDhzTime, pSet->dT_jl_dhz, T_40ms);
  654. InitTR_Time(&pR->tPLJL.tHighTime, pSet->dT_jl_ghz, T_40ms);
  655. InitTR_Time(&pR->tPLJL.tLowTime, pSet->dT_jl_lowhz, T_40ms);
  656. InitTR_Time(&pR->tLostVot.tLostVotTime, pSet->dT_Z, T_20ms);
  657. InitTR_Time(&pR->tLostVot.tLostVLockTime,0,pSet->dT_fa_bsTz);
  658. InitTR_Time(&pR->tTQHz.tTQTime,pSet->dT_tq,0); //同期
  659. InitTR_Time(&pR->tSWST.tTWCNGJ1s, pRunSet->dWCN_T, WRN_RET_TIME);
  660. InitTR_Time(&pR->tSWST.tTKZHLGJ1s, T_1s*10, WRN_RET_TIME);
  661. InitTR_Time(&pR->tTripfail_2s, pRunSet->dT_TZSB, 0); //跳闸失败时间继电器
  662. InitTR_Time(&pR->tTripfail_hz, 0 , pRunSet->dT_TZSB); //跳闸失败时间继电器
  663. InitTR_Time(&pR->tSWST.tCTXXYC, T_1s*3, WRN_RET_TIME); // CT相序异常
  664. InitTR_Time(&pR->tSWST.tCTYC, T_1s*10, WRN_RET_TIME); // CT断线
  665. InitTR_Time(&pR->tTZZFG_5S0ms, pRunSet->dT_ZZFG, 0); //无故障延时5s
  666. for(i=0;i<8;i++)
  667. {
  668. if(pRunSet->bTT_FDLTz[i])
  669. {
  670. InitTR_Time(&pR->tFdl[i].tFdlTime,pRunSet->dTFDL[i], PRO_RET_TIME);
  671. }
  672. else
  673. {
  674. InitTR_Time(&pR->tFdl[i].tFdlTime,pRunSet->dTFDL[i], WRN_RET_TIME);
  675. }
  676. }
  677. #ifdef FUNC_DRIVE_JY
  678. InitTR(&gb_drive.tDriveUa1Time,pSet->dT_drive_ua1, 0);
  679. InitTR(&gb_drive.tDriveUa2Time,pSet->dT_drive_ua2, 0);
  680. InitTR(&gb_drive.tDriveU0Time,pSet->dT_drive_u0, 0);
  681. InitTR(&gb_drive.tDriveITime,pSet->dT_drive_i, 0);
  682. InitTR(&gb_drive.tDriveI0Time,pSet->dT_drive_i0, 0);
  683. InitTR(&gb_drive.tDriveAgainTime,pSet->dT_drive_again, 0);
  684. InitTR(&gb_drive.tDriveFaBSTime,T_25ms*2, 0);
  685. #endif
  686. #ifdef FUNC_DRIVE
  687. InitTR(&gb_drive.tQDTime_hz,pRunSet->tSwSet[sw].dT_Drive_hz, 0);
  688. InitTR(&gb_drive.tQDTime_fz,pRunSet->tSwSet[sw].dT_Drive_fz, 0);
  689. InitTR(&gb_drive.tQDTime_fz_end,pRunSet->tSwSet[sw].dT_fz_end, 0);
  690. InitTR(&gb_drive.tQDTime_hz_end,pRunSet->tSwSet[sw].dT_hz_end, 0);
  691. #endif
  692. }
  693. for(i=0;i<VOL_NUMBER;i++)
  694. {
  695. InitTR_Time(&g_tVol[i].tQDTime,pRunSet->tVolSet[i].dTVol, WRN_RET_TIME);
  696. }
  697. InitTR_Time(&g_tJLSDTime,pRunSet->dSDYX_T, T_1s*5);
  698. InitTR_Time(&tFAg.tRstTime,pRunSet->dT_sendext*10, 0);
  699. #ifdef FUN_JDXX
  700. jdxx_relayinit();
  701. #endif
  702. }
  703. /**************************************************************************
  704. 函数名称:ValueOverRelay
  705. 函数版本:1.00
  706. 作者: mwd
  707. 创建日期:2007.9.29
  708. 函数功能说明:过量继电器
  709. 输入参数:dI、dIdz 相比较
  710. CONST_FHXISHU: 返回系数,常数
  711. bEN: 1--返回系数有效,0-返回系数无效
  712. 其他输入:
  713. 输出参数?
  714. 返回值:?I>dIdz,返回true ,否则,返回false
  715. ***************************************************************************/
  716. bool OverRelay(DWORD dI,DWORD dIdz,DWORD dfhdz ,bool bEN)
  717. {
  718. if(bEN)
  719. {
  720. if(dI>dfhdz)
  721. {
  722. return (true);
  723. }
  724. else
  725. {
  726. return (false);
  727. }
  728. }
  729. else
  730. {
  731. if(dI>dIdz)
  732. {
  733. return (true);
  734. }
  735. else
  736. {
  737. return (false);
  738. }
  739. }
  740. }
  741. /**************************************************************************
  742. 函数名称:ValueLowRelay
  743. 函数版本:1.00
  744. 作者:
  745. 创建日期:2007.9.29
  746. 函数功能说明:欠量继电器
  747. 输入参数:dI、dIdz 相比较
  748. CONST_FHXISHU: 返回系数,常数
  749. bEN: 1--返回系数有效,0-返回系数无效
  750. 其他输入:
  751. 输出参数?
  752. 返回值:?I>dIdz,返回true ,否则,返回false
  753. ***************************************************************************/
  754. bool LowRelay(DWORD dI,DWORD dIdz,DWORD dfhdz ,bool bEN)
  755. {
  756. if(bEN)
  757. {
  758. if(dI<dfhdz)
  759. {
  760. return (true);
  761. }
  762. else
  763. {
  764. return (false);
  765. }
  766. }
  767. else
  768. {
  769. if(dI<dIdz)
  770. {
  771. return (true);
  772. }
  773. else
  774. {
  775. return (false);
  776. }
  777. }
  778. }
  779. /**************************************************************************
  780. 函数名称:SelectFrom
  781. 函数版本:1.00
  782. 作者: MWD
  783. 创建日期:2007.9.29
  784. 函数功能说明:二选一函数
  785. 输入参数:DWORD A: 待选数
  786. DWORD B: 待选数
  787. bool bSelect
  788. 输出参数:
  789. 返回值: bSelect=0 时,返回 A; bSelect=1 时,返回 B;
  790. **************************************************************************/
  791. DWORD SelectMax(DWORD A, DWORD B, DWORD C)
  792. {
  793. DWORD max;
  794. max=A;
  795. if(B>max)
  796. {
  797. max=B;
  798. }
  799. if(C>max)
  800. {
  801. max=C;
  802. }
  803. return (max);
  804. }
  805. /**************************************************************************
  806. 函数名称:CalcAngSub
  807. 函数版本:1.00
  808. 作者: MWD
  809. 创建日期:2007.9.29
  810. 函数功能说明:计算向量角差,并转换至 0~360之间
  811. 输入参数:long Real1,
  812. long Imag1,
  813. long Imag2,
  814. long Imag2
  815. 输出参数:
  816. 返回值: long 角差;
  817. **************************************************************************/
  818. long CalcAngSub(long Real1, long Imag1, long Real2, long Imag2)
  819. {
  820. long lTmp;
  821. lTmp = _AngPQ(Real1, Imag1)- _AngPQ(Real2,Imag2);
  822. //规格化在0 ~ 360之间
  823. if(lTmp < 0)
  824. {
  825. lTmp += ANGLE_P360;
  826. }
  827. if(lTmp>ANGLE_P180) //转换为-180 ~180
  828. {
  829. lTmp-=ANGLE_P360;
  830. }
  831. return (lTmp);
  832. }
  833. /**************************************************************************
  834. 函数名称:SynJudge
  835. 函数版本:1.00
  836. 作者: 保护组 MWD
  837. 创建日期:2007.10.13
  838. 函数功能说明:同期判别
  839. 输入参数:long ANG1: UX与UA角差
  840. long ANG2: UX与UA角差记忆值
  841. DWORD ANGSET: 同期角度定值
  842. 输出参数:
  843. 返回值: TRUE---同期满足,
  844. FALSE--同期不满足
  845. **************************************************************************/
  846. bool SynJudge(long lANG1,long lANG2,DWORD dANGSET)//同期判别
  847. {
  848. bool bStatus;
  849. long lTemp;
  850. lTemp = lAbs(lANG1 - lANG2);
  851. if( ( (long)dANGSET > lTemp )
  852. ||( lTemp > (ANGLE_P360 - (long)dANGSET)) )
  853. {
  854. bStatus = 1;
  855. }
  856. else
  857. {
  858. bStatus = 0;
  859. }
  860. return( bStatus );
  861. }
  862. /**************************************************************************
  863. 函数名称:PowerDirectionalRelay
  864. 函数版本:1.00
  865. 作者: Chenlei
  866. 创建日期:2007.11.4
  867. 函数功能说明:输入电压、电流和阻抗角定值以及电压门槛定值,判断测量阻抗是否
  868. 落在动作特性区内,并输出动作标志。
  869. 输入参数:Ur -- 电压实部
  870. Ui -- 电压虚部
  871. U -- 电压幅值
  872.      Ir -- 电流实部
  873. Ii -- 电流虚部
  874. I -- 电流幅值
  875. Umk -- 电压门槛
  876. Imk -- 电流门槛
  877. Ang1 -- 灵敏角1
  878. Ang2 -- 灵敏角2
  879. 输出参数:管脚10_动作标志
  880. 返回值: false-不动作;true-动作
  881. **************************************************************************/
  882. bool PowerDirectionalRelay(long Ur,long Ui,DWORD U, long Ir,long Ii,DWORD I, DWORD Umk,DWORD Imk,long sina1,long cosa1,long sina2,long cosa2)
  883. {
  884. bool bDIRB;
  885. long lTemp; //中间变量
  886. long lTemp1; //中间变量
  887. long lTemp2; //中间变量
  888. bDIRB = false;
  889. if (( U > Umk ) && ( I > Imk )) //电压、电流均大于门槛,进行方向判断;否则,返回
  890. {
  891. lTemp1 = _MulFac_S(Ur,( Ir * cosa1 - Ii * sina1 ));
  892. lTemp2 = _MulFac_S(Ui, ( Ii * cosa1 + Ir * sina1 ));
  893. lTemp = lTemp1 + lTemp2;
  894. if ( lTemp > 0 )
  895. {
  896. lTemp1 = _MulFac_S(Ur, ( Ir * cosa2 - Ii * sina2 ));
  897. lTemp2 = _MulFac_S(Ui, ( Ii * cosa2 + Ir * sina2 ));
  898. lTemp = lTemp1 + lTemp2;
  899. if ( lTemp > 0 )
  900. {
  901. bDIRB = true;
  902. }
  903. }
  904. }
  905. return( bDIRB );
  906. }
  907. /******************************end*****************************************/