switch.c 108 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669
  1. /******************************************************************************
  2. 版权所有:
  3. 文件名称: switch.c
  4. 文件版本: 01.01
  5. 创建作者: sunxi
  6. 创建日期: 2013-04-15
  7. 功能说明: DTU核心处理程序以开关为单位,循环处理。
  8. 其它说明:
  9. 修改记录:
  10. */
  11. /*------------------------------- 头文件 --------------------------------------
  12. */
  13. #include "head.h"
  14. #ifdef CPU_FUXI
  15. #include "rt_clib.h"
  16. #include "fourier.h"
  17. #endif
  18. /*------------------------------- 宏定义 --------------------------------------
  19. */
  20. #ifdef CPU_FUXI
  21. #define AUTO_ADJUST_NUM 1 // 自动校准时平均的次数
  22. #else
  23. #define AUTO_ADJUST_NUM 50 // 自动校准时平均的次数
  24. #endif
  25. #define MEA_CAL_NUMBER 5 // 实际测量时平均的次数
  26. //#define MEA_CAL_HARMONIC 14 //(CFG_ADC_DOTS_PER_PERIOD/2) // 谐波计算的次数
  27. /*------------------------------ 全局变量 -------------------------------------
  28. */
  29. int g_sw_init; // SW是否初始化
  30. struct ui g_ui[UI_NUM]; // 电压电流模拟量计算的综合结构
  31. struct ui_jy g_ui_jy[3]; // 方向判断中的记忆电压
  32. struct ui120 Us1_120,Us2_120;
  33. struct ui_p0 g_ui_p0[SWITCH_NUM_MAX]; //零序功率
  34. int g_ui_angle0; // 角度计算时,作为参考电压通道在g_ui中的索引
  35. int g_prot_index; // 保护计算时,采样通道中采样点的索引
  36. struct sw g_sw[SWITCH_NUM_EXT]; // 开关综合结构
  37. struct sw_public g_sw_pub; // 开关公共部分综合结构
  38. int g_mea_cnt = 0; // 测量计数
  39. int g_harmonic_num = 13; // 默认计算13次谐波
  40. // 谐波系数修正
  41. float g_harmonic_factor[CFG_ADC_DOTS_PER_PERIOD/2] =
  42. {
  43. 1.0,1.0,1.0,1.0,1.0,1.0,1.0,1.0,
  44. 1.0,1.0,1.0,1.0,1.0,1.0,1.0,1.0,
  45. };
  46. // 开关开入名称
  47. const s8 * g_sw_di_name[SW_DI_NUM] =
  48. {
  49. "合位开入", // 1
  50. "分位开入",// 2
  51. "隔离刀闸", // 3
  52. "接地刀闸", // 4
  53. #ifdef DISP_DOUBLE_CN
  54. "弹簧未储能", // 5
  55. "弹簧已储能", // 5
  56. #else
  57. "弹簧储能位", // 5
  58. #endif
  59. "气压低", // 6
  60. "HQ开入", // 7
  61. "TQ开入", // 8
  62. "电源侧瞬压", // 9
  63. "负荷侧瞬压", // 10
  64. "手动合闸", // 11
  65. "手动分闸", // 12
  66. //#ifdef GD_AREA_ECZD_2020//2020指导意见使用停用FA及保护
  67. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020//2020指导意见使用停用FA及保护
  68. "停用FA及保护",
  69. #else
  70. "保护总功能投入",
  71. #endif
  72. #ifdef GD_AREA_MAIN_2020
  73. "常规保护压板", //13
  74. "重合闸投入压板", // 14
  75. "馈线自动化压板", // 15
  76. "智能分布式压板", // 16
  77. #elif defined GD_AREA_ECZD_2020 && !defined GD_AREA_ZHONGSHAN_2020
  78. "常规保护压板", //13
  79. "重合闸投入压板", // 14
  80. "常规FA压板", // 15
  81. "智能分布式FA压板", // 16
  82. #else
  83. "常规保护压板", //13
  84. "重合闸投入压板", // 14
  85. "就地FA压板", // 15
  86. "智能FA压板", // 16
  87. #endif
  88. "联络/分段模式", // 17
  89. "开关远方", // 18
  90. "闭锁重合闸", // 19
  91. //#ifdef GD_AREA_ECZD_2020
  92. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020//2020指导意见使用停用FA及保护
  93. "停用同期压板", // 20
  94. #else
  95. "同期压板", // 20
  96. #endif
  97. "控制回路断线", // 21
  98. "脉冲计数1", // 22
  99. "脉冲计数2", // 23
  100. "就地FA闭锁压板",//"开入8",// 31
  101. #ifdef GD_AREA_ECZD_2020//2020指导意见使用停用解列压板
  102. "停用自动解列功能压板",
  103. #elif defined GD_AREA_MAIN_2020
  104. "停用解列功能压板",
  105. #else
  106. "频率电压解列压板",
  107. #endif
  108. #ifdef TYTQ_DI_YB
  109. "停用检同期压板", // 24
  110. #else
  111. "开入1", // 24
  112. #endif
  113. #ifdef JZS_FUNCTION
  114. "集中式投退压板", //
  115. #else
  116. "开入2", // 25
  117. #endif
  118. #ifdef DO_KOUT_CHECK
  119. "开出自检",
  120. #else
  121. "开入3",// 26
  122. #endif
  123. //#ifdef GD_AREA_ZHUHAI_V2
  124. #if defined GD_AREA_ZHUHAI_V2 || defined GD_AREA_JIEYANG || defined GD_AREA_LIAONING_2021
  125. "对侧开关位置",
  126. #else
  127. "开入4",// 27
  128. #endif
  129. "安全自动控制压板",
  130. #ifdef BS_FAL_DI_YB
  131. "闭锁FA联络压板",
  132. #endif
  133. #ifdef CUSTOMIZE_BZT //备自投
  134. "备自投开入",
  135. "#1进线合位开入",
  136. "#1进线分位开入",
  137. "#2进线合位开入",
  138. "#2进线分位开入",
  139. "备自投-合位开入",
  140. "备自投-分位开入",
  141. "闭锁备自投",
  142. "备自投-失压分闸"
  143. #endif
  144. #ifdef GD_AREA_ECZD_QINGYUAN_2022
  145. "保护合闸出口",
  146. "保护跳闸出口",
  147. "遥控/电动合闸",
  148. "遥控/电动分闸",
  149. #endif
  150. };
  151. // 开关开出名称
  152. const s8 * g_sw_do_name[SW_DO_NUM] =
  153. {
  154. "合闸",
  155. "跳闸",
  156. "保护合闸",
  157. "保护分闸",
  158. "遥控合闸",
  159. "遥控分闸",
  160. "瞬压复归",
  161. "瞬压复归1",
  162. "瞬压闭锁",
  163. "储能信号",//"开出11",
  164. "保护动作开出",
  165. #ifdef GD_AREA_CHAOZHOU_CHAOAN_FUYANG
  166. "同期合闸开出-常闭",
  167. "同期合闸开出-常开",
  168. #else
  169. "同期合闸开出",
  170. #endif
  171. #ifdef CUSTOMIZE_BZT //备自投
  172. "备自投-#1进线合闸",
  173. "备自投-#1进线分闸",
  174. "备自投-#2进线合闸",
  175. "备自投-#2进线分闸",
  176. "备自投-分段合闸",
  177. "备自投-分段分闸",
  178. "备自投-进线1失压分闸",
  179. "备自投-进线2失压分闸",
  180. #endif
  181. #if defined GD_AREA_MAIN_2020 || defined SW_FAIL_SINGLE_OUT
  182. "开关失灵",
  183. #endif
  184. #ifdef GD_AREA_YUNAN_LP
  185. "电源消失开出",
  186. #else
  187. "开出14",
  188. #endif
  189. #ifdef GD_AREA_PROTECTOR
  190. "装置异常告警动作",
  191. #endif
  192. };
  193. const s8 * g_sw_led_name[SW_LED_NUM]=
  194. {
  195. "综合合位灯",
  196. "综合分位灯",
  197. "合位灯",
  198. "分位灯",
  199. "过流灯",
  200. "接地灯",
  201. "重合闸灯",
  202. "充电灯",
  203. "闭锁灯",
  204. "XT灯",
  205. "YT灯",
  206. "动作灯",
  207. "重合闭锁灯",
  208. #ifdef DISP_DOUBLE_CN
  209. "未储能灯",
  210. "已储能灯",
  211. #else
  212. "储能灯",
  213. #endif
  214. "联络灯",
  215. "分段灯",
  216. "重合+FA闭锁灯",
  217. #ifdef GD_AREA_MAIN_2020
  218. "常规保护模式灯",
  219. #else
  220. "保护模式灯",
  221. #endif
  222. "就地FA模式灯",
  223. "分布式模式灯",
  224. "X+Y灯",
  225. #ifdef QYD_STATE_LED
  226. "气压低灯",
  227. #endif
  228. #ifdef CHZ_QUIT_LED
  229. "重合闸退出灯",//(硬件压板或软件压板退出灯亮)
  230. #endif
  231. #if defined GD_AREA_GUANGZHOU_FTU || defined GD_AREA_TEST_2020
  232. "故障告警灯",
  233. #elif defined GD_AREA_ZHUHAI_V2
  234. "告警灯",
  235. #endif
  236. #ifdef GD_AREA_ZHUHAI_V2
  237. "通讯异常灯" //珠海局针对的是智能分布式通信异常
  238. #endif
  239. //#ifdef GD_AREA_ECZD_2020
  240. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  241. "自动解列功能灯",
  242. "同期合闸功能灯",
  243. "停用保护及FA灯",
  244. "停用自动解列灯",
  245. "停用同期合闸灯",
  246. #endif
  247. #ifdef TZ_STATE_LED
  248. "跳闸灯",
  249. #endif
  250. #ifdef CHZ_CD_LED
  251. "重合闸充电灯",
  252. #endif
  253. #ifdef EQU_RUN_LED
  254. "装置工作指示灯",
  255. #endif
  256. #ifdef SWITCH_GLJD_LED
  257. "隔离刀闸灯",
  258. "接地刀闸灯",
  259. #endif
  260. #ifdef FUNC_DRIVE
  261. "开关传动灯",
  262. #endif
  263. };
  264. // 开关模拟量名称
  265. //!!!更改模拟量名称可能会对以下宏有影响,请注意
  266. //#define MEA_I_OFFSET 4 //用于判断英文‘I’起始位置
  267. //#define MEA_U_OFFSET 6 //用于判断英文‘U’起始位置
  268. const struct mea_desc g_sw_ac_desc[SW_AC_NUM_ALL] =
  269. {
  270. #ifdef DISP_MEA_CN
  271. {"保护IA",UNIT_A5,UNIT_ANG},
  272. {"保护IB",UNIT_A5,UNIT_ANG},
  273. {"保护IC",UNIT_A5,UNIT_ANG},
  274. {"保护I0",UNIT_A5,UNIT_ANG},
  275. #ifdef SW_AC_I0S_SAMPLE
  276. {"保护I0s",UNIT_A5,UNIT_ANG},
  277. #endif
  278. {"测量IA",UNIT_A5,UNIT_ANG},
  279. {"测量IB",UNIT_A5,UNIT_ANG},
  280. {"测量IC",UNIT_A5,UNIT_ANG},
  281. {"总有功",UNIT_W,UNIT_NULL},
  282. {"A相有功",UNIT_W,UNIT_NULL},
  283. {"B相有功",UNIT_W,UNIT_NULL},
  284. {"C相有功",UNIT_W,UNIT_NULL},
  285. {"总无功",UNIT_Var,UNIT_NULL},
  286. {"A相无功",UNIT_Var,UNIT_NULL},
  287. {"B相无功",UNIT_Var,UNIT_NULL},
  288. {"C相无功",UNIT_Var,UNIT_NULL},
  289. {"功率因素",UNIT_COS,UNIT_NULL},
  290. #else
  291. {"BIA",UNIT_A5,UNIT_ANG},
  292. {"BIB",UNIT_A5,UNIT_ANG},
  293. {"BIC",UNIT_A5,UNIT_ANG},
  294. #ifdef GD_TEST_2021
  295. {"I0",UNIT_I0A,UNIT_ANG},
  296. #else
  297. {"I0",UNIT_A5,UNIT_ANG},
  298. #endif
  299. #ifdef SW_AC_I0S_SAMPLE
  300. {"I0s",UNIT_A5,UNIT_ANG},
  301. #endif
  302. {"CIA",UNIT_A5,UNIT_ANG},
  303. {"CIB",UNIT_A5,UNIT_ANG},
  304. {"CIC",UNIT_A5,UNIT_ANG},
  305. {"P",UNIT_W,UNIT_NULL},
  306. {"Pa",UNIT_W,UNIT_NULL},
  307. {"Pb",UNIT_W,UNIT_NULL},
  308. {"Pc",UNIT_W,UNIT_NULL},
  309. {"Q",UNIT_Var,UNIT_NULL},
  310. {"Qa",UNIT_Var,UNIT_NULL},
  311. {"Qb",UNIT_Var,UNIT_NULL},
  312. {"Qc",UNIT_Var,UNIT_NULL},
  313. #ifdef FUN_YC_POWER_S
  314. {"S",UNIT_Var,UNIT_NULL},
  315. #endif
  316. {"COS",UNIT_COS,UNIT_NULL},
  317. #endif
  318. {"BI_UNB",UNIT_Per,UNIT_NULL},
  319. {"CI_UNB",UNIT_Per,UNIT_NULL},
  320. {"脉冲计数1",UNIT_GE,UNIT_NULL},
  321. {"脉冲计数2",UNIT_GE,UNIT_NULL},
  322. {"速断电流定值",UNIT_NULL,UNIT_NULL},
  323. {"速断保护时间",UNIT_NULL,UNIT_NULL},
  324. {"过流电流定值",UNIT_NULL,UNIT_NULL},
  325. {"过流保护时间",UNIT_NULL,UNIT_NULL},
  326. {"零序电流定值",UNIT_NULL,UNIT_NULL},
  327. {"零序保护时间",UNIT_NULL,UNIT_NULL},
  328. {"零序保护模式",UNIT_NULL,UNIT_NULL},
  329. {"一次重合闸时间",UNIT_NULL,UNIT_NULL},
  330. {"二次重合闸时间",UNIT_NULL,UNIT_NULL},
  331. {"得电闭合时间",UNIT_NULL,UNIT_NULL},
  332. {"无压分闸闭锁时间",UNIT_NULL,UNIT_NULL},
  333. {"工作模式",UNIT_NULL,UNIT_NULL},
  334. #ifdef METERING_ENERGY
  335. {"计量UAB",UNIT_V220,UNIT_NULL}, // yc 17
  336. {"计量UBC",UNIT_V220,UNIT_NULL},
  337. {"计量UCA",UNIT_V220,UNIT_NULL},
  338. {"计量UA",UNIT_V220,UNIT_NULL},
  339. {"计量UB",UNIT_V220,UNIT_NULL},
  340. {"计量UC",UNIT_V220,UNIT_NULL},
  341. {"计量IA",UNIT_A5,UNIT_NULL},
  342. {"计量IB",UNIT_A5,UNIT_NULL},
  343. {"计量IC",UNIT_A5,UNIT_NULL},
  344. {"计量I0",UNIT_A5,UNIT_NULL},
  345. {"计量有功功率",UNIT_W,UNIT_NULL},
  346. {"计量A相有功功率",UNIT_W,UNIT_NULL},
  347. {"计量B相有功功率",UNIT_W,UNIT_NULL},
  348. {"计量C相有功功率",UNIT_W,UNIT_NULL},
  349. {"计量无功功率",UNIT_Var,UNIT_NULL},
  350. {"计量A相无功功率",UNIT_Var,UNIT_NULL},
  351. {"计量B相无功功率",UNIT_Var,UNIT_NULL},
  352. {"计量C相无功功率",UNIT_Var,UNIT_NULL},
  353. {"计量视在功率",UNIT_Var,UNIT_NULL},
  354. {"计量A相视在功率",UNIT_Var,UNIT_NULL},
  355. {"计量B相视在功率",UNIT_Var,UNIT_NULL},
  356. {"计量C相视在功率",UNIT_Var,UNIT_NULL},
  357. {"计量功率因数",UNIT_COS,UNIT_NULL},
  358. {"计量A相功率因数",UNIT_COS,UNIT_NULL},
  359. {"计量B相功率因数",UNIT_COS,UNIT_NULL},
  360. {"计量C相功率因数",UNIT_COS,UNIT_NULL},
  361. {"计量频率",UNIT_Hz,UNIT_NULL},
  362. #else
  363. {"YC1",UNIT_NULL,UNIT_NULL}, // yc 17
  364. {"YC2",UNIT_NULL,UNIT_NULL},
  365. {"YC3",UNIT_NULL,UNIT_NULL},
  366. {"YC4",UNIT_NULL,UNIT_NULL},
  367. {"YC5",UNIT_NULL,UNIT_NULL},
  368. {"YC6",UNIT_NULL,UNIT_NULL},
  369. {"YC7",UNIT_NULL,UNIT_NULL},
  370. {"YC8",UNIT_NULL,UNIT_NULL},
  371. {"YC9",UNIT_NULL,UNIT_NULL},
  372. {"YC10",UNIT_NULL,UNIT_NULL},
  373. {"YC11",UNIT_NULL,UNIT_NULL},
  374. {"YC12",UNIT_NULL,UNIT_NULL},
  375. #endif
  376. };
  377. // 计量模块电度值
  378. const struct mea_desc g_dd_desc[SW_DD_NUM_ALL]=
  379. {
  380. {"当前正向有功", UNIT_kWh,UNIT_NULL}, //6401
  381. {"当前正向无功", UNIT_kVarh,UNIT_NULL}, //6402
  382. {"当前一象限无功", UNIT_kVarh,UNIT_NULL}, //6403
  383. {"当前四象限无功", UNIT_kVarh,UNIT_NULL}, //6404
  384. {"当前反向有功", UNIT_kWh,UNIT_NULL}, //6405
  385. {"当前反向无功", UNIT_kVarh,UNIT_NULL}, //6406
  386. {"当前二象限无功", UNIT_kVarh,UNIT_NULL}, //6407
  387. {"当前三象限无功", UNIT_kVarh,UNIT_NULL}, //6408
  388. {"15分冻结正向有功", UNIT_kWh,UNIT_NULL}, //6409
  389. {"15分冻结正向无功", UNIT_kVarh,UNIT_NULL}, //640A
  390. {"15分冻结一象限无功", UNIT_kVarh,UNIT_NULL}, //640B
  391. {"15分冻结四象限无功", UNIT_kVarh,UNIT_NULL}, //640C
  392. {"15分冻结反向有功", UNIT_kWh,UNIT_NULL}, //640D
  393. {"15分冻结反向无功", UNIT_kVarh,UNIT_NULL}, //640E
  394. {"15分冻结二象限无功", UNIT_kVarh,UNIT_NULL}, //640F
  395. {"15分冻结三象限无功", UNIT_kVarh,UNIT_NULL}, //6410
  396. {"日冻结正向有功", UNIT_kWh,UNIT_NULL}, //6411
  397. {"日冻结冻结正向无功", UNIT_kVarh,UNIT_NULL}, //6412
  398. {"日冻结一象限无功", UNIT_kVarh,UNIT_NULL}, //6413
  399. {"日冻结四象限无功", UNIT_kVarh,UNIT_NULL}, //6414
  400. {"日冻结反向有功", UNIT_kWh,UNIT_NULL}, //6415
  401. {"日冻结反向无功", UNIT_kVarh,UNIT_NULL}, //6416
  402. {"日冻结二象限无功", UNIT_kVarh,UNIT_NULL}, //6417
  403. {"日冻结三象限无功", UNIT_kVarh,UNIT_NULL}, //6418
  404. {"潮变冻结正向有功", UNIT_kWh,UNIT_NULL}, //6419
  405. {"潮变冻结正向无功", UNIT_kVarh,UNIT_NULL}, //641A
  406. {"潮变冻结一象限无功", UNIT_kVarh,UNIT_NULL}, //641B
  407. {"潮变冻结四象限无功", UNIT_kVarh,UNIT_NULL}, //641C
  408. {"潮变冻结反向有功", UNIT_kWh,UNIT_NULL}, //641D
  409. {"潮变冻结反向无功", UNIT_kVarh,UNIT_NULL}, //641E
  410. {"潮变冻结二象限无功", UNIT_kVarh,UNIT_NULL}, //641F
  411. {"潮变冻结三象限无功", UNIT_kVarh,UNIT_NULL}, //6420
  412. #ifdef METERING_ENERGY
  413. {"当前A相有功", UNIT_kWh, UNIT_NULL},
  414. {"当前B相有功", UNIT_kWh, UNIT_NULL},
  415. {"当前C相有功", UNIT_kWh, UNIT_NULL},
  416. {"当前A相正向有功", UNIT_kWh, UNIT_NULL},
  417. {"当前B相正向有功", UNIT_kWh, UNIT_NULL},
  418. {"当前C相正向有功", UNIT_kWh, UNIT_NULL},
  419. {"当前A相反向有功", UNIT_kWh, UNIT_NULL},
  420. {"当前B相反向有功", UNIT_kWh, UNIT_NULL},
  421. {"当前C相反向有功", UNIT_kWh, UNIT_NULL},
  422. {"当前总有功", UNIT_kWh, UNIT_NULL},
  423. {"当前总无功", UNIT_kWh, UNIT_NULL},
  424. #endif
  425. };
  426. // 开关公共开入名称
  427. const s8 * g_pub_di_name[PUB_DI_NUM] =
  428. {
  429. "远方", // 1
  430. "就地", // 2
  431. "柜门位置", // 3
  432. "信号复归", // 4
  433. "交流失电告警", // 5
  434. "电池电源故障", // 6
  435. "电池欠压", // 7
  436. "电池活化状态", // 8
  437. "电容器动作", // 9
  438. "FA解锁", // 10
  439. "装置复位", // 11
  440. "功能总压板", // 12
  441. //#ifdef GD_AREA_ECZD_2020
  442. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  443. "检修状态压板", // 13
  444. #else
  445. "遥信屏蔽压板", // 13
  446. #endif
  447. "非电量1开入", // 14
  448. "非电量2开入", // 15
  449. "非电量3开入", // 16
  450. "非电量4开入", // 17
  451. "非电量5开入", // 18
  452. "非电量6开入", // 19
  453. "非电量7开入", // 20
  454. "非电量8开入", // 21
  455. "开入1", // 22
  456. "开入2", // 23
  457. "开入3", // 24
  458. "开入4", // 25
  459. "开入5", // 26
  460. "开入6", // 27
  461. #ifdef YX_DI_ERROR
  462. "遥信自检",
  463. #else
  464. "开入7", // 28
  465. #endif
  466. #ifdef KZ_OUT_TT
  467. "控制出口压板",
  468. #else
  469. "开入8", // 29
  470. #endif
  471. "信号复归+FA解锁", // 30
  472. };
  473. // 开关公共开出名称
  474. const s8 * g_pub_do_name[PUB_DO_NUM] =
  475. {
  476. "电池活化",
  477. "活化退出",
  478. "开出03",
  479. "开出04",
  480. "开出05",
  481. "开出06",
  482. "开出07",
  483. "开出08",
  484. "开出09",
  485. #ifdef YK_ZZDY_KC
  486. "装置电源开出",
  487. #endif
  488. "电压合格率清零",
  489. "预控开出",
  490. "解除闭锁",
  491. "远方重启",
  492. "远方复归",
  493. #ifdef YK_FG_FAJS
  494. "远方复归&FA解锁", // 远方复归+FA解锁
  495. #endif
  496. "重合软压板合",
  497. "重合软压板分",
  498. #if defined BHFA_YB_YK || defined BHFAGS_YB_YK
  499. //#ifdef GD_AREA_ECZD_2020
  500. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  501. "停用保护总软压板合",
  502. "停用保护总软压板分",
  503. #else
  504. "功能总投入软压板合",
  505. "功能总投入软压板分",
  506. #endif
  507. "保护出口软压板合",
  508. "保护出口软压板分",
  509. #ifndef BH_FA_INONE_SW
  510. "常规保护软压板合",
  511. "常规保护软压板分",
  512. "馈线自动化软压板合",
  513. "馈线自动化软压板分",
  514. #ifdef BHFAGS_YB_YK
  515. "智能分布式软压板合",
  516. "智能分布式软压板分",
  517. #endif
  518. #endif
  519. #else
  520. //#ifdef GD_AREA_ECZD_2020
  521. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  522. "停用保护总软压板合",
  523. "停用保护总软压板分",
  524. #else
  525. "自动功能软压板合",
  526. "自动功能软压板分",
  527. #endif
  528. "保护投入软压板合",
  529. "保护投入软压板分",
  530. #endif
  531. #ifdef TQ_SOFT_YB
  532. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  533. "停用同期软压板合",
  534. "停用同期软压板分",
  535. #else
  536. "检同期软压板合",
  537. "检同期软压板分",
  538. #endif
  539. #endif
  540. #ifdef JZS_FUNCTION
  541. "集中式软压板-合",
  542. "集中式软压板-分",
  543. #endif
  544. #ifdef YK_SOFT_YB
  545. "遥控软压板-合",
  546. "遥控软压板-分",
  547. #endif
  548. #ifdef YK_FA_ENBLE
  549. "FA遥控闭锁-合",
  550. "FA遥控闭锁-分",
  551. #endif
  552. #ifdef YK_FA_S_L_ENBLE
  553. "分段/联络-合",
  554. "分段/联络-分",
  555. #endif
  556. #ifdef JL_SOFT_YB
  557. "停用解列软压板合",
  558. "停用解列软压板分",
  559. #endif
  560. #ifdef METERING_ENERGY
  561. "遥控电度清零",
  562. "遥控线损事件清零",
  563. #endif
  564. #ifdef FUNC_DRIVE
  565. "传动接收软压板合",
  566. "传动接收软压板分",
  567. "传动指令",
  568. #endif
  569. #ifdef FUNC_DRIVE_JY
  570. "不停电传动功能",
  571. #endif
  572. #ifdef FUNC_RESET_EQU
  573. "重启装置",
  574. #endif
  575. };
  576. const s8 * g_pub_led_name[PUB_LED_NUM]=
  577. {
  578. "电源灯",
  579. "运行灯",
  580. #ifdef COMM_STATUS_LED
  581. "通信数据灯",
  582. "通信状态灯",
  583. #else
  584. "通信灯",
  585. #endif
  586. "电池灯",
  587. "异常灯",
  588. //#ifdef GD_AREA_ECZD_2020
  589. #if defined GD_AREA_ECZD_2020 || defined GD_AREA_MAIN_2020
  590. "运行告警灯",
  591. #endif
  592. "动作灯",
  593. "远方灯",
  594. "就地灯",
  595. "232T1",
  596. "232R1",
  597. "232T2",
  598. "232R2",
  599. "232T3",
  600. "232R3",
  601. "485T1",
  602. "485R1",
  603. "485T2",
  604. "485R2",
  605. "485T3",
  606. "485R3",
  607. "网口1",
  608. "网口2",
  609. #if defined __GOOSE_USING_DOUBLE_ETH__ || defined NET3_IP5
  610. "网口3",
  611. #endif
  612. #ifdef BAT_STATE_LED
  613. "电池欠压灯",
  614. "电池活化灯",
  615. #endif
  616. #ifdef KZ_OUT_TT
  617. "控制闭锁灯",
  618. #endif
  619. #ifdef IEC_ERR_LED
  620. "规约通信异常灯",
  621. #endif
  622. #ifdef LINK_ERR_LED
  623. "级联异常灯",
  624. #endif
  625. };
  626. // 开关公共模拟量名称
  627. const struct mea_desc g_pub_ac_desc[PUB_AC_NUM_ALL] =
  628. {
  629. #ifdef DISP_MEA_CN
  630. #ifdef GD_AREA_ZHUHAI_V2
  631. {"电缆UA1",UNIT_V100,UNIT_ANG},
  632. {"电缆UB1",UNIT_V100,UNIT_ANG},
  633. {"电缆UC1",UNIT_V100,UNIT_ANG},
  634. {"电缆UAB1",UNIT_V100,UNIT_ANG},
  635. {"电缆UBC1",UNIT_V100,UNIT_ANG},
  636. {"电缆UCA1",UNIT_V100,UNIT_ANG},
  637. {"母线U0 ",UNIT_V100,UNIT_ANG},
  638. {"电缆US1",UNIT_V220,UNIT_ANG},
  639. {"母线UA2",UNIT_V100,UNIT_ANG},
  640. {"母线UB2",UNIT_V100,UNIT_ANG},
  641. {"母线UC2",UNIT_V100,UNIT_ANG},
  642. {"母线UAB2",UNIT_V100,UNIT_ANG},
  643. {"母线UBC2",UNIT_V100,UNIT_ANG},
  644. {"母线UCA2",UNIT_V100,UNIT_ANG},
  645. {"电缆U0 ",UNIT_V100,UNIT_ANG},
  646. {"母线US2",UNIT_V220,UNIT_ANG},
  647. #else
  648. {"母线UA1",UNIT_V100,UNIT_ANG},
  649. {"母线UB1",UNIT_V100,UNIT_ANG},
  650. {"母线UC1",UNIT_V100,UNIT_ANG},
  651. {"母线UAB1",UNIT_V100,UNIT_ANG},
  652. {"母线UBC1",UNIT_V100,UNIT_ANG},
  653. {"母线UCA1",UNIT_V100,UNIT_ANG},
  654. {"母线U01",UNIT_V100,UNIT_ANG},
  655. #ifdef GD_AREA_HUIZHOU_HUIDONG
  656. {"母线AB3",UNIT_V220,UNIT_ANG},
  657. #else
  658. {"母线US1",UNIT_V220,UNIT_ANG},
  659. #endif
  660. {"线路UA2",UNIT_V100,UNIT_ANG},
  661. {"线路UB2",UNIT_V100,UNIT_ANG},
  662. {"线路UC2",UNIT_V100,UNIT_ANG},
  663. {"线路UAB2",UNIT_V100,UNIT_ANG},
  664. {"线路UBC2",UNIT_V100,UNIT_ANG},
  665. {"线路UCA2",UNIT_V100,UNIT_ANG},
  666. {"线路U02",UNIT_V100,UNIT_ANG},
  667. #ifdef GD_AREA_HUIZHOU_HUIDONG
  668. {"母线BC3",UNIT_V220,UNIT_ANG},
  669. #else
  670. {"线路US2",UNIT_V220,UNIT_ANG},
  671. #endif
  672. #endif
  673. {"V_UNB1",UNIT_Per,UNIT_NULL},
  674. {"V_UNB2",UNIT_Per,UNIT_NULL},
  675. {"工频1",UNIT_Hz,UNIT_NULL},
  676. {"工频2",UNIT_Hz,UNIT_NULL},
  677. #else
  678. {"UA1",UNIT_V100,UNIT_ANG},
  679. {"UB1",UNIT_V100,UNIT_ANG},
  680. {"UC1",UNIT_V100,UNIT_ANG},
  681. {"UAB1",UNIT_V100,UNIT_ANG},
  682. {"UBC1",UNIT_V100,UNIT_ANG},
  683. {"UCA1",UNIT_V100,UNIT_ANG},
  684. {"U01",UNIT_V100,UNIT_ANG},
  685. {"US1",UNIT_V220,UNIT_ANG},
  686. {"UA2",UNIT_V100,UNIT_ANG},
  687. {"UB2",UNIT_V100,UNIT_ANG},
  688. {"UC2",UNIT_V100,UNIT_ANG},
  689. {"UAB2",UNIT_V100,UNIT_ANG},
  690. {"UBC2",UNIT_V100,UNIT_ANG},
  691. {"UCA2",UNIT_V100,UNIT_ANG},
  692. {"U02",UNIT_V100,UNIT_ANG},
  693. {"US2",UNIT_V220,UNIT_ANG},
  694. {"V_UNB1",UNIT_Per,UNIT_NULL},
  695. {"V_UNB2",UNIT_Per,UNIT_NULL},
  696. {"UF1",UNIT_Hz,UNIT_NULL},
  697. {"UF2",UNIT_Hz,UNIT_NULL},
  698. #endif
  699. {"直流电压1",UNIT_V050,UNIT_NULL},
  700. {"直流电压2",UNIT_V050,UNIT_NULL},
  701. #ifdef GD_AREA_YUNAN_LP // 云南涞浦
  702. {"DltUab",UNIT_V100,UNIT_NULL},
  703. {"DltUbc",UNIT_V100,UNIT_NULL},
  704. {"DltUca",UNIT_V100,UNIT_NULL},
  705. {"ArgUab",UNIT_ANG,UNIT_NULL},
  706. {"ArgUbc",UNIT_ANG,UNIT_NULL},
  707. {"ArgUca",UNIT_ANG,UNIT_NULL},
  708. #endif
  709. {"温度",UNIT_TEMP,UNIT_NULL},
  710. {"Ver",UNIT_NULL,UNIT_NULL},
  711. #ifdef BATTERY_WITH_COMM
  712. {"活化放电时长",UINT_Hour,UNIT_NULL},
  713. {"当前放电时长",UINT_Hour,UNIT_NULL},
  714. #endif
  715. #ifdef DEV_GPS_ATGM332D
  716. #ifndef GPS_JWD_SPLIT
  717. {"经度",UNIT_ANG,UNIT_NULL},
  718. {"纬度",UNIT_ANG,UNIT_NULL},
  719. #else
  720. {"经度-度",UNIT_ANG,UNIT_NULL},
  721. {"纬度-分",UNIT_ANG,UNIT_NULL},
  722. {"经度-秒",UNIT_ANG,UNIT_NULL},
  723. {"纬度-度",UNIT_ANG,UNIT_NULL},
  724. {"纬度-分",UNIT_ANG,UNIT_NULL},
  725. {"纬度-秒",UNIT_ANG,UNIT_NULL},
  726. #endif
  727. {"卫星个数",UNIT_GE,UNIT_NULL},
  728. #endif
  729. {"YC1",UNIT_NULL,UNIT_NULL},
  730. {"YC2",UNIT_NULL,UNIT_NULL},
  731. {"YC3",UNIT_NULL,UNIT_NULL},
  732. {"YC4",UNIT_NULL,UNIT_NULL},
  733. {"YC5",UNIT_NULL,UNIT_NULL},
  734. {"YC6",UNIT_NULL,UNIT_NULL},
  735. {"YC7",UNIT_NULL,UNIT_NULL},
  736. {"YC8",UNIT_NULL,UNIT_NULL},
  737. #ifdef FUNC_SEND_FAULT_CURRENT
  738. {"A相故障电流",UNIT_A5,UNIT_ANG},
  739. {"B相故障电流",UNIT_A5,UNIT_ANG},
  740. {"C相故障电流",UNIT_A5,UNIT_ANG},
  741. {"零序电流",UNIT_A5,UNIT_ANG},
  742. #else
  743. {"YC9",UNIT_NULL,UNIT_NULL},
  744. {"YC10",UNIT_NULL,UNIT_NULL},
  745. {"YC11",UNIT_NULL,UNIT_NULL},
  746. {"YC12",UNIT_NULL,UNIT_NULL},
  747. #endif
  748. #ifdef BATTERY_BP_L500
  749. {"电池内阻",UINT_mVperA,UNIT_NULL},
  750. {"电池温度",UNIT_TEMP,UNIT_NULL},
  751. {"电池实时电量",UNIT_Per,UNIT_NULL},
  752. {"电池放电电流",UINT_mA,UNIT_NULL},
  753. {"电池充电电流",UINT_mA,UNIT_NULL},
  754. #endif
  755. };
  756. /*------------------------------ 函数声明 -------------------------------------
  757. */
  758. int _sw_cal_mea(void);
  759. void _sw_cal_average(int cal_num);
  760. float _sw_ui_e_k(int index);
  761. void _sw_auto_adjust_pq(void);
  762. void _sw_get_dots(void);
  763. void _sw_cal_fft(void);
  764. void _sw_cal_effect(void);
  765. void _sw_cal_angle(void);
  766. void _sw_cal_ri_correct(void);
  767. void _sw_min_max(int ui_index,u32 *p_min,u32*p_max);
  768. void _fz_min_max(int ui_index1,int ui_index2,u32 *p_min,u32*p_max);
  769. float _sw_base_angle(int ui_index);
  770. int _sw_save_dc_factor(float dc1_H, float dc1_L,float dc2_H, float dc2_L);
  771. void _sw_temp_factor(void);
  772. /*------------------------------ 外部函数 -------------------------------------
  773. 外部函数供其它实体文件引用,必须仔细检查传入参数的合法性.
  774. */
  775. /******************************************************************************
  776. 函数名称: sw_init
  777. 函数版本: 01.01
  778. 创建作者: sunxi
  779. 创建日期: 2013-08-07
  780. 函数说明: 线路开关初始化
  781. 参数说明:
  782. 返回值:
  783. 0: 成功
  784. 其它: 失败
  785. 修改记录:
  786. */
  787. int sw_init(void)
  788. {
  789. int sw,i,type,ui;
  790. float f;
  791. // 初始化为固定默认值,只有上电初始化才运行一次
  792. if(g_sw_init == 0)
  793. {
  794. memset(&g_ui,0,sizeof(g_ui));
  795. memset(&g_sw_pub,0,sizeof(g_sw_pub));
  796. memset(&g_sw_pub.di,SW_DI_TYPE_OFF,sizeof(g_sw_pub.di));
  797. memset(&g_sw_pub.di_cfg_index,INDEX_INVALLID,sizeof(g_sw_pub.di_cfg_index));
  798. memset(&g_sw_pub.do_cfg_index,INDEX_INVALLID,sizeof(g_sw_pub.do_cfg_index));
  799. memset(&g_sw_pub.ac_cfg_index,INDEX_INVALLID,sizeof(g_sw_pub.ac_cfg_index));
  800. memset(&g_sw_pub.led_cfg_index,INDEX_INVALLID,sizeof(g_sw_pub.led_cfg_index));
  801. for(i=0; i< UI_NUM; i++)
  802. {
  803. g_ui[i].chn_index = CFG_ADC_CHANNEL_ZERO;
  804. g_ui[i].ui_base_make = -1;
  805. g_ui[i].e_factor0 = 1.0 ;
  806. // 使用理论默认值初始化m2_factor_k,防止初始化时使用此值的定值出错,
  807. // 导致保护逻辑出错(例如,跳位有流告警)
  808. if(i<PUB_AC_NUM)
  809. {
  810. g_ui[i].m2_factor_k = rt_round(factor_e_k(EQU_SCALE_PT_DEFAULT)*Q08_BASE);
  811. }
  812. else
  813. {
  814. g_ui[i].m2_factor_k = rt_round(factor_e_k(EQU_SCALE_CT_DEFAULT)*Q08_BASE);
  815. }
  816. g_ui[i].m2_factor_c = rt_round(1.0*Q16_BASE);
  817. }
  818. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  819. {
  820. memset(&g_sw[sw],0,sizeof(g_sw[i]));
  821. memset(&g_sw[sw].di,SW_DI_TYPE_OFF,sizeof(g_sw[sw].di));
  822. memset(&g_sw[sw].di_cfg_index,INDEX_INVALLID,sizeof(g_sw[sw].di_cfg_index));
  823. memset(&g_sw[sw].do_cfg_index,INDEX_INVALLID,sizeof(g_sw[sw].do_cfg_index));
  824. memset(&g_sw[sw].ac_cfg_index,INDEX_INVALLID,sizeof(g_sw[sw].ac_cfg_index));
  825. memset(&g_sw[sw].led_cfg_index,INDEX_INVALLID,sizeof(g_sw[sw].led_cfg_index));
  826. }
  827. }
  828. g_sw_init = 0;
  829. // 检查装置配置
  830. if(equ_config_null())
  831. {
  832. return -1;
  833. }
  834. // DI通道
  835. for(i=0; i< g_equ_config->di_num; i++)
  836. {
  837. if(g_equ_config_di[i].owner > SWITCH_NUM_MAX)
  838. {
  839. rt_printf("switch_init(own):i=%d,owner=%d,SWITCH_NUM_MAX=%d.\r\n",i, g_equ_config_di[i].owner,SWITCH_NUM_MAX);
  840. continue;
  841. }
  842. // 如果是其它类型(type == 0),不处理
  843. type = g_equ_config_di[i].type;
  844. if(type == 0)
  845. {
  846. continue;
  847. }
  848. type--;
  849. if(g_equ_config_di[i].owner == 0)
  850. {
  851. if(type < PUB_DI_NUM)
  852. {
  853. g_sw_pub.di_cfg_index[type] = i;
  854. }
  855. else
  856. {
  857. rt_printf("switch_init(di):i=%d,type=%d,DI_NUM=%d.\r\n",i, type,PUB_DI_NUM);
  858. }
  859. }
  860. else
  861. {
  862. sw = g_equ_config_di[i].owner - 1;
  863. if(type < SW_DI_NUM)
  864. {
  865. g_sw[sw].di_cfg_index[type] = i;
  866. }
  867. else
  868. {
  869. rt_printf("switch_init(di):i=%d,type=%d,DI_NUM=%d,sw=%d.\r\n",i, type,SW_DI_NUM,sw);
  870. }
  871. }
  872. }
  873. // DO通道
  874. for(i=0; i< g_equ_config->do_num; i++)
  875. {
  876. if(g_equ_config_do[i].owner > SWITCH_NUM_MAX)
  877. {
  878. rt_printf("switch_init(own):i=%d,owner=%d,SWITCH_NUM_MAX=%d.\r\n",i, g_equ_config_do[i].owner,SWITCH_NUM_MAX);
  879. continue;
  880. }
  881. // 如果是其它类型(type == 0),不处理
  882. type = g_equ_config_do[i].type;
  883. if(type == 0)
  884. {
  885. continue;
  886. }
  887. type--;
  888. if(g_equ_config_do[i].owner == 0)
  889. {
  890. if(type < PUB_DO_NUM)
  891. {
  892. g_sw_pub.do_cfg_index[type] = i;
  893. }
  894. else if(type < PUB_DO_NUM + PUB_LED_NUM)
  895. {
  896. s16 slot,index;
  897. g_sw_pub.led_cfg_index[type-PUB_DO_NUM] = i;
  898. slot = g_equ_config_do[i].slot;
  899. index = g_equ_config_do[i].index;
  900. g_led_slot[slot].sn[index].sw = 0;
  901. g_led_slot[slot].sn[index].no = type-PUB_DO_NUM;
  902. index++;
  903. if(index > g_led_slot[slot].num)
  904. {
  905. g_led_slot[slot].num = index;
  906. }
  907. }
  908. else
  909. {
  910. rt_printf("switch_init(do):i=%d,type=%d,PUB_DO_NUM + PUB_LED_NUM=%d.\r\n",i, type,PUB_DO_NUM + PUB_LED_NUM);
  911. }
  912. }
  913. else
  914. {
  915. sw = g_equ_config_do[i].owner - 1;
  916. if(type < SW_DO_NUM)
  917. {
  918. g_sw[sw].do_cfg_index[type] = i;
  919. }
  920. else if(type < SW_DO_LED_NUM)
  921. {
  922. s16 slot,index;
  923. g_sw[sw].led_cfg_index[type-SW_DO_NUM] = i;
  924. slot = g_equ_config_do[i].slot;
  925. index = g_equ_config_do[i].index;
  926. g_led_slot[slot].sn[index].sw = sw+1;
  927. g_led_slot[slot].sn[index].no = type-SW_DO_NUM;
  928. index++;
  929. if(index > g_led_slot[slot].num)
  930. {
  931. g_led_slot[slot].num = index;
  932. }
  933. }
  934. else
  935. {
  936. rt_printf("switch_init(do):i=%d,type=%d,SW_DO_LED_NUM=%d,sw=%d.\r\n",i, type,SW_DO_LED_NUM,sw);
  937. }
  938. }
  939. }
  940. // AC通道
  941. for(i=0; i< g_equ_config->ac_num; i++)
  942. {
  943. if(g_equ_config_ac[i].owner > SWITCH_NUM_MAX)
  944. {
  945. rt_printf("switch_init(own):i=%d,owner=%d,SWITCH_NUM_MAX=%d.\r\n",i, g_equ_config_ac[i].owner,SWITCH_NUM_MAX);
  946. continue;
  947. }
  948. // 如果是其它类型(type == 0),不处理
  949. type = g_equ_config_ac[i].type;
  950. if(type == 0)
  951. {
  952. continue;
  953. }
  954. type--;
  955. if(g_equ_config_ac[i].owner == 0)
  956. {
  957. if(type < PUB_AC_NUM)
  958. {
  959. // 索引
  960. ui = type;
  961. g_sw_pub.ac_cfg_index[type] = i;
  962. }
  963. else
  964. {
  965. rt_printf("switch_init(ac):i=%d,type=%d,AC_NUM=%d.\r\n",i, g_equ_config_ac[i].type,PUB_AC_NUM);
  966. continue;
  967. }
  968. }
  969. else
  970. {
  971. sw = g_equ_config_ac[i].owner - 1;
  972. if(type < SW_AC_NUM)
  973. {
  974. ui = UI_SW_INDEX(sw,type);
  975. // 索引
  976. g_sw[sw].ac_cfg_index[type] = i;
  977. }
  978. else
  979. {
  980. rt_printf("switch_init(ac):i=%d,type=%d,AC_NUM=%d,sw=%d.\r\n",i, type,SW_AC_NUM,sw);
  981. continue;
  982. }
  983. }
  984. // 通道索引
  985. g_ui[ui].chn_index = equ_get_ac_channel(g_equ_config_ac[i].slot,g_equ_config_ac[i].index);
  986. // 系数
  987. factor_e_c_get(g_equ_config_ac[i].slot,g_equ_config_ac[i].index,&f);
  988. g_ui[ui].e_factor0 = f /factor_e_k(g_equ_config_ac[i].scale);
  989. g_ui[ui].m2_factor_k = rt_round(factor_e_k(g_equ_config_ac[i].scale)*Q08_BASE);
  990. #ifdef PROTECT_AC_ADJUST
  991. factor_p_e_c_get(g_equ_config_ac[i].slot,g_equ_config_ac[i].index,&f); //保护校准系数
  992. #endif
  993. g_ui[ui].m2_factor_c = rt_round(f*Q16_BASE);
  994. factor_p_c_get(g_equ_config_ac[i].slot,g_equ_config_ac[i].index,&f);
  995. g_ui[ui].p_factor = f;
  996. //一二变比
  997. g_ui[ui].e_ps = factor_e_ps(equ_get_ac_scale(g_equ_config_ac[i].slot, g_equ_config_ac[i].index));
  998. // 暂时屏蔽,看看不使用PQ校准的效果
  999. //factor_pq_get(g_equ_config_ac[i].slot,g_equ_config_ac[i].index,g_ui[ui].pq_factor);
  1000. }
  1001. // 计算角度时的基准通道
  1002. if(g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO)
  1003. {
  1004. g_ui_angle0 = PUB_AC_UA1;
  1005. }
  1006. else if(g_ui[PUB_AC_UAB1].chn_index != CFG_ADC_CHANNEL_ZERO)
  1007. {
  1008. g_ui_angle0 = PUB_AC_UAB1;
  1009. }
  1010. else if(g_ui[PUB_AC_UAB2].chn_index != CFG_ADC_CHANNEL_ZERO)
  1011. {
  1012. g_ui_angle0 = PUB_AC_UAB2;
  1013. }
  1014. else
  1015. {
  1016. g_ui_angle0 = -1;
  1017. }
  1018. // 相电压合成线电压标志
  1019. if( g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO
  1020. && g_ui[PUB_AC_UB1].chn_index != CFG_ADC_CHANNEL_ZERO
  1021. && g_ui[PUB_AC_UC1].chn_index != CFG_ADC_CHANNEL_ZERO
  1022. && g_ui[PUB_AC_UAB1].chn_index == CFG_ADC_CHANNEL_ZERO
  1023. && g_ui[PUB_AC_UBC1].chn_index == CFG_ADC_CHANNEL_ZERO
  1024. && g_ui[PUB_AC_UCA1].chn_index == CFG_ADC_CHANNEL_ZERO)
  1025. {
  1026. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_LV1;
  1027. memcpy(&g_ui[PUB_AC_UAB1],&g_ui[PUB_AC_UA1],sizeof(g_ui[0]));
  1028. g_ui[PUB_AC_UAB1].chn_index = CFG_ADC_CHANNEL_ZERO;
  1029. g_ui[PUB_AC_UAB1].ui_base_make = PUB_AC_UA1;
  1030. g_ui[PUB_AC_UAB1].e_factor0 = (g_ui[PUB_AC_UA1].e_factor0 + g_ui[PUB_AC_UB1].e_factor0)/2;
  1031. memcpy(&g_ui[PUB_AC_UBC1],&g_ui[PUB_AC_UA1],sizeof(g_ui[0]));
  1032. g_ui[PUB_AC_UBC1].chn_index = CFG_ADC_CHANNEL_ZERO;
  1033. g_ui[PUB_AC_UBC1].ui_base_make = PUB_AC_UA1;
  1034. g_ui[PUB_AC_UBC1].e_factor0 = (g_ui[PUB_AC_UB1].e_factor0 + g_ui[PUB_AC_UC1].e_factor0)/2;
  1035. memcpy(&g_ui[PUB_AC_UCA1],&g_ui[PUB_AC_UA1],sizeof(g_ui[0]));
  1036. g_ui[PUB_AC_UCA1].chn_index = CFG_ADC_CHANNEL_ZERO;
  1037. g_ui[PUB_AC_UCA1].ui_base_make = PUB_AC_UA1;
  1038. g_ui[PUB_AC_UCA1].e_factor0 = (g_ui[PUB_AC_UC1].e_factor0 + g_ui[PUB_AC_UA1].e_factor0)/2;
  1039. }
  1040. if(g_ui[PUB_AC_UA2].chn_index != CFG_ADC_CHANNEL_ZERO
  1041. && g_ui[PUB_AC_UB2].chn_index != CFG_ADC_CHANNEL_ZERO
  1042. && g_ui[PUB_AC_UC2].chn_index != CFG_ADC_CHANNEL_ZERO
  1043. && g_ui[PUB_AC_UAB2].chn_index == CFG_ADC_CHANNEL_ZERO
  1044. && g_ui[PUB_AC_UBC2].chn_index == CFG_ADC_CHANNEL_ZERO
  1045. && g_ui[PUB_AC_UCA2].chn_index == CFG_ADC_CHANNEL_ZERO)
  1046. {
  1047. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_LV2;
  1048. memcpy(&g_ui[PUB_AC_UAB2],&g_ui[PUB_AC_UA2],sizeof(g_ui[0]));
  1049. g_ui[PUB_AC_UAB2].chn_index = CFG_ADC_CHANNEL_ZERO;
  1050. g_ui[PUB_AC_UAB2].ui_base_make = PUB_AC_UA2;
  1051. g_ui[PUB_AC_UAB2].e_factor0 = (g_ui[PUB_AC_UA2].e_factor0 + g_ui[PUB_AC_UB2].e_factor0)/2;
  1052. memcpy(&g_ui[PUB_AC_UBC2],&g_ui[PUB_AC_UA2],sizeof(g_ui[0]));
  1053. g_ui[PUB_AC_UBC2].chn_index = CFG_ADC_CHANNEL_ZERO;
  1054. g_ui[PUB_AC_UBC2].ui_base_make = PUB_AC_UA2;
  1055. g_ui[PUB_AC_UBC2].e_factor0 = (g_ui[PUB_AC_UB2].e_factor0 + g_ui[PUB_AC_UC2].e_factor0)/2;
  1056. memcpy(&g_ui[PUB_AC_UCA2],&g_ui[PUB_AC_UA2],sizeof(g_ui[0]));
  1057. g_ui[PUB_AC_UCA2].chn_index = CFG_ADC_CHANNEL_ZERO;
  1058. g_ui[PUB_AC_UCA2].ui_base_make = PUB_AC_UA2;
  1059. g_ui[PUB_AC_UCA2].e_factor0 = (g_ui[PUB_AC_UC2].e_factor0 + g_ui[PUB_AC_UA2].e_factor0)/2;
  1060. }
  1061. // 合成UCA标志
  1062. if( g_ui[PUB_AC_UAB1].chn_index != CFG_ADC_CHANNEL_ZERO
  1063. && g_ui[PUB_AC_UBC1].chn_index != CFG_ADC_CHANNEL_ZERO
  1064. && g_ui[PUB_AC_UCA1].chn_index == CFG_ADC_CHANNEL_ZERO)
  1065. {
  1066. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_UCA1;
  1067. memcpy(&g_ui[PUB_AC_UCA1],&g_ui[PUB_AC_UAB1],sizeof(g_ui[0]));
  1068. g_ui[PUB_AC_UCA1].chn_index = CFG_ADC_CHANNEL_ZERO;
  1069. g_ui[PUB_AC_UCA1].ui_base_make = PUB_AC_UAB1;
  1070. g_ui[PUB_AC_UCA1].e_factor0 = (g_ui[PUB_AC_UAB1].e_factor0 + g_ui[PUB_AC_UBC1].e_factor0)/2;
  1071. }
  1072. if( g_ui[PUB_AC_UAB2].chn_index != CFG_ADC_CHANNEL_ZERO
  1073. && g_ui[PUB_AC_UBC2].chn_index != CFG_ADC_CHANNEL_ZERO
  1074. && g_ui[PUB_AC_UCA2].chn_index == CFG_ADC_CHANNEL_ZERO)
  1075. {
  1076. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_UCA2;
  1077. memcpy(&g_ui[PUB_AC_UCA2],&g_ui[PUB_AC_UAB2],sizeof(g_ui[0]));
  1078. g_ui[PUB_AC_UCA2].chn_index = CFG_ADC_CHANNEL_ZERO;
  1079. g_ui[PUB_AC_UCA2].ui_base_make = PUB_AC_UAB2;
  1080. g_ui[PUB_AC_UCA2].e_factor0 = (g_ui[PUB_AC_UAB2].e_factor0 + g_ui[PUB_AC_UBC2].e_factor0)/2;
  1081. }
  1082. // U01 零序电压自产
  1083. if( g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO
  1084. && g_ui[PUB_AC_UB1].chn_index != CFG_ADC_CHANNEL_ZERO
  1085. && g_ui[PUB_AC_UC1].chn_index != CFG_ADC_CHANNEL_ZERO
  1086. && g_ui[PUB_AC_U01].chn_index == CFG_ADC_CHANNEL_ZERO
  1087. &&pRunSet->bTT_U0ZC)
  1088. {
  1089. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_U01;
  1090. memcpy(&g_ui[PUB_AC_U01],&g_ui[PUB_AC_UA1],sizeof(g_ui[0]));
  1091. g_ui[PUB_AC_U01].chn_index = CFG_ADC_CHANNEL_ZERO;
  1092. g_ui[PUB_AC_U01].ui_base_make = PUB_AC_UA1;
  1093. g_ui[PUB_AC_U01].e_factor0 = (g_ui[PUB_AC_UA1].e_factor0 + g_ui[PUB_AC_UB1].e_factor0+g_ui[PUB_AC_UC1].e_factor0)/3;
  1094. }
  1095. // U02 零序电压自产
  1096. if( g_ui[PUB_AC_UA2].chn_index != CFG_ADC_CHANNEL_ZERO
  1097. && g_ui[PUB_AC_UB2].chn_index != CFG_ADC_CHANNEL_ZERO
  1098. && g_ui[PUB_AC_UC2].chn_index != CFG_ADC_CHANNEL_ZERO
  1099. && g_ui[PUB_AC_U02].chn_index == CFG_ADC_CHANNEL_ZERO
  1100. &&pRunSet->bTT_U0ZC)
  1101. {
  1102. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_U02;
  1103. memcpy(&g_ui[PUB_AC_U02],&g_ui[PUB_AC_UA2],sizeof(g_ui[0]));
  1104. g_ui[PUB_AC_U02].chn_index = CFG_ADC_CHANNEL_ZERO;
  1105. g_ui[PUB_AC_U02].ui_base_make = PUB_AC_UA2;
  1106. g_ui[PUB_AC_U02].e_factor0 = (g_ui[PUB_AC_UA2].e_factor0 + g_ui[PUB_AC_UB2].e_factor0+g_ui[PUB_AC_UC2].e_factor0)/3;
  1107. }
  1108. // 合成IB、I0标志
  1109. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  1110. {
  1111. if( g_ui[UI_SW_INDEX(sw,SW_AC_IA)].chn_index != CFG_ADC_CHANNEL_ZERO
  1112. && g_ui[UI_SW_INDEX(sw,SW_AC_IC)].chn_index != CFG_ADC_CHANNEL_ZERO
  1113. && g_ui[UI_SW_INDEX(sw,SW_AC_IB)].chn_index == CFG_ADC_CHANNEL_ZERO)
  1114. {
  1115. g_sw[sw].ui_flags |= UI_FLAGS_MAKE_IB;
  1116. memcpy(&g_ui[UI_SW_INDEX(sw,SW_AC_IB)],&g_ui[UI_SW_INDEX(sw,SW_AC_IA)],sizeof(g_ui[0]));
  1117. g_ui[UI_SW_INDEX(sw,SW_AC_IB)].chn_index = CFG_ADC_CHANNEL_ZERO;
  1118. g_ui[UI_SW_INDEX(sw,SW_AC_IB)].ui_base_make = UI_SW_INDEX(sw,SW_AC_IA);
  1119. g_ui[UI_SW_INDEX(sw,SW_AC_IB)].e_factor0 = (g_ui[UI_SW_INDEX(sw,SW_AC_IA)].e_factor0 + g_ui[UI_SW_INDEX(sw,SW_AC_IC)].e_factor0)/2;
  1120. }
  1121. if( g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].chn_index != CFG_ADC_CHANNEL_ZERO
  1122. && g_ui[UI_SW_INDEX(sw,SW_AC_CIC)].chn_index != CFG_ADC_CHANNEL_ZERO
  1123. && g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].chn_index == CFG_ADC_CHANNEL_ZERO)
  1124. {
  1125. g_sw[sw].ui_flags |= UI_FLAGS_MAKE_CIB;
  1126. memcpy(&g_ui[UI_SW_INDEX(sw,SW_AC_CIB)],&g_ui[UI_SW_INDEX(sw,SW_AC_CIA)],sizeof(g_ui[0]));
  1127. g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].chn_index = CFG_ADC_CHANNEL_ZERO;
  1128. g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].ui_base_make = UI_SW_INDEX(sw,SW_AC_CIA);
  1129. g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].e_factor0 = (g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].e_factor0 + g_ui[UI_SW_INDEX(sw,SW_AC_CIC)].e_factor0)/2;
  1130. }
  1131. if( g_ui[UI_SW_INDEX(sw,SW_AC_IA)].chn_index != CFG_ADC_CHANNEL_ZERO
  1132. && g_ui[UI_SW_INDEX(sw,SW_AC_IB)].chn_index != CFG_ADC_CHANNEL_ZERO
  1133. && g_ui[UI_SW_INDEX(sw,SW_AC_IC)].chn_index != CFG_ADC_CHANNEL_ZERO
  1134. && g_ui[UI_SW_INDEX(sw,SW_AC_I0)].chn_index == CFG_ADC_CHANNEL_ZERO)
  1135. {
  1136. g_sw[sw].ui_flags |= UI_FLAGS_MAKE_I0;
  1137. memcpy(&g_ui[UI_SW_INDEX(sw,SW_AC_I0)],&g_ui[UI_SW_INDEX(sw,SW_AC_IA)],sizeof(g_ui[0]));
  1138. g_ui[UI_SW_INDEX(sw,SW_AC_I0)].chn_index = CFG_ADC_CHANNEL_ZERO;
  1139. g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ui_base_make = UI_SW_INDEX(sw,SW_AC_IA);
  1140. g_ui[UI_SW_INDEX(sw,SW_AC_I0)].e_factor0 = (g_ui[UI_SW_INDEX(sw,SW_AC_IA)].e_factor0
  1141. + g_ui[UI_SW_INDEX(sw,SW_AC_IB)].e_factor0
  1142. + g_ui[UI_SW_INDEX(sw,SW_AC_IC)].e_factor0)/3;
  1143. }
  1144. }
  1145. #if 0 // 支持功率电压选择,计算方法等计算时再确定
  1146. // 确认是3表法还是2表法
  1147. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  1148. {
  1149. if(g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO
  1150. && g_ui[PUB_AC_UB1].chn_index != CFG_ADC_CHANNEL_ZERO
  1151. && g_ui[PUB_AC_UC1].chn_index != CFG_ADC_CHANNEL_ZERO)
  1152. {
  1153. if( g_ui[UI_SW_INDEX(sw,SW_AC_IA)].chn_index != CFG_ADC_CHANNEL_ZERO
  1154. && g_ui[UI_SW_INDEX(sw,SW_AC_IB)].chn_index != CFG_ADC_CHANNEL_ZERO
  1155. && g_ui[UI_SW_INDEX(sw,SW_AC_IC)].chn_index != CFG_ADC_CHANNEL_ZERO)
  1156. {
  1157. g_sw[sw].ui_flags |= UI_FLAGS_3M;
  1158. }
  1159. }
  1160. }
  1161. #endif
  1162. //通道名称
  1163. for(i=0; i< UI_NUM; i++)
  1164. {
  1165. if(i< PUB_AC_NUM)
  1166. {
  1167. if(strlen(g_pub_ac_desc[i].name) < CFG_NAME_LEN)
  1168. strcpy(g_ui[i].name, g_pub_ac_desc[i].name);
  1169. else
  1170. strncpy(g_ui[i].name, g_pub_ac_desc[i].name,CFG_NAME_LEN);
  1171. }
  1172. else
  1173. {
  1174. sw = (i-PUB_AC_NUM)/SW_AC_NUM;
  1175. sprintf(g_ui[i].name,"%02d%s",sw+1,g_sw_ac_desc[(i-PUB_AC_NUM)%SW_AC_NUM].name);
  1176. }
  1177. }
  1178. // 复位统计数据
  1179. sw_stat_reset();
  1180. g_sw_init = 1;
  1181. return 0;
  1182. }
  1183. int sw_ext_init(void)
  1184. {
  1185. // U01 零序电压自产
  1186. if( g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO
  1187. && g_ui[PUB_AC_UB1].chn_index != CFG_ADC_CHANNEL_ZERO
  1188. && g_ui[PUB_AC_UC1].chn_index != CFG_ADC_CHANNEL_ZERO
  1189. && g_ui[PUB_AC_U01].chn_index == CFG_ADC_CHANNEL_ZERO
  1190. &&pRunSet->bTT_U0ZC)
  1191. {
  1192. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_U01;
  1193. memcpy(&g_ui[PUB_AC_U01],&g_ui[PUB_AC_UA1],sizeof(g_ui[0]));
  1194. g_ui[PUB_AC_U01].chn_index = CFG_ADC_CHANNEL_ZERO;
  1195. g_ui[PUB_AC_U01].ui_base_make = PUB_AC_UA1;
  1196. g_ui[PUB_AC_U01].e_factor0 = (g_ui[PUB_AC_UA1].e_factor0 + g_ui[PUB_AC_UB1].e_factor0+g_ui[PUB_AC_UC1].e_factor0)/3;
  1197. }
  1198. // U02 零序电压自产
  1199. if( g_ui[PUB_AC_UA2].chn_index != CFG_ADC_CHANNEL_ZERO
  1200. && g_ui[PUB_AC_UB2].chn_index != CFG_ADC_CHANNEL_ZERO
  1201. && g_ui[PUB_AC_UC2].chn_index != CFG_ADC_CHANNEL_ZERO
  1202. && g_ui[PUB_AC_U02].chn_index == CFG_ADC_CHANNEL_ZERO
  1203. &&pRunSet->bTT_U0ZC)
  1204. {
  1205. g_sw_pub.ui_flags |= UI_FLAGS_MAKE_U02;
  1206. memcpy(&g_ui[PUB_AC_U02],&g_ui[PUB_AC_UA2],sizeof(g_ui[0]));
  1207. g_ui[PUB_AC_U02].chn_index = CFG_ADC_CHANNEL_ZERO;
  1208. g_ui[PUB_AC_U02].ui_base_make = PUB_AC_UA2;
  1209. g_ui[PUB_AC_U02].e_factor0 = (g_ui[PUB_AC_UA2].e_factor0 + g_ui[PUB_AC_UB2].e_factor0+g_ui[PUB_AC_UC2].e_factor0)/3;
  1210. }
  1211. return 0;
  1212. }
  1213. /******************************************************************************
  1214. 函数名称: sw_exit
  1215. 函数版本: 01.01
  1216. 创建作者: sunxi
  1217. 创建日期: 2013-08-07
  1218. 函数说明: 线路开关退出
  1219. 参数说明:
  1220. 返回值:
  1221. 0: 成功
  1222. 其它: 失败
  1223. 修改记录:
  1224. */
  1225. int sw_exit(void)
  1226. {
  1227. return 0;
  1228. }
  1229. int sw_di_get(u32 sw,u32 no)
  1230. {
  1231. u8 v;
  1232. if(no == 0)
  1233. {
  1234. return -1;
  1235. }
  1236. no--;
  1237. if(sw == 0)
  1238. {
  1239. v=g_sw_pub.di[no] ;
  1240. }
  1241. else
  1242. {
  1243. sw--;
  1244. v=g_sw[sw].di[no] ;
  1245. }
  1246. return v;
  1247. }
  1248. int sw_di_set(u32 sw,u32 no,u8 v)
  1249. {
  1250. if(no == 0)
  1251. {
  1252. return -1;
  1253. }
  1254. no--;
  1255. if(sw == 0)
  1256. {
  1257. g_sw_pub.di[no] = v;
  1258. }
  1259. else
  1260. {
  1261. sw--;
  1262. g_sw[sw].di[no] = v;
  1263. }
  1264. return 0;
  1265. }
  1266. /******************************************************************************
  1267. 函数名称: sw_do
  1268. 函数版本: 01.01
  1269. 创建作者: sunxi
  1270. 创建日期: 2013-08-07
  1271. 函数说明: 针对线路开关执行开出动作
  1272. 参数说明:
  1273. sw 开关序号
  1274. index 开出索引
  1275. type 开出类型
  1276. 返回值:
  1277. 0: 成功
  1278. 其它: 失败
  1279. 修改记录:
  1280. */
  1281. static int _sw_do(u32 slot,u32 index,int type)
  1282. {
  1283. int ret,do_num;
  1284. do_num = equ_get_do_num(slot);
  1285. if(do_num == 0)
  1286. {
  1287. return -1;
  1288. }
  1289. // 将辅助板的4个开出(64~67)映射到(0~3),
  1290. // 解决32位宽度不够的问题,这样LED灯不允许配置成开出。
  1291. // 其它板不存在这个问题,例如开出板只有16个开出可配
  1292. if((g_board_info[slot].type == BOARD_TYPE_AUX) || (g_board_info[slot].type == BOARD_TYPE_ZT))
  1293. {
  1294. index = index%32;
  1295. }
  1296. ret = 0;
  1297. switch(type)
  1298. {
  1299. case SW_DO_TYPE_OFF:
  1300. case SW_DO_TYPE_ON:
  1301. ret = dido_do(slot,(1<<index),type);
  1302. break;
  1303. case SW_DO_TYPE_SELECT_ON:
  1304. if(dido_do_have_select(slot,index))
  1305. {
  1306. ret = dido_do(slot,(1<<do_num),1);
  1307. }
  1308. break;
  1309. case SW_DO_TYPE_SELECT_OFF:
  1310. if(dido_do_have_select(slot,index))
  1311. {
  1312. ret = dido_do(slot,(1<<do_num),0);
  1313. }
  1314. break;
  1315. default:
  1316. ret = -3;
  1317. break;
  1318. }
  1319. return ret;
  1320. }
  1321. int sw_do(u32 sw,u32 index,int type)
  1322. {
  1323. int ret;
  1324. u32 slot;
  1325. TRELAY_T *pR=&g_tRelay[sw];
  1326. if((index == SW_DO_HZ || index == SW_DO_YKH || index == SW_DO_BHH) && (type == SW_DO_TYPE_ON))
  1327. {
  1328. if(pR->run_stu.sw==1)
  1329. {
  1330. pR->uRmtSW.bHz_Doing = 1;
  1331. #ifdef FUNC_DRIVE
  1332. gb_drive.bHz_Doing = 1;
  1333. #endif
  1334. }
  1335. pR->uRmtSW.bTz_Doing = 0;
  1336. #ifdef FUNC_DRIVE
  1337. gb_drive.bTz_Doing = 0;
  1338. #endif
  1339. }
  1340. if((index == SW_DO_FZ || index == SW_DO_YKT || index == SW_DO_BHT) && (type == SW_DO_TYPE_ON))
  1341. {
  1342. if(pR->run_stu.sw==2)
  1343. {
  1344. pR->uRmtSW.bTz_Doing = 1;
  1345. #ifdef FUNC_DRIVE
  1346. gb_drive.bTz_Doing = 1;
  1347. #endif
  1348. }
  1349. pR->uRmtSW.bHz_Doing = 0;
  1350. #ifdef FUNC_DRIVE
  1351. gb_drive.bHz_Doing = 0;
  1352. #endif
  1353. }
  1354. if(sw >= SWITCH_NUM_MAX || index >=SW_DO_NUM)
  1355. {
  1356. return -1;
  1357. }
  1358. // 气压低闭锁分合闸
  1359. if(pRunSet->tSwSet[sw].bTT_QYD_BS
  1360. && (g_sw[sw].di[SW_DI_QYD] == SW_DI_TYPE_ON)
  1361. && (index == SW_DO_HZ || index == SW_DO_FZ||index == SW_DO_YKH||index == SW_DO_YKT||index ==SW_DO_BHH||index ==SW_DO_BHT))
  1362. {
  1363. return -2;
  1364. }
  1365. // 需要通道有配置
  1366. index = g_sw[sw].do_cfg_index[index];
  1367. if(index == INDEX_INVALLID || index >= g_equ_config->do_num)
  1368. {
  1369. return -3;
  1370. }
  1371. slot = g_equ_config_do[index].slot;
  1372. index = g_equ_config_do[index].index;
  1373. ret = _sw_do(slot,index,type);
  1374. return ret;
  1375. }
  1376. /******************************************************************************
  1377. 函数名称: sw_do_pub
  1378. 函数版本: 01.01
  1379. 创建作者: sunxi
  1380. 创建日期: 2013-08-07
  1381. 函数说明: 针对线路开关公共部门执行开出动作
  1382. 参数说明:
  1383. index 开出索引
  1384. type 开出类型
  1385. 返回值:
  1386. 0: 成功
  1387. 其它: 失败
  1388. 修改记录:
  1389. */
  1390. int sw_do_pub(u32 index,int type)
  1391. {
  1392. int ret;
  1393. u32 slot;
  1394. if(index >=PUB_DO_NUM)
  1395. {
  1396. return -1;
  1397. }
  1398. index = g_sw_pub.do_cfg_index[index];
  1399. if(index == INDEX_INVALLID || index >= g_equ_config->do_num)
  1400. {
  1401. return -2;
  1402. }
  1403. slot = g_equ_config_do[index].slot;
  1404. index = g_equ_config_do[index].index;
  1405. ret = _sw_do(slot,index,type);
  1406. return ret;
  1407. }
  1408. /******************************************************************************
  1409. 函数名称: sw_do_yk
  1410. 函数版本: 01.01
  1411. 创建作者: sunxi
  1412. 创建日期: 2013-08-07
  1413. 函数说明: 预控继电器开出
  1414. 参数说明:
  1415. index 开出索引
  1416. type 开出类型
  1417. 返回值:
  1418. 0: 成功
  1419. 其它: 失败
  1420. 修改记录:
  1421. */
  1422. int sw_do_yuk(int type)
  1423. {
  1424. int ret;
  1425. u32 slot;
  1426. int index;
  1427. index = g_sw_pub.do_cfg_index[PUB_DO_YK];
  1428. if(index == INDEX_INVALLID || index >= g_equ_config->do_num)
  1429. {
  1430. return -2;
  1431. }
  1432. slot = g_equ_config_do[index].slot;
  1433. index = g_equ_config_do[index].index;
  1434. ret = _sw_do(slot,index,type);
  1435. return ret;
  1436. }
  1437. /******************************************************************************
  1438. 函数名称: sw_v_m2_factor_k
  1439. 函数版本: 01.01
  1440. 创建作者: sunxi
  1441. 创建日期: 2013-08-07
  1442. 函数说明: 得到一个保护定值计算用的理论转化系数。目前假设所有电压的系数都是一样,
  1443. 从第一组电压中取出一个。
  1444. 参数说明:
  1445. 返回值:
  1446. 修改记录:
  1447. */
  1448. float sw_v_m2_factor_k(int id)
  1449. {
  1450. if(id < PUB_AC_NUM)
  1451. {
  1452. if(id == PUB_AC_US1)
  1453. {
  1454. if((short)g_sw_pub.ac_cfg_index[PUB_AC_US1] == INDEX_INVALLID)
  1455. {
  1456. return g_ui[PUB_AC_UAB1].m2_factor_k;
  1457. }
  1458. else
  1459. {
  1460. if(g_ui[id].chn_index != CFG_ADC_CHANNEL_ZERO)
  1461. {
  1462. return g_ui[id].m2_factor_k;
  1463. }
  1464. }
  1465. }
  1466. else if(id == PUB_AC_US2)
  1467. {
  1468. if((short)g_sw_pub.ac_cfg_index[PUB_AC_US2] == INDEX_INVALLID)
  1469. {
  1470. return g_ui[PUB_AC_UBC2].m2_factor_k;
  1471. }
  1472. else
  1473. {
  1474. if(g_ui[id].chn_index != CFG_ADC_CHANNEL_ZERO)
  1475. {
  1476. return g_ui[id].m2_factor_k;
  1477. }
  1478. }
  1479. }
  1480. else if(id == PUB_AC_U01)
  1481. {
  1482. if(g_ui[id].chn_index == CFG_ADC_CHANNEL_ZERO)
  1483. {
  1484. return g_ui[PUB_AC_UA1].m2_factor_k;
  1485. }
  1486. else
  1487. {
  1488. if(g_ui[id].chn_index != CFG_ADC_CHANNEL_ZERO)
  1489. {
  1490. return g_ui[id].m2_factor_k;
  1491. }
  1492. }
  1493. }
  1494. else if(id == PUB_AC_U02)
  1495. {
  1496. if(g_ui[id].chn_index == CFG_ADC_CHANNEL_ZERO)
  1497. {
  1498. return g_ui[PUB_AC_UA2].m2_factor_k;
  1499. }
  1500. else
  1501. {
  1502. if(g_ui[id].chn_index != CFG_ADC_CHANNEL_ZERO)
  1503. {
  1504. return g_ui[id].m2_factor_k;
  1505. }
  1506. }
  1507. }
  1508. else
  1509. {
  1510. //if(g_ui[id].chn_index != CFG_ADC_CHANNEL_ZERO)
  1511. //{
  1512. return g_ui[id].m2_factor_k;
  1513. //}
  1514. }
  1515. }
  1516. return 1.0;
  1517. }
  1518. #ifdef FUNC_DRIVE_JY
  1519. static void drive_ui_proc(void)
  1520. {
  1521. int i=0,sw=0;
  1522. TSETSW *pSet = &pRunSet->tSwSet[sw];
  1523. if(!gb_drive.b_drive_on)
  1524. {
  1525. return;
  1526. }
  1527. for(i=0;i<1;i++)//保护遥测值
  1528. {
  1529. if(!gb_drive.tDriveUa1Time.boolTrip)
  1530. {
  1531. g_ui[PUB_AC_UA1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UA1]/256.0));
  1532. g_ui[PUB_AC_UB1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UB1]/256.0));
  1533. g_ui[PUB_AC_UC1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UC1]/256.0));
  1534. g_ui[PUB_AC_UAB1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UAB1]/256.0));
  1535. g_ui[PUB_AC_UBC1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UBC1]/256.0));
  1536. g_ui[PUB_AC_UCA1].m2[i] = GetSetSQR(pSet->dU_drive_ua1,(pRunSet->dKU[PUB_AC_UCA1]/256.0));
  1537. }
  1538. if(!gb_drive.tDriveUa2Time.boolTrip)
  1539. {
  1540. g_ui[PUB_AC_UA2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UA2]/256.0));
  1541. g_ui[PUB_AC_UB2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UB2]/256.0));
  1542. g_ui[PUB_AC_UC2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UC2]/256.0));
  1543. g_ui[PUB_AC_UAB2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UAB2]/256.0));
  1544. g_ui[PUB_AC_UBC2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UBC2]/256.0));
  1545. g_ui[PUB_AC_UCA2].m2[i] = GetSetSQR(pSet->dU_drive_ua2,(pRunSet->dKU[PUB_AC_UCA2]/256.0));
  1546. }
  1547. if(!gb_drive.tDriveU0Time.boolTrip)
  1548. {
  1549. g_ui[PUB_AC_U01].m2[i] = GetSetSQR(pSet->dU_drive_u0,(pRunSet->dKU[PUB_AC_U01]/256.0));
  1550. }
  1551. if(!gb_drive.tDriveITime.boolTrip)
  1552. {
  1553. g_ui[UI_SW_INDEX_BEGIN(sw)+SW_AC_IA].m2[i] = GetSetSQR(pSet->dU_drive_i,(g_ui[UI_SW_INDEX_BEGIN(sw)+SW_AC_IA].m2_factor_k/256.0));
  1554. }
  1555. if(!gb_drive.tDriveI0Time.boolTrip)
  1556. {
  1557. g_ui[UI_SW_INDEX_BEGIN(sw)+SW_AC_I0].m2[i] = GetSetSQR(pSet->dU_drive_i0,(g_ui[UI_SW_INDEX_BEGIN(sw)+SW_AC_I0].m2_factor_k/256.0));
  1558. }
  1559. }
  1560. #if 0
  1561. //测量显示遥测值
  1562. g_sw_pub.ac_in[PUB_AC_UA1] =(pSet->dU_drive_ua1*Q16_BASE);
  1563. g_sw_pub.ac_in[PUB_AC_UAB1] =(pSet->dU_drive_ua1*Q16_BASE);
  1564. g_sw_pub.ac_in[PUB_AC_UA2] =(pSet->dU_drive_ua2*Q16_BASE);
  1565. g_sw_pub.ac_in[PUB_AC_UAB2] =(pSet->dU_drive_ua2*Q16_BASE);
  1566. g_sw_pub.ac_in[PUB_AC_U01] = (qs16)(pSet->dU_drive_u0*Q16_BASE);
  1567. g_sw[sw].ac_in[SW_AC_IA] = (qs16)(pSet->dU_drive_i*Q16_BASE);
  1568. g_sw[sw].ac_in[SW_AC_I0] = (qs16)(pSet->dU_drive_i0*Q16_BASE);
  1569. #endif
  1570. }
  1571. #endif
  1572. /******************************************************************************
  1573. 函数名称: sw_cal_protect
  1574. 函数版本: 01.01
  1575. 创建作者: sunxi
  1576. 创建日期: 2013-08-07
  1577. 函数说明: 在保护5ms中断中计算基波的值。
  1578. 参数说明:
  1579. 返回值:
  1580. 修改记录:
  1581. */
  1582. void sw_cal_protect(void)
  1583. {
  1584. int sw,i,index ;
  1585. short *psam;
  1586. qs08 angle;
  1587. qs16 lncos,lnsin;
  1588. struct ri_s16 ri16;
  1589. struct ri_s16 ri16_2;
  1590. struct ri_s32 ri;
  1591. struct ri_s32 ri_2[2];
  1592. // 更新保护计算时采样点的索引
  1593. g_prot_index=g_adc_dots_index;
  1594. #ifdef FUN_HCBS
  1595. {
  1596. extern DWORD dTcounterrem;
  1597. dTcounterrem=dTCounter;
  1598. }
  1599. #endif
  1600. // 计算模值平方
  1601. for(i=0; i<UI_NUM; i++)
  1602. {
  1603. // 如果索引通道不存在,不需计算
  1604. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  1605. {
  1606. continue;
  1607. }
  1608. // 检查硬件通道是否正常,如果不正常,ri清零;否则计算出ri。
  1609. if(equ_ac_channel_is_ok(g_ui[i].chn_index) == 0)
  1610. {
  1611. ri16.r = 0;
  1612. ri16.i = 0;
  1613. ri16_2.r = 0;
  1614. ri16_2.i = 0;
  1615. }
  1616. else
  1617. {
  1618. psam = adc_fourier_address(g_ui[i].chn_index,g_prot_index);
  1619. // 基波FFT
  1620. fourier32(psam, &ri16, FOURIER_HARMONIC_1);
  1621. // 二次谐波FFT
  1622. if (i >= PUB_AC_NUM)
  1623. {
  1624. fourier32(psam, &ri16_2, FOURIER_HARMONIC_2);
  1625. }
  1626. }
  1627. //基波计算
  1628. ri.r = _MulFac_S(ri16.r,g_ui[i].m2_factor_c); // 电压电流实部
  1629. ri.i = _MulFac_S(ri16.i,g_ui[i].m2_factor_c); // 电压电流虚部
  1630. angle = rt_round((g_ui[i].p_factor + factor_p_k(g_ui[i].chn_index))*256);
  1631. lncos = mCos(angle);
  1632. lnsin = mSin(angle);
  1633. g_ui[i].ri.r = _MulFac_S(ri.r,lncos) - _MulFac_S(ri.i,lnsin);
  1634. g_ui[i].ri.i = _MulFac_S(ri.r,lnsin) + _MulFac_S(ri.i,lncos);
  1635. g_ui[i].m2[0] = SQR(g_ui[i].ri.r,g_ui[i].ri.i); // 电压电流平方和
  1636. rt_stat_in(&g_ui[i].m2_stat,g_ui[i].m2[0]);
  1637. //二次谐波计算
  1638. if (i >= PUB_AC_NUM)
  1639. {
  1640. ri_2[0].r = _MulFac_S(ri16_2.r,g_ui[i].m2_factor_c); // 电压电流实部
  1641. ri_2[0].i = _MulFac_S(ri16_2.i,g_ui[i].m2_factor_c); // 电压电流虚部
  1642. #if 0
  1643. angle = rt_round(g_ui[i].p_factor*256);
  1644. lncos = mCos(angle);
  1645. lnsin = mSin(angle);
  1646. #endif
  1647. ri_2[1].r = _MulFac_S(ri_2[0].r,lncos) - _MulFac_S(ri_2[0].i,lnsin);
  1648. ri_2[1].i = _MulFac_S(ri_2[0].r,lnsin) + _MulFac_S(ri_2[0].i,lncos);
  1649. g_ui[i].m2[1] = SQR(ri_2[1].r,ri_2[1].i); // 电压电流平方和
  1650. }
  1651. }
  1652. #ifdef GD_AREA_ECZD_2020
  1653. //计算正序和负序电压
  1654. //US1
  1655. if((g_ui[PUB_AC_UA1].chn_index != CFG_ADC_CHANNEL_ZERO)&&(g_ui[PUB_AC_UB1].chn_index != CFG_ADC_CHANNEL_ZERO)&&(g_ui[PUB_AC_UC1].chn_index != CFG_ADC_CHANNEL_ZERO))
  1656. {
  1657. _sw_cal_Xfl120(PUB_AC_UA1, &Us1_120);
  1658. }
  1659. else
  1660. {
  1661. Us2_120.vect1=0;
  1662. Us2_120.vect2=0;
  1663. }
  1664. //US2
  1665. if((g_ui[PUB_AC_UA2].chn_index != CFG_ADC_CHANNEL_ZERO)&&(g_ui[PUB_AC_UB2].chn_index != CFG_ADC_CHANNEL_ZERO)&&(g_ui[PUB_AC_UC2].chn_index != CFG_ADC_CHANNEL_ZERO))
  1666. {
  1667. _sw_cal_Xfl120(PUB_AC_UA2, &Us2_120);
  1668. }
  1669. else
  1670. {
  1671. Us2_120.vect1=0;
  1672. Us2_120.vect2=0;
  1673. }
  1674. #endif
  1675. // 合成线电压1
  1676. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_LV1)
  1677. {
  1678. g_ui[PUB_AC_UAB1].ri.r = g_ui[PUB_AC_UA1].ri.r - g_ui[PUB_AC_UB1].ri.r;
  1679. g_ui[PUB_AC_UAB1].ri.i = g_ui[PUB_AC_UA1].ri.i - g_ui[PUB_AC_UB1].ri.i;
  1680. g_ui[PUB_AC_UAB1].m2[0] = SQR(g_ui[PUB_AC_UAB1].ri.r,g_ui[PUB_AC_UAB1].ri.i);
  1681. rt_stat_in(&g_ui[PUB_AC_UAB1].m2_stat,g_ui[PUB_AC_UAB1].m2[0]);
  1682. g_ui[PUB_AC_UBC1].ri.r = g_ui[PUB_AC_UB1].ri.r - g_ui[PUB_AC_UC1].ri.r;
  1683. g_ui[PUB_AC_UBC1].ri.i = g_ui[PUB_AC_UB1].ri.i - g_ui[PUB_AC_UC1].ri.i;
  1684. g_ui[PUB_AC_UBC1].m2[0] = SQR(g_ui[PUB_AC_UBC1].ri.r,g_ui[PUB_AC_UBC1].ri.i);
  1685. rt_stat_in(&g_ui[PUB_AC_UBC1].m2_stat,g_ui[PUB_AC_UBC1].m2[0]);
  1686. g_ui[PUB_AC_UCA1].ri.r = g_ui[PUB_AC_UC1].ri.r - g_ui[PUB_AC_UA1].ri.r;
  1687. g_ui[PUB_AC_UCA1].ri.i = g_ui[PUB_AC_UC1].ri.i - g_ui[PUB_AC_UA1].ri.i;
  1688. g_ui[PUB_AC_UCA1].m2[0] = SQR(g_ui[PUB_AC_UCA1].ri.r,g_ui[PUB_AC_UCA1].ri.i);
  1689. rt_stat_in(&g_ui[PUB_AC_UCA1].m2_stat,g_ui[PUB_AC_UCA1].m2[0]);
  1690. }
  1691. // 合成线电压2
  1692. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_LV2)
  1693. {
  1694. g_ui[PUB_AC_UAB2].ri.r = g_ui[PUB_AC_UA2].ri.r - g_ui[PUB_AC_UB2].ri.r;
  1695. g_ui[PUB_AC_UAB2].ri.i = g_ui[PUB_AC_UA2].ri.i - g_ui[PUB_AC_UB2].ri.i;
  1696. g_ui[PUB_AC_UAB2].m2[0] = SQR(g_ui[PUB_AC_UAB2].ri.r,g_ui[PUB_AC_UAB2].ri.i);
  1697. rt_stat_in(&g_ui[PUB_AC_UAB2].m2_stat,g_ui[PUB_AC_UAB2].m2[0]);
  1698. g_ui[PUB_AC_UBC2].ri.r = g_ui[PUB_AC_UB2].ri.r - g_ui[PUB_AC_UC2].ri.r;
  1699. g_ui[PUB_AC_UBC2].ri.i = g_ui[PUB_AC_UB2].ri.i - g_ui[PUB_AC_UC2].ri.i;
  1700. g_ui[PUB_AC_UBC2].m2[0] = SQR(g_ui[PUB_AC_UBC2].ri.r,g_ui[PUB_AC_UBC2].ri.i);
  1701. rt_stat_in(&g_ui[PUB_AC_UBC2].m2_stat,g_ui[PUB_AC_UBC2].m2[0]);
  1702. g_ui[PUB_AC_UCA2].ri.r = g_ui[PUB_AC_UC2].ri.r - g_ui[PUB_AC_UA2].ri.r;
  1703. g_ui[PUB_AC_UCA2].ri.i = g_ui[PUB_AC_UC2].ri.i - g_ui[PUB_AC_UA2].ri.i;
  1704. g_ui[PUB_AC_UCA2].m2[0] = SQR(g_ui[PUB_AC_UCA2].ri.r,g_ui[PUB_AC_UCA2].ri.i);
  1705. rt_stat_in(&g_ui[PUB_AC_UCA2].m2_stat,g_ui[PUB_AC_UCA2].m2[0]);
  1706. }
  1707. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_UCA1) // 合成线电压UCA1
  1708. {
  1709. g_ui[PUB_AC_UCA1].ri.r =- g_ui[PUB_AC_UAB1].ri.r - g_ui[PUB_AC_UBC1].ri.r;
  1710. g_ui[PUB_AC_UCA1].ri.i =- g_ui[PUB_AC_UAB1].ri.i - g_ui[PUB_AC_UBC1].ri.i;
  1711. g_ui[PUB_AC_UCA1].m2[0] = SQR(g_ui[PUB_AC_UCA1].ri.r,g_ui[PUB_AC_UCA1].ri.i);
  1712. rt_stat_in(&g_ui[PUB_AC_UCA1].m2_stat,g_ui[PUB_AC_UCA1].m2[0]);
  1713. }
  1714. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_UCA2) // 合成线电压UCA1
  1715. {
  1716. g_ui[PUB_AC_UCA2].ri.r =- g_ui[PUB_AC_UAB2].ri.r - g_ui[PUB_AC_UBC2].ri.r;
  1717. g_ui[PUB_AC_UCA2].ri.i =- g_ui[PUB_AC_UAB2].ri.i - g_ui[PUB_AC_UBC2].ri.i;
  1718. g_ui[PUB_AC_UCA2].m2[0] = SQR(g_ui[PUB_AC_UCA2].ri.r,g_ui[PUB_AC_UCA2].ri.i);
  1719. rt_stat_in(&g_ui[PUB_AC_UCA1].m2_stat,g_ui[PUB_AC_UCA2].m2[0]);
  1720. }
  1721. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_U01)
  1722. {
  1723. g_ui[PUB_AC_U01].ri.r = g_ui[PUB_AC_UA1].ri.r + g_ui[PUB_AC_UB1].ri.r+ g_ui[PUB_AC_UC1].ri.r;
  1724. g_ui[PUB_AC_U01].ri.i = g_ui[PUB_AC_UA1].ri.i + g_ui[PUB_AC_UB1].ri.i+ g_ui[PUB_AC_UC1].ri.i;
  1725. g_ui[PUB_AC_U01].m2[0] = SQR(g_ui[PUB_AC_U01].ri.r,g_ui[PUB_AC_U01].ri.i);
  1726. rt_stat_in(&g_ui[PUB_AC_U01].m2_stat,g_ui[PUB_AC_U01].m2[0]);
  1727. }
  1728. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_U02)
  1729. {
  1730. g_ui[PUB_AC_U02].ri.r = g_ui[PUB_AC_UA2].ri.r + g_ui[PUB_AC_UB2].ri.r+ g_ui[PUB_AC_UC2].ri.r;
  1731. g_ui[PUB_AC_U02].ri.i = g_ui[PUB_AC_UA2].ri.i + g_ui[PUB_AC_UB2].ri.i+ g_ui[PUB_AC_UC2].ri.i;
  1732. g_ui[PUB_AC_U02].m2[0] = SQR(g_ui[PUB_AC_U02].ri.r,g_ui[PUB_AC_U02].ri.i);
  1733. rt_stat_in(&g_ui[PUB_AC_U02].m2_stat,g_ui[PUB_AC_U02].m2[0]);
  1734. }
  1735. // 合成电流
  1736. for(sw=0; sw<g_sw_num; sw++)
  1737. {
  1738. // IB
  1739. if(g_sw[sw].ui_flags&UI_FLAGS_MAKE_IB)
  1740. {
  1741. index = UI_SW_INDEX(sw,SW_AC_IB);
  1742. g_ui[index].ri.r = -g_ui[UI_SW_INDEX(sw,SW_AC_IA)].ri.r - g_ui[UI_SW_INDEX(sw,SW_AC_IC)].ri.r;
  1743. g_ui[index].ri.i = -g_ui[UI_SW_INDEX(sw,SW_AC_IA)].ri.i - g_ui[UI_SW_INDEX(sw,SW_AC_IC)].ri.i;
  1744. g_ui[index].m2[0] = SQR(g_ui[index].ri.r,g_ui[index].ri.i);
  1745. rt_stat_in(&g_ui[index].m2_stat,g_ui[index].m2[0]);
  1746. }
  1747. // I0
  1748. if(g_sw[sw].ui_flags&UI_FLAGS_MAKE_I0)
  1749. {
  1750. index = UI_SW_INDEX(sw,SW_AC_I0);
  1751. g_ui[index].ri.r = g_ui[UI_SW_INDEX(sw,SW_AC_IA)].ri.r + g_ui[UI_SW_INDEX(sw,SW_AC_IB)].ri.r + g_ui[UI_SW_INDEX(sw,SW_AC_IC)].ri.r;
  1752. g_ui[index].ri.i = g_ui[UI_SW_INDEX(sw,SW_AC_IA)].ri.i + g_ui[UI_SW_INDEX(sw,SW_AC_IB)].ri.i + g_ui[UI_SW_INDEX(sw,SW_AC_IC)].ri.i;
  1753. g_ui[index].m2[0] = SQR(g_ui[index].ri.r,g_ui[index].ri.i);
  1754. rt_stat_in(&g_ui[index].m2_stat,g_ui[index].m2[0]);
  1755. }
  1756. #ifdef FUN_JDXX
  1757. //计算零序有功无功
  1758. if(pRunSet->tSwSet[sw].bTT_Power_v2 == 0)
  1759. {
  1760. if(g_ui[PUB_AC_U01].chn_index != CFG_ADC_CHANNEL_ZERO)
  1761. {
  1762. if(g_ui[UI_SW_INDEX(sw,SW_AC_I0)].chn_index != CFG_ADC_CHANNEL_ZERO)
  1763. {
  1764. g_ui_p0[sw].p= _sw_p2(g_ui[PUB_AC_U01].ri.r,g_ui[PUB_AC_U01].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.i,g_ui[PUB_AC_U01].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].e_factor);
  1765. g_ui_p0[sw].q= _sw_q2(g_ui[PUB_AC_U01].ri.r,g_ui[PUB_AC_U01].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.i,g_ui[PUB_AC_U01].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].e_factor);
  1766. }
  1767. if(g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].chn_index != CFG_ADC_CHANNEL_ZERO)
  1768. {
  1769. g_ui_p0[sw].ps= _sw_p2(g_ui[PUB_AC_U01].ri.r,g_ui[PUB_AC_U01].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.i,g_ui[PUB_AC_U01].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].e_factor);
  1770. g_ui_p0[sw].qs= _sw_q2(g_ui[PUB_AC_U01].ri.r,g_ui[PUB_AC_U01].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.i,g_ui[PUB_AC_U01].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].e_factor);
  1771. }
  1772. }
  1773. else
  1774. {
  1775. g_ui_p0[sw].p=0;g_ui_p0[sw].q=0;
  1776. g_ui_p0[sw].ps=0;g_ui_p0[sw].qs=0;
  1777. }
  1778. }
  1779. else
  1780. {
  1781. if(g_ui[PUB_AC_U02].chn_index != CFG_ADC_CHANNEL_ZERO)
  1782. {
  1783. if(g_ui[UI_SW_INDEX(sw,SW_AC_I0)].chn_index != CFG_ADC_CHANNEL_ZERO)
  1784. {
  1785. g_ui_p0[sw].p= _sw_p2(g_ui[PUB_AC_U02].ri.r,g_ui[PUB_AC_U02].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.i,g_ui[PUB_AC_U02].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].e_factor);
  1786. g_ui_p0[sw].q= _sw_q2(g_ui[PUB_AC_U02].ri.r,g_ui[PUB_AC_U02].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].ri.i,g_ui[PUB_AC_U02].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0)].e_factor);
  1787. }
  1788. if(g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].chn_index != CFG_ADC_CHANNEL_ZERO)
  1789. {
  1790. g_ui_p0[sw].ps= _sw_p2(g_ui[PUB_AC_U02].ri.r,g_ui[PUB_AC_U02].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.i,g_ui[PUB_AC_U02].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].e_factor);
  1791. g_ui_p0[sw].qs= _sw_q2(g_ui[PUB_AC_U02].ri.r,g_ui[PUB_AC_U02].ri.i,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.r,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].ri.i,g_ui[PUB_AC_U02].e_factor,g_ui[UI_SW_INDEX(sw,SW_AC_I0s)].e_factor);
  1792. }
  1793. }
  1794. else
  1795. {
  1796. g_ui_p0[sw].p=0;g_ui_p0[sw].q=0;
  1797. g_ui_p0[sw].ps=0;g_ui_p0[sw].qs=0;
  1798. }
  1799. }
  1800. #endif
  1801. }
  1802. // 仅线电压需计算幅值
  1803. for(i=PUB_AC_UAB1; i<PUB_AC_NUM; i++)
  1804. {
  1805. g_ui[i].fz = _AmXY(g_ui[i].ri.r,g_ui[i].ri.i);
  1806. }
  1807. #ifdef FUNC_DRIVE_JY
  1808. drive_ui_proc();
  1809. #endif
  1810. // 计算最大最小值
  1811. _sw_min_max(PUB_AC_UA1,&g_sw_pub.m2_min[0],&g_sw_pub.m2_max[0]);
  1812. _sw_min_max(PUB_AC_UAB1,&g_sw_pub.m2_min[2],&g_sw_pub.m2_max[2]);
  1813. _sw_min_max(PUB_AC_UAB2,&g_sw_pub.m2_min[3],&g_sw_pub.m2_max[3]);
  1814. _fz_min_max(PUB_AC_UAB1,PUB_AC_UCA1,&g_sw_pub.fz_min[0],&g_sw_pub.fz_max[0]);
  1815. _fz_min_max(PUB_AC_UAB2,PUB_AC_UCA2,&g_sw_pub.fz_min[1],&g_sw_pub.fz_max[1]);
  1816. for(sw=0; sw<g_sw_num; sw++)
  1817. {
  1818. for(i=UI_SW_INDEX(sw,SW_AC_IA); i<=UI_SW_INDEX(sw,SW_AC_IC); i++)
  1819. {
  1820. g_ui[i].fz = _AmXY(g_ui[i].ri.r,g_ui[i].ri.i);
  1821. }
  1822. _sw_min_max(UI_SW_INDEX_BEGIN(sw),&g_sw[sw].m2_min,&g_sw[sw].m2_max);
  1823. _fz_min_max(UI_SW_INDEX(sw,SW_AC_IA),UI_SW_INDEX(sw,SW_AC_IC),&g_sw[sw].fz_min,&g_sw[sw].fz_max);
  1824. }
  1825. return;
  1826. }
  1827. /******************************************************************************
  1828. 函数名称: sw_cal_app
  1829. 函数版本: 01.01
  1830. 创建作者: sunxi
  1831. 创建日期: 2013-08-07
  1832. 函数说明: 在测量线程中计算测量值
  1833. 参数说明:
  1834. 返回值:
  1835. 修改记录:
  1836. */
  1837. void _sw_cal_zl(void);
  1838. int sw_cal_app(void )
  1839. {
  1840. _sw_temp_factor();
  1841. if(_sw_cal_mea() != 0)
  1842. {
  1843. return 0;
  1844. }
  1845. // 如果没有达到累计次数,直接返回。
  1846. g_mea_cnt++;
  1847. if(g_mea_cnt < MEA_CAL_NUMBER)
  1848. {
  1849. return 0;
  1850. }
  1851. g_mea_cnt = 0;
  1852. _sw_cal_average(MEA_CAL_NUMBER);
  1853. return 0;
  1854. }
  1855. void sw_factor_cp(void) //保存校正的系数,根据第一路电流的配置,是按CT默认100A校正还是51欧校正
  1856. {
  1857. bool b100A=false;
  1858. bool b50A=false;
  1859. bool b20A=false;
  1860. bool b10A=false;
  1861. int i;
  1862. for(i=0; i< g_equ_config->ac_num; i++)
  1863. {
  1864. if(g_equ_config_ac[i].owner ==1&&g_equ_config_ac[i].type==(SW_AC_IA+1)) // 根据开关1 IA的配置,保存相关的参数
  1865. {
  1866. if(g_equ_config_ac[i].scale==EQU_SCALE_CT_DEFAULT)
  1867. {
  1868. b100A=true;
  1869. }
  1870. if(g_equ_config_ac[i].scale==EQU_SCALE_CT_10A_51)
  1871. {
  1872. b50A=true;
  1873. }
  1874. if(g_equ_config_ac[i].scale==EQU_SCALE_CT_10A_249)
  1875. {
  1876. b20A=true;
  1877. }
  1878. if(g_equ_config_ac[i].scale==EQU_SCALE_CT_10A_120)
  1879. {
  1880. b10A=true;
  1881. }
  1882. if(b100A)
  1883. {
  1884. rt_file_cp("/app/data/acfactor.bin","/app/data/acfactor_100A.bin");
  1885. }
  1886. if(b50A)
  1887. {
  1888. rt_file_cp("/app/data/acfactor.bin","/app/data/acfactor_50A.bin");
  1889. }
  1890. if(b20A)
  1891. {
  1892. rt_file_cp("/app/data/acfactor.bin","/app/data/acfactor_20A.bin");
  1893. }
  1894. if(b10A)
  1895. {
  1896. rt_file_cp("/app/data/acfactor.bin","/app/data/acfactor_10A.bin");
  1897. }
  1898. return;
  1899. }
  1900. }
  1901. }
  1902. /******************************************************************************
  1903. 函数名称: sw_auto_adjust
  1904. 函数版本: 01.01
  1905. 创建作者: sunxi
  1906. 创建日期: 2013-08-07
  1907. 函数说明: 自动校准程序
  1908. U 100V,I 5A,
  1909. 参数说明:
  1910. 返回值:
  1911. 0: 成功
  1912. 其它: 失败
  1913. 修改记录:
  1914. */
  1915. struct pq_factor
  1916. {
  1917. int cfg_index;
  1918. float pq[2];
  1919. };
  1920. struct pq_factor g_pq_factor[SWITCH_NUM_MAX][3];
  1921. int sw_auto_adjust(int ui_angle0)
  1922. {
  1923. float baseAng;
  1924. int ret,i,j,sw;
  1925. int cfg_index;
  1926. float factor;
  1927. float fv;
  1928. float minfv,maxfv;
  1929. float baseValue ;
  1930. u16 base_v=0,base_i=0;
  1931. #ifdef PROTECT_AC_ADJUST
  1932. float fv_p;
  1933. #endif
  1934. g_mea_cnt= 0;
  1935. // 如果是单板测试,可能需要使用PUB_AC_UA2作为角度0参考
  1936. if(ui_angle0 != -1)
  1937. {
  1938. g_ui_angle0 = ui_angle0;
  1939. }
  1940. // 测量值复位
  1941. g_factor_version = ACFACTOR_FILE_VERSION;
  1942. for(i=0; i<UI_NUM; i++)
  1943. {
  1944. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  1945. {
  1946. continue;
  1947. }
  1948. g_ui[i].e_acc = 0;
  1949. g_ui[i].e = 0;
  1950. g_ui[i].p_acc = 0;
  1951. g_ui[i].p = 0;
  1952. g_ui[i].p_mark = 0;
  1953. g_ui[i].e_factor = 1.0/_sw_ui_e_k(i);
  1954. g_ui[i].p_factor = 0;
  1955. }
  1956. for(sw=0; sw<g_sw_num; sw++)
  1957. {
  1958. for(j=0; j<3; j++)
  1959. {
  1960. g_pq_factor[sw][j].cfg_index = -1;
  1961. g_pq_factor[sw][j].pq[0] = 0;
  1962. g_pq_factor[sw][j].pq[1] = 0;
  1963. }
  1964. }
  1965. sw_stat_reset();
  1966. // 测量AUTO_ADJUST_NUM次
  1967. for(i=0;i<AUTO_ADJUST_NUM;i++) // 计算多次幅值
  1968. {
  1969. watchdog_feed_mainloop();
  1970. // 得到采样点
  1971. _sw_get_dots();
  1972. // fft
  1973. _sw_cal_fft();
  1974. _sw_cal_ri_correct();
  1975. // 计算有效值
  1976. _sw_cal_effect();
  1977. // 计算角度
  1978. _sw_cal_angle();
  1979. // 延时20ms,并喂狗
  1980. #ifdef CPU_FUXI
  1981. msleep(30);
  1982. #else
  1983. ustimer_delay(20*USTIMER_MS);
  1984. #endif
  1985. watchdog_feed_mainloop();
  1986. }
  1987. _sw_cal_average(AUTO_ADJUST_NUM);
  1988. #if 0 //def PROTECT_AC_ADJUST
  1989. factor_restore_default();
  1990. ustimer_delay(20*USTIMER_MS);
  1991. #endif
  1992. for(i=0; i<UI_NUM; i++)
  1993. {
  1994. // 如果索引通道不存在,不需计算
  1995. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  1996. {
  1997. continue;
  1998. }
  1999. fv = (float)g_ui[i].e/Q16_BASE;
  2000. #ifdef PROTECT_AC_ADJUST
  2001. fv_p = (float)_Mul_Div_U(sqrt_32fix(g_ui[i].m2[0]), 256, g_ui[i].m2_factor_k)/(float)Q16_BASE;
  2002. #endif
  2003. // 确定通道配置索引和基本值
  2004. if(i<PUB_AC_NUM)
  2005. {
  2006. cfg_index = g_sw_pub.ac_cfg_index[i];
  2007. //if(g_equ_config_ac[cfg_index].scale == EQU_SCALE_EVT_3V25_100V)
  2008. //{
  2009. // 电子式相电压
  2010. // baseValue = 57.735;
  2011. //}
  2012. /*
  2013. else if(g_equ_config_ac[cfg_index].scale == EQU_SCALE_EVT_6V50_100V)
  2014. {
  2015. // 电子式零序电压,为了校验方便,使用C相电压,换算零序为此值。
  2016. baseValue = 28.86751346;
  2017. }
  2018. */
  2019. // 自适应电压校准
  2020. if(fv > 200) // 220
  2021. {
  2022. // 220V额定电压
  2023. baseValue = 220; //
  2024. }
  2025. else if (fv > (120.0*1.732)) // 207.84
  2026. {
  2027. // 130V相电压合成线电压校准
  2028. // 因为罩式控制器在用100V校准时,PT切换不断的响,
  2029. // 130V相电压可得到225V电源,可避免PT切换的异响
  2030. baseValue = 130*1.732; // 225.16
  2031. }
  2032. else if(fv > 90*1.732) // 155.88
  2033. {
  2034. // 100V相电压合成线电压校准
  2035. baseValue = 100*1.732; // 173.2
  2036. }
  2037. else if (fv > 120.0) // 120
  2038. {
  2039. // 130V 相电压校准
  2040. baseValue = 130; // 130
  2041. }
  2042. else if(fv > 90.0)
  2043. {
  2044. // 100V 相电压校准
  2045. baseValue = 100; // 100
  2046. }
  2047. else if(fv > 50.0)
  2048. {
  2049. // 100V 相电压校准
  2050. baseValue = 57.735; // 57.735
  2051. }
  2052. else if(fv > 16.0)
  2053. {
  2054. // 100V 相电压校准
  2055. baseValue = 20; // 20
  2056. }
  2057. else if(fv > 8.0)
  2058. {
  2059. // 10V 相电压校准
  2060. baseValue = 10; // 10
  2061. }
  2062. else if(fv > 6.0)
  2063. {
  2064. baseValue =6.5;
  2065. }
  2066. else if(fv > 2.0)
  2067. {
  2068. // 10V 相电压校准
  2069. baseValue = 3; // 10
  2070. }
  2071. else if(fv > 1.5)
  2072. {
  2073. baseValue = 1.8763875;
  2074. }
  2075. else
  2076. {
  2077. // 57.735V 相电压校准
  2078. baseValue = 57.735; // 57.735
  2079. }
  2080. }
  2081. else
  2082. {
  2083. sw = (i - PUB_AC_NUM)/SW_AC_NUM;
  2084. j = (i - PUB_AC_NUM)%SW_AC_NUM;
  2085. cfg_index = g_sw[sw].ac_cfg_index[j];
  2086. // 电子式互感器I0使用5A校准
  2087. // if(g_equ_config_ac[cfg_index].scale == EQU_SCALE_ECT_1V_1A
  2088. // || g_equ_config_ac[cfg_index].scale == EQU_SCALE_ECT_0V2_1A)
  2089. if(g_equ_config_ac[cfg_index].scale == EQU_SCALE_ECT_1V_1A)
  2090. {
  2091. // 电子式CT使用1A。
  2092. baseValue = 1;
  2093. }
  2094. else if(g_equ_config_ac[cfg_index].scale == EQU_SCALE_CT_10A_249)
  2095. {
  2096. // 高精度零序电流互感器,小信号校正值
  2097. baseValue = 0.5;
  2098. }
  2099. else if(fv > 4)
  2100. {
  2101. baseValue=5;
  2102. }
  2103. else if(fv > 2)
  2104. {
  2105. // 大容量校准时,例如16回路,标准源可能带不动5A负载。
  2106. baseValue=3;
  2107. }
  2108. else
  2109. {
  2110. baseValue=1;
  2111. }
  2112. }
  2113. minfv=baseValue*0.9;
  2114. maxfv=baseValue*1.1;
  2115. // 检查幅值是否超范围
  2116. if(fv<minfv)
  2117. {
  2118. rt_printf("sw_auto_adjust(invalid):i=%d,fv=%f,minfv=%f\r\n",i,fv ,minfv);
  2119. continue;
  2120. }
  2121. else if(fv>maxfv)
  2122. {
  2123. rt_printf("sw_auto_adjust(err):i=%d,fv=%f,maxfv=%f\r\n",i,fv ,maxfv);
  2124. return -1;
  2125. }
  2126. // 得到并检查校正系数
  2127. factor=baseValue/fv;
  2128. if(CheckFloatSet(&factor,MAX_FACTOR,MIN_FACTOR)>0)
  2129. {
  2130. rt_printf("sw_auto_adjust(err):i=%d,fv=%f,factor=%f.\r\n",i,fv ,factor);
  2131. return -2;
  2132. }
  2133. // 保存校正系数
  2134. factor_e_c_set(g_equ_config_ac[cfg_index].slot,g_equ_config_ac[cfg_index].index,factor);
  2135. #ifdef PROTECT_AC_ADJUST
  2136. factor=baseValue/fv_p;
  2137. rt_printf("fv_p=%f,baseValue=%f,factor=%f\r\n",fv_p, baseValue, factor);
  2138. if(CheckFloatSet(&factor,MAX_FACTOR,MIN_FACTOR)>0)
  2139. {
  2140. rt_printf("sw_auto_adjust(err) protect ac:i=%d,fv=%f,factor_p=%f.\r\n",i,fv ,factor);
  2141. return -2;
  2142. }
  2143. // 保存校正系数
  2144. factor_p_e_c_set(g_equ_config_ac[cfg_index].slot,g_equ_config_ac[cfg_index].index,factor);
  2145. #endif
  2146. // 保存校正成功配置通道值
  2147. if(i >= PUB_AC_NUM)
  2148. {
  2149. g_pq_factor[sw][j].cfg_index = cfg_index;
  2150. }
  2151. // 角度校准
  2152. baseAng =_sw_base_angle(i);
  2153. fv = (float)g_ui[i].p/Q16_BASE;
  2154. if(baseAng == 360.0)
  2155. {
  2156. factor = 0;
  2157. }
  2158. else
  2159. {
  2160. factor = baseAng - fv;
  2161. }
  2162. // 确保角度在正负180内。
  2163. if(factor > 180.0)
  2164. {
  2165. factor -= 360.0;
  2166. }
  2167. if(factor < -180.0)
  2168. {
  2169. factor += 360.0;
  2170. }
  2171. rt_printf("sw_auto_adjust(ang):i=%d,fv=%f,factor=%f.\r\n",i,fv ,factor);
  2172. if(factor<MIN_PHASE)
  2173. {
  2174. return -3;
  2175. }
  2176. else if(factor>MAX_PHASE)
  2177. {
  2178. return -4;
  2179. }
  2180. if(CheckFloatSet(&factor,MAX_PHASE,MIN_PHASE)>0)
  2181. {
  2182. return -5;
  2183. }
  2184. // 如果是基准通道,就不更新角度校准值。
  2185. if(i != g_ui_angle0)
  2186. {
  2187. factor_p_c_set(g_equ_config_ac[cfg_index].slot,g_equ_config_ac[cfg_index].index,factor);
  2188. }
  2189. // 保存校正温度和基准值
  2190. factor_temp_set(g_equ_config_ac[cfg_index].slot,
  2191. #if defined TMP_CHIP_DS18B20
  2192. ds18b20_get_temp()
  2193. #elif defined TMP_CHIP_GX21M15
  2194. gx21m15_get_temp()
  2195. #endif
  2196. );
  2197. if(i < PUB_AC_NUM)
  2198. {
  2199. base_v = baseValue;
  2200. }
  2201. else
  2202. {
  2203. base_i = baseValue;
  2204. }
  2205. }
  2206. // 重新初始化
  2207. sw_init();
  2208. //保存校正系数
  2209. ret = factor_write_all(base_v,base_i);
  2210. if(ret != 0)
  2211. {
  2212. return -6;
  2213. }
  2214. sw_factor_cp();
  2215. soe_record_opt(EV_CHNZJS, 0);
  2216. return 0;
  2217. }
  2218. float g_dc_factor[2][2]=
  2219. {
  2220. {1.0,1.0},
  2221. {1.0,1.0},
  2222. };
  2223. int sw_adjust_dc_0(void)
  2224. {
  2225. int i;
  2226. float dc;
  2227. #ifdef DC_NUM_SET
  2228. for(i=0;i<pRunSet->dDc_num;i++)
  2229. #else
  2230. for(i=0;i<DC_NUM;i++)
  2231. #endif
  2232. {
  2233. dc = dc_get(i);
  2234. if(dc < 0.5*dc_adjust[0])
  2235. {
  2236. return -1;
  2237. }
  2238. if(dc > 1.5*dc_adjust[0])
  2239. {
  2240. return -2;
  2241. }
  2242. g_dc_factor[i][0] = dc;
  2243. }
  2244. return 0;
  2245. }
  2246. int sw_adjust_dc_1(void)
  2247. {
  2248. int i;
  2249. float dc;
  2250. #ifdef DC_NUM_SET
  2251. for(i=0;i<pRunSet->dDc_num;i++)
  2252. #else
  2253. for(i=0;i<DC_NUM;i++)
  2254. #endif
  2255. {
  2256. dc = dc_get(i);
  2257. if(dc < 0.5*dc_adjust[1])
  2258. {
  2259. return -1;
  2260. }
  2261. if(dc > 1.5*dc_adjust[1])
  2262. {
  2263. return -2;
  2264. }
  2265. g_dc_factor[i][1] = dc;
  2266. }
  2267. _sw_save_dc_factor(g_dc_factor[0][1], g_dc_factor[0][0], g_dc_factor[1][1], g_dc_factor[1][0]);
  2268. return 0;
  2269. }
  2270. /*------------------------------ 内部函数 -------------------------------------
  2271. 内部函数以下划线‘_’开头,不需要检查参数的合法性.
  2272. */
  2273. /******************************************************************************
  2274. 函数名称: _sw_get_dots
  2275. 函数版本: 01.01
  2276. 创建作者: sunxi
  2277. 创建日期: 2013-08-07
  2278. 函数说明: 获取采样点,供测量计算用
  2279. 参数说明:
  2280. 返回值:
  2281. 修改记录:
  2282. */
  2283. void xdl_smooth3 ( short in[], short out[], int N );
  2284. void xdl_smooth5 ( short in[], short out[], int N );
  2285. int _sw_check_tb_dots(unsigned long dot_index)
  2286. {
  2287. int i,j;
  2288. if(pRunSet->dSmoothZero==0)return 0;
  2289. for(i=0;i<CFG_ADC_CHANNEL;i++)
  2290. {
  2291. short pnSam[3] = {0};
  2292. long laaa;
  2293. DWORD daaa;
  2294. int caulp;
  2295. if(!g_equ_adc_config[i]) // 通道无配置
  2296. {
  2297. continue;
  2298. }
  2299. for(j=0;j<CFG_ADC_DOTS_PER_PERIOD;j++)
  2300. {
  2301. caulp = (dot_index+j)&CFG_ADC_DOTS_MASK;
  2302. // 取出连续三周波的同一对应点
  2303. pnSam[0] = g_adc_dots[i][(caulp - 1) & SAMLENGTH];
  2304. pnSam[1] = g_adc_dots[i][(caulp - SAMFREQ -1) & SAMLENGTH];
  2305. pnSam[2] = g_adc_dots[i][(caulp - 2*SAMFREQ -1) & SAMLENGTH];
  2306. // 计算突变量并取绝对值,i(k)-2*i(k-N)+i(K-2N)
  2307. laaa = ( pnSam[0] - pnSam[1]*2 + pnSam[2]);
  2308. if(laaa < 0)
  2309. {
  2310. daaa = -laaa;//
  2311. }
  2312. else
  2313. {
  2314. daaa = laaa;
  2315. }
  2316. // 检查是否超过突变量门槛,且需满足3次,即对应相电流突变量满足要求
  2317. if(daaa > pRunSet->dSmoothZero)
  2318. {
  2319. rt_printf("\r\n chnel=%d zero=%d set=%d",i,daaa,pRunSet->dSmoothZero);
  2320. return -1;
  2321. }
  2322. }
  2323. }
  2324. return 0;
  2325. }
  2326. void _sw_get_dots(void)
  2327. {
  2328. unsigned long i,loop,dots_index ,dots_count_old;
  2329. int cnt;
  2330. int ret=0;
  2331. loop =0;
  2332. do
  2333. {
  2334. // 获取采样点的位置,如果最后一个周波跨界,调整采样点的位置。
  2335. #ifdef CPU_FUXI
  2336. dots_count_old = g_adc_dots_index - CFG_ADC_DOTS_PER_PERIOD; //jack.liu 20200921 获取最后一个周波的采样点
  2337. #else
  2338. dots_count_old = g_adc_dots_count - CFG_ADC_DOTS_PER_PERIOD; // 最后一个周波的采样点
  2339. #endif
  2340. cnt = (dots_count_old&CFG_ADC_DOTS_MASK) - (CFG_ADC_DOTS_PER_CHANNEL - CFG_ADC_DOTS_PER_PERIOD);
  2341. if(cnt > 0)
  2342. {
  2343. dots_count_old -= cnt;
  2344. }
  2345. dots_index = dots_count_old&CFG_ADC_DOTS_MASK;
  2346. ret=_sw_check_tb_dots(dots_index);
  2347. if(ret<0)return; // 波形判断有突变,不处理采样
  2348. for(i=0;i<CFG_ADC_CHANNEL;i++)
  2349. {
  2350. #if 0
  2351. if(g_equ_adc_config[i])
  2352. {
  2353. xdl_smooth3(&g_adc_dots[i][dots_index],&g_adc_dots[i][CFG_ADC_DOTS_PER_CHANNEL],CFG_ADC_DOTS_PER_PERIOD);
  2354. }
  2355. #else
  2356. memcpy(&g_adc_dots[i][CFG_ADC_DOTS_PER_CHANNEL],&g_adc_dots[i][dots_index],CFG_ADC_DOTS_PER_PERIOD*2);
  2357. #endif
  2358. }
  2359. loop++;
  2360. if(loop > 5)
  2361. {
  2362. rt_printf("sw_get_dots:i=%d\r\n",loop);
  2363. }
  2364. }
  2365. #ifdef CPU_FUXI
  2366. while((g_adc_dots_index - dots_count_old) > CFG_ADC_DOTS_PER_CHANNEL);
  2367. #else
  2368. while((g_adc_dots_count - dots_count_old) > CFG_ADC_DOTS_PER_CHANNEL);
  2369. #endif
  2370. }
  2371. /******************************************************************************
  2372. 函数名称: _sw_fft
  2373. 函数版本: 01.01
  2374. 创建作者: sunxi
  2375. 创建日期: 2013-08-07
  2376. 函数说明: 计算FFT,一次计算两个通道
  2377. 参数说明:
  2378. ch0 通道0索引
  2379. ch1 通道1索引
  2380. p0 通道0结果,所有谐波的复数表示。
  2381. p1 通道1结果,所有谐波的复数表示。
  2382. 返回值:
  2383. 修改记录:
  2384. */
  2385. void _sw_fft(int ch0,int ch1,complex * p0,complex * p1)
  2386. {
  2387. static complex k[CFG_ADC_DOTS_PER_PERIOD];
  2388. int i;
  2389. // 初始化点
  2390. for(i=0; i<CFG_ADC_DOTS_PER_PERIOD; i++)
  2391. {
  2392. k[i].r = g_adc_dots[ch0][CFG_ADC_DOTS_PER_CHANNEL + i];
  2393. k[i].i = g_adc_dots[ch1][CFG_ADC_DOTS_PER_CHANNEL + i];
  2394. }
  2395. // 计算
  2396. fft(CFG_ADC_DOTS_PER_PERIOD, &k[0]);
  2397. // 整理
  2398. for (i=1;i<=g_harmonic_num;i++)
  2399. {
  2400. if(p0)
  2401. {
  2402. p0[i].r = (k[i].r+k[CFG_ADC_DOTS_PER_PERIOD-i].r)/CFG_ADC_DOTS_PER_PERIOD;
  2403. p0[i].i = (k[i].i-k[CFG_ADC_DOTS_PER_PERIOD-i].i)/CFG_ADC_DOTS_PER_PERIOD;
  2404. }
  2405. if(p1)
  2406. {
  2407. p1[i].r = (k[i].i+k[CFG_ADC_DOTS_PER_PERIOD-i].i)/CFG_ADC_DOTS_PER_PERIOD;
  2408. p1[i].i = (k[CFG_ADC_DOTS_PER_PERIOD-i].r-k[i].r)/CFG_ADC_DOTS_PER_PERIOD;
  2409. }
  2410. }
  2411. }
  2412. /******************************************************************************
  2413. 函数名称: _sw_cal_fft
  2414. 函数版本: 01.01
  2415. 创建作者: sunxi
  2416. 创建日期: 2013-08-07
  2417. 函数说明: 计算所有通道的FFT
  2418. 参数说明:
  2419. 返回值:
  2420. 修改记录:
  2421. */
  2422. void _sw_cal_fft(void)
  2423. {
  2424. s32 i,index0;
  2425. // fft
  2426. index0 = UI_NUM;
  2427. for(i=0;i<UI_NUM;i++)
  2428. {
  2429. // 如果索引通道不存在,不需计算
  2430. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  2431. {
  2432. continue;
  2433. }
  2434. // 检查硬件通道是否正常,如果不正常,ri清零;否则计算出ri。
  2435. if(equ_ac_channel_is_ok(g_ui[i].chn_index) == 0)
  2436. {
  2437. memset(&g_ui[i].h,0,sizeof(g_ui[i].h));
  2438. continue;
  2439. }
  2440. if(index0 == UI_NUM)
  2441. {
  2442. index0 = i;
  2443. }
  2444. else
  2445. {
  2446. _sw_fft(g_ui[index0].chn_index,g_ui[i].chn_index,g_ui[index0].h,g_ui[i].h);
  2447. index0 = UI_NUM;
  2448. }
  2449. }
  2450. if(index0 != UI_NUM)
  2451. {
  2452. _sw_fft(g_ui[index0].chn_index,g_ui[index0].chn_index,g_ui[index0].h,NULL);
  2453. }
  2454. return;
  2455. }
  2456. /******************************************************************************
  2457. 函数名称: _sw_cal_h_sub
  2458. 函数版本: 01.01
  2459. 创建作者: sunxi
  2460. 创建日期: 2013-08-07
  2461. 函数说明: 2个谐波向量减
  2462. 参数说明:
  2463. r 结果
  2464. a 向量a的g_ui索引
  2465. b 向量b的g_ui索引
  2466. 返回值:
  2467. 修改记录:
  2468. */
  2469. void _sw_cal_h_sub(int r,int a,int b)
  2470. {
  2471. int i;
  2472. for(i=1;i<=g_harmonic_num;i++)
  2473. {
  2474. g_ui[r].h[i].r = g_ui[a].h[i].r - g_ui[b].h[i].r;
  2475. g_ui[r].h[i].i = g_ui[a].h[i].i - g_ui[b].h[i].i;
  2476. }
  2477. return;
  2478. }
  2479. /******************************************************************************
  2480. 函数名称: _sw_cal_h_sub2
  2481. 函数版本: 01.01
  2482. 创建作者: sunxi
  2483. 创建日期: 2013-08-07
  2484. 函数说明: 谐波向量减,求Ib
  2485. 参数说明:
  2486. r 结果
  2487. o 向量o的g_ui索引
  2488. a 向量a的g_ui索引
  2489. b 向量b的g_ui索引
  2490. 返回值:
  2491. 修改记录:
  2492. */
  2493. void _sw_cal_h_sub2(int r,int o,int a,int b)
  2494. {
  2495. int i;
  2496. float factor_i0_ia=1.0;
  2497. if((g_ui[o].m2_factor_k!=0)&&(g_ui[o].m2_factor_k!=g_ui[a].m2_factor_k))
  2498. {
  2499. factor_i0_ia=(float)g_ui[a].m2_factor_k/g_ui[o].m2_factor_k;
  2500. }
  2501. for(i=1;i<=g_harmonic_num;i++)
  2502. {
  2503. g_ui[r].h[i].r = g_ui[o].h[i].r*factor_i0_ia - g_ui[a].h[i].r - g_ui[b].h[i].r;
  2504. g_ui[r].h[i].i = g_ui[o].h[i].i *factor_i0_ia- g_ui[a].h[i].i - g_ui[b].h[i].i;
  2505. }
  2506. return;
  2507. }
  2508. /******************************************************************************
  2509. 函数名称: _sw_cal_h_add
  2510. 函数版本: 01.01
  2511. 创建作者: sunxi
  2512. 创建日期: 2013-08-07
  2513. 函数说明: 3个谐波向量加
  2514. 参数说明:
  2515. r 结果
  2516. a 向量a的g_ui索引
  2517. b 向量b的g_ui索引
  2518. c 向量c的g_ui索引
  2519. 返回值:
  2520. 修改记录:
  2521. */
  2522. void _sw_cal_h_add(int r,int a,int b,int c)
  2523. {
  2524. int i;
  2525. for(i=1;i<=g_harmonic_num;i++)
  2526. {
  2527. g_ui[r].h[i].r = g_ui[a].h[i].r + g_ui[b].h[i].r + g_ui[c].h[i].r;
  2528. g_ui[r].h[i].i = g_ui[a].h[i].i + g_ui[b].h[i].i + g_ui[c].h[i].i;
  2529. }
  2530. return;
  2531. }
  2532. /******************************************************************************
  2533. 函数名称: _sw_cal_ri_correct
  2534. 函数版本: 01.01
  2535. 创建作者: sunxi
  2536. 创建日期: 2013-08-07
  2537. 函数说明: 根据角度误差校正向量值
  2538. 参数说明:
  2539. 返回值:
  2540. 修改记录:
  2541. */
  2542. void _sw_cal_ri_correct(void)
  2543. {
  2544. s32 i,j;
  2545. qs08 angle;
  2546. qs16 lncos,lnsin,v;
  2547. struct ri_s32 ri;
  2548. for(i=0;i<UI_NUM;i++)
  2549. {
  2550. // 如果索引通道不存在,不需计算
  2551. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  2552. {
  2553. continue;
  2554. }
  2555. // 根据频率修正角度校正值,提高频率变化时的功率精度。
  2556. angle = rt_round((g_ui[i].p_factor + factor_p_k(g_ui[i].chn_index))*256);
  2557. for(j=1;j<=g_harmonic_num;j++)
  2558. {
  2559. lncos = mCos(angle*j);
  2560. lnsin = mSin(angle*j);
  2561. ri.r = rt_round(g_ui[i].h[j].r * Q16_BASE);
  2562. ri.i = rt_round(g_ui[i].h[j].i * Q16_BASE);
  2563. v = _MulFac_S(ri.r,lncos) - _MulFac_S(ri.i,lnsin);
  2564. g_ui[i].h[j].r = (float)v/Q16_BASE;
  2565. v = _MulFac_S(ri.r,lnsin) + _MulFac_S(ri.i,lncos);
  2566. g_ui[i].h[j].i = (float)v/Q16_BASE;
  2567. }
  2568. }
  2569. }
  2570. /******************************************************************************
  2571. 函数名称: _sw_cal_unbalance
  2572. 函数版本: 01.01
  2573. 创建作者: sunxi
  2574. 创建日期: 2013-08-07
  2575. 函数说明: 不平衡度计算
  2576. 参数说明:
  2577. 返回值:
  2578. 修改记录:
  2579. */
  2580. #ifdef asdfadasdfa
  2581. void CalcuIx120( struct UI *pI, struct UI120 *pII )
  2582. {
  2583. long labc,lbc;
  2584. labc = pI->lIaR - (( pI->lIbR + pI->lIcR )>>1);
  2585. lbc = pI->lIbI - pI->lIcI;
  2586. lbc =_MulFac_S(lbc, 56756);//(1.732/2)*2^16=56756
  2587. pII->l1Cos = labc - lbc;
  2588. pII->l2Cos = labc + lbc;
  2589. labc = pI->lIaI - ( (pI->lIbI + pI->lIcI )>>1);
  2590. lbc = pI->lIbR - pI->lIcR;
  2591. lbc =_MulFac_S(lbc,56756);//(1.732/2)*2^16=56756
  2592. pII->l1Sin = labc + lbc;
  2593. pII->l2Sin = labc - lbc;
  2594. pII->l0Cos = pI->lIaR + pI->lIbR + pI->lIcR;
  2595. pII->l0Sin = pI->lIaI + pI->lIbI + pI->lIcI;
  2596. pII->d1Modu = SQR( pII->l1Cos, pII->l1Sin );
  2597. pII->d2Modu = SQR( pII->l2Cos, pII->l2Sin );
  2598. pII->d0Modu = SQR( pII->l0Cos, pII->l0Sin );
  2599. }
  2600. #endif
  2601. float _sw_cal_unbalance(int ui_index)
  2602. {
  2603. float abc,bc;
  2604. float r1,r2,i1,i2;
  2605. abc = g_ui[ui_index].h[1].r - (g_ui[ui_index+1].h[1].r + g_ui[ui_index+2].h[1].r)/2;
  2606. bc = g_ui[ui_index+1].h[1].i - g_ui[ui_index+2].h[1].i;
  2607. bc = bc * (1.7320508/2);
  2608. r1 = abc - bc;
  2609. r2 = abc + bc;
  2610. abc = g_ui[ui_index].h[1].i - (g_ui[ui_index+1].h[1].i + g_ui[ui_index+2].h[1].i)/2;
  2611. bc = g_ui[ui_index+1].h[1].r - g_ui[ui_index+2].h[1].r;
  2612. bc = bc * (1.7320508/2);
  2613. i1 = abc + bc;
  2614. i2 = abc - bc;
  2615. abc = sqrtf(r1*r1 + i1*i1);
  2616. bc = sqrtf(r2*r2 + i2*i2);
  2617. //rt_printf("%s\tabc=%f,\tbc=%f.\r\n",g_ui[ui_index].name,abc*g_ui[ui_index].e_factor,bc*g_ui[ui_index].e_factor);
  2618. if(abc == 0.0)
  2619. {
  2620. return 100;
  2621. }
  2622. return bc/abc*100;
  2623. }
  2624. /******************************************************************************
  2625. 函数名称: _sw_cal_unbalance
  2626. 函数版本: 01.01
  2627. 创建作者: sunxi
  2628. 创建日期: 2013-08-07
  2629. 函数说明: 正负序计算
  2630. 参数说明:
  2631. 返回值:
  2632. 修改记录:
  2633. */
  2634. void _sw_cal_Xfl120( int ui_index, struct ui120 *pII )
  2635. {
  2636. float abc,bc;
  2637. float r1,r2,i1,i2;
  2638. abc = g_ui[ui_index].ri.r - (g_ui[ui_index+1].ri.r + g_ui[ui_index+2].ri.r)/2;
  2639. bc = g_ui[ui_index+1].ri.i - g_ui[ui_index+2].ri.i;
  2640. bc = bc * (1.7320508/2);
  2641. r1 = abc - bc;
  2642. r2 = abc + bc;
  2643. abc = g_ui[ui_index].ri.i - (g_ui[ui_index+1].ri.i + g_ui[ui_index+2].ri.i)/2;
  2644. bc = g_ui[ui_index+1].ri.r - g_ui[ui_index+2].ri.r;
  2645. bc = bc * (1.7320508/2);
  2646. i1 = abc + bc;
  2647. i2 = abc - bc;
  2648. pII->vect1 = (r1*r1 + i1*i1)/9;
  2649. pII->vect2 = (r2*r2 + i2*i2)/9;
  2650. }
  2651. /******************************************************************************
  2652. 函数名称: _sw_cal_make
  2653. 函数版本: 01.01
  2654. 创建作者: sunxi
  2655. 创建日期: 2013-08-07
  2656. 函数说明: 测量合成通道向量值
  2657. 参数说明:
  2658. 返回值:
  2659. 修改记录:
  2660. */
  2661. void _sw_cal_make(void)
  2662. {
  2663. int sw ;
  2664. // 合成电压
  2665. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_LV1)
  2666. {
  2667. _sw_cal_h_sub(PUB_AC_UAB1,PUB_AC_UA1,PUB_AC_UB1);
  2668. _sw_cal_h_sub(PUB_AC_UBC1,PUB_AC_UB1,PUB_AC_UC1);
  2669. _sw_cal_h_sub(PUB_AC_UCA1,PUB_AC_UC1,PUB_AC_UA1);
  2670. }
  2671. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_LV2)
  2672. {
  2673. _sw_cal_h_sub(PUB_AC_UAB2,PUB_AC_UA2,PUB_AC_UB2);
  2674. _sw_cal_h_sub(PUB_AC_UBC2,PUB_AC_UB2,PUB_AC_UC2);
  2675. _sw_cal_h_sub(PUB_AC_UCA2,PUB_AC_UC2,PUB_AC_UA2);
  2676. }
  2677. // 合成UCA
  2678. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_UCA1)
  2679. {
  2680. {
  2681. int i;
  2682. for(i=1;i<=g_harmonic_num;i++)
  2683. {
  2684. g_ui[PUB_AC_UCA1].h[i].r = -g_ui[PUB_AC_UAB1].h[i].r - g_ui[PUB_AC_UBC1].h[i].r;
  2685. g_ui[PUB_AC_UCA1].h[i].i = -g_ui[PUB_AC_UAB1].h[i].i - g_ui[PUB_AC_UBC1].h[i].i;
  2686. }
  2687. }
  2688. }
  2689. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_UCA2)
  2690. {
  2691. {
  2692. int i;
  2693. for(i=1;i<=g_harmonic_num;i++)
  2694. {
  2695. g_ui[PUB_AC_UCA2].h[i].r = -g_ui[PUB_AC_UAB2].h[i].r - g_ui[PUB_AC_UBC2].h[i].r;
  2696. g_ui[PUB_AC_UCA2].h[i].i = -g_ui[PUB_AC_UAB2].h[i].i - g_ui[PUB_AC_UBC2].h[i].i;
  2697. }
  2698. }
  2699. }
  2700. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_U01)
  2701. {
  2702. {
  2703. int i;
  2704. for(i=1;i<=g_harmonic_num;i++)
  2705. {
  2706. g_ui[PUB_AC_U01].h[i].r = g_ui[PUB_AC_UA1].h[i].r + g_ui[PUB_AC_UB1].h[i].r+ g_ui[PUB_AC_UC1].h[i].r;
  2707. g_ui[PUB_AC_U01].h[i].i = g_ui[PUB_AC_UA1].h[i].i + g_ui[PUB_AC_UB1].h[i].i+ g_ui[PUB_AC_UC1].h[i].i;
  2708. }
  2709. }
  2710. }
  2711. if(g_sw_pub.ui_flags&UI_FLAGS_MAKE_U02)
  2712. {
  2713. {
  2714. int i;
  2715. for(i=1;i<=g_harmonic_num;i++)
  2716. {
  2717. g_ui[PUB_AC_U02].h[i].r = g_ui[PUB_AC_UA2].h[i].r + g_ui[PUB_AC_UB2].h[i].r+ g_ui[PUB_AC_UC2].h[i].r;
  2718. g_ui[PUB_AC_U02].h[i].i = g_ui[PUB_AC_UA2].h[i].i + g_ui[PUB_AC_UB2].h[i].i+ g_ui[PUB_AC_UC2].h[i].i;
  2719. }
  2720. }
  2721. }
  2722. // 电压不平衡计算
  2723. g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE1] += _sw_cal_unbalance(PUB_AC_UA1);
  2724. g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE2] += _sw_cal_unbalance(PUB_AC_UA2);
  2725. // 开关电流
  2726. for(sw=0; sw<g_sw_num; sw++)
  2727. {
  2728. // 合成电流IB
  2729. if(g_sw[sw].ui_flags&UI_FLAGS_MAKE_IB)
  2730. {
  2731. _sw_cal_h_sub2(UI_SW_INDEX(sw,SW_AC_IB),UI_SW_INDEX(sw,SW_AC_I0),UI_SW_INDEX(sw,SW_AC_IA),UI_SW_INDEX(sw,SW_AC_IC));
  2732. }
  2733. // 合成电流IB
  2734. if(g_sw[sw].ui_flags&UI_FLAGS_MAKE_CIB)
  2735. {
  2736. _sw_cal_h_sub2(UI_SW_INDEX(sw,SW_AC_CIB),UI_SW_INDEX(sw,SW_AC_I0),UI_SW_INDEX(sw,SW_AC_CIA),UI_SW_INDEX(sw,SW_AC_CIC));
  2737. }
  2738. // 合成电流I0
  2739. if(g_sw[sw].ui_flags&UI_FLAGS_MAKE_I0)
  2740. {
  2741. _sw_cal_h_add(UI_SW_INDEX(sw,SW_AC_I0),UI_SW_INDEX(sw,SW_AC_IA),UI_SW_INDEX(sw,SW_AC_IB),UI_SW_INDEX(sw,SW_AC_IC));
  2742. }
  2743. // 电流不平衡计算
  2744. g_sw[sw].ac_in_acc[SW_AC_IN_BI_UNBALANCE] += _sw_cal_unbalance(UI_SW_INDEX(sw,SW_AC_IA));
  2745. // 电流不平衡计算
  2746. g_sw[sw].ac_in_acc[SW_AC_IN_CI_UNBALANCE] += _sw_cal_unbalance(UI_SW_INDEX(sw,SW_AC_CIA));
  2747. }
  2748. }
  2749. /******************************************************************************
  2750. 函数名称: _sw_cal_effect
  2751. 函数版本: 01.01
  2752. 创建作者: sunxi
  2753. 创建日期: 2013-08-07
  2754. 函数说明: 测量计算有效值,累加结果。
  2755. 参数说明:
  2756. 返回值:
  2757. 修改记录:
  2758. */
  2759. void _sw_cal_effect(void)
  2760. {
  2761. int i,j;
  2762. float f,re,im,sum;
  2763. for(i=0;i<UI_NUM;i++)
  2764. {
  2765. // 如果索引通道不存在,不需计算
  2766. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[i].ui_base_make == -1)
  2767. {
  2768. continue;
  2769. }
  2770. sum = 0.0;
  2771. for(j=1;j<=g_harmonic_num;j++)
  2772. {
  2773. re = g_ui[i].h[j].r;
  2774. im = g_ui[i].h[j].i;
  2775. f = sqrtf(re*re+im*im);
  2776. f *= g_harmonic_factor[j]; // 谐波系数修正
  2777. sum += f*f;
  2778. #if 0
  2779. if(i>=UI_SW_INDEX(1,SW_AC_IA) && i<=UI_SW_INDEX(1,SW_AC_I0))
  2780. {
  2781. rt_printf("%s[%02d]:e=%f,p=%f.\r\n",g_ui[i].name,j,f*g_ui[i].e_factor,_sw_cal_angle0(re,im));
  2782. }
  2783. #endif
  2784. }
  2785. f = sqrtf(sum);
  2786. g_ui[i].e_acc += f*g_ui[i].e_factor ;
  2787. }
  2788. return ;
  2789. }
  2790. /******************************************************************************
  2791. 函数名称: _sw_cal_angle0
  2792. 函数版本: 01.01
  2793. 创建作者: sunxi
  2794. 创建日期: 2013-08-07
  2795. 函数说明: 计算向量角度
  2796. 参数说明:
  2797. re 向量实部
  2798. im 向量虚部
  2799. 返回值:
  2800. 修改记录:
  2801. */
  2802. #if 1
  2803. float _sw_cal_angle0(float re, float im)
  2804. {
  2805. float p;
  2806. p = atan2f(im,re);
  2807. p = p*180/pi;
  2808. return p;
  2809. }
  2810. #else
  2811. const int Angle_const[7] =
  2812. {
  2813. 0,267,577,1000,1732,3732,57400
  2814. };
  2815. float _sw_cal_angle0(float re, float im)
  2816. {
  2817. float angle_arttg;
  2818. float angle = 0;
  2819. uint8 quad;
  2820. if (re >=0)
  2821. {
  2822. if (im >=0)
  2823. quad = 1;
  2824. else
  2825. {
  2826. quad = 4;
  2827. im = im*(-1);
  2828. }
  2829. }
  2830. else
  2831. {
  2832. re = re*(-1);
  2833. if (im >= 0)
  2834. quad = 2;
  2835. else
  2836. {
  2837. im = im*(-1);
  2838. quad = 3;
  2839. }
  2840. }
  2841. if (re <=2)
  2842. {
  2843. switch (quad)
  2844. {
  2845. case 1:angle = 90;break;
  2846. case 2:angle = 90;break;
  2847. case 3:angle = 270;break;
  2848. case 4:angle = 270;break;
  2849. }
  2850. }
  2851. else
  2852. {
  2853. angle_arttg = (im*1000)/re;
  2854. if (angle_arttg <= Angle_const[1])
  2855. {
  2856. angle = 0 + (angle_arttg-Angle_const[0])*57/(1000+Angle_const[0]*angle_arttg/1000);
  2857. }
  2858. else if (angle_arttg <= Angle_const[2])
  2859. {
  2860. angle = 15 + (angle_arttg-Angle_const[1])*57/(1000+Angle_const[1]*angle_arttg/1000);
  2861. }
  2862. else if (angle_arttg <= Angle_const[3])
  2863. {
  2864. angle = 30 + (angle_arttg-Angle_const[2])*57/(1000+Angle_const[2]*angle_arttg/1000);
  2865. }
  2866. else if (angle_arttg <= Angle_const[4])
  2867. {
  2868. angle = 45 + (angle_arttg-Angle_const[3])*57/(1000+Angle_const[3]*angle_arttg/1000);
  2869. }
  2870. else if (angle_arttg <= Angle_const[5])
  2871. {
  2872. angle = 60 + (angle_arttg-Angle_const[4])*57/(1000+Angle_const[4]*angle_arttg/1000);
  2873. }
  2874. else if (angle_arttg <= Angle_const[6])
  2875. {
  2876. angle = 75 + (angle_arttg-Angle_const[5])*57/(1000+Angle_const[5]*angle_arttg/1000);
  2877. }
  2878. else
  2879. {
  2880. angle = 90;
  2881. }
  2882. switch (quad)
  2883. {
  2884. case 1: angle = angle;break;
  2885. case 2: angle = 180 - angle;break;
  2886. case 3: angle = 180 + angle;break;
  2887. case 4: angle = 360 - angle;break;
  2888. }
  2889. }
  2890. if((re < 5) && (im < 5)) angle = 0;
  2891. return(angle);
  2892. }
  2893. #endif
  2894. /******************************************************************************
  2895. 函数名称: _sw_cal_angle_correct
  2896. 函数版本: 01.01
  2897. 创建作者: sunxi
  2898. 创建日期: 2013-08-07
  2899. 函数说明: 测量计算角度时对角度进行校正,保证累加时不会出现计算错误。
  2900. 参数说明:
  2901. 返回值:
  2902. 修改记录:
  2903. */
  2904. void _sw_cal_angle_correct(qs16 *angle,int *mark)
  2905. {
  2906. if(*angle > ANGF180)
  2907. {
  2908. *angle -= ANG360;
  2909. }
  2910. if(*angle < ANGN180)
  2911. {
  2912. *angle += ANG360;
  2913. }
  2914. if(*mark == 0)
  2915. {
  2916. if(abs(*angle)< 90*Q16_BASE)
  2917. {
  2918. *mark = 1;
  2919. }
  2920. else
  2921. {
  2922. *mark = -1;
  2923. }
  2924. }
  2925. if(*mark == -1)
  2926. {
  2927. if(*angle >= 0)
  2928. {
  2929. *angle = 180*Q16_BASE - *angle;
  2930. }
  2931. else
  2932. {
  2933. *angle = (-180)*Q16_BASE - *angle;
  2934. }
  2935. }
  2936. }
  2937. /******************************************************************************
  2938. 函数名称: _sw_cal_angle
  2939. 函数版本: 01.01
  2940. 创建作者: sunxi
  2941. 创建日期: 2013-08-07
  2942. 函数说明: 测量计算角度,每次调用累加计算值。
  2943. 参数说明:
  2944. 返回值:
  2945. 修改记录:
  2946. */
  2947. void _sw_cal_angle(void)
  2948. {
  2949. int i;
  2950. qs16 qs;
  2951. float angle,angle0;
  2952. // 检查是否有基准通道
  2953. if(g_ui_angle0 == -1)
  2954. {
  2955. return;
  2956. }
  2957. // 计算基准通道的角度
  2958. angle0 = _sw_cal_angle0(g_ui[g_ui_angle0].h[1].r,g_ui[g_ui_angle0].h[1].i);
  2959. // angle0 += g_ui[g_ui_angle0].p_factor;
  2960. // 计算相对角度
  2961. for(i=0;i<UI_NUM;i++)
  2962. {
  2963. // 如果索引通道不存在,不需计算
  2964. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[i].ui_base_make == -1)
  2965. {
  2966. continue;
  2967. }
  2968. angle = _sw_cal_angle0(g_ui[i].h[1].r,g_ui[i].h[1].i);
  2969. // angle += g_ui[i].p_factor;
  2970. angle -= angle0;
  2971. qs = rt_round(angle*Q16_BASE);
  2972. _sw_cal_angle_correct(&qs,&g_ui[i].p_mark);
  2973. g_ui[i].p_acc += qs;
  2974. }
  2975. return ;
  2976. }
  2977. /******************************************************************************
  2978. 函数名称: _sw_p2
  2979. 函数版本: 01.01
  2980. 创建作者: sunxi
  2981. 创建日期: 2013-08-07
  2982. 函数说明: 根据电压电流向量计算p值
  2983. 参数说明:
  2984. ur 电压实部
  2985. ui 电压虚部
  2986. ir 电流实部
  2987. ii 电流虚部
  2988. k1 电压系数
  2989. k2 电流系数
  2990. 返回值: p值
  2991. 修改记录:
  2992. */
  2993. float _sw_p2( float Ur, float Ui,float Ir, float Ii, float k1, float k2)
  2994. {
  2995. float p ;
  2996. p = Ur*Ir + Ui*Ii;
  2997. p = p * k1 *k2;
  2998. return p;
  2999. }
  3000. /******************************************************************************
  3001. 函数名称: _sw_q2
  3002. 函数版本: 01.01
  3003. 创建作者: sunxi
  3004. 创建日期: 2013-08-07
  3005. 函数说明: 根据电压电流向量计算q值
  3006. 参数说明:
  3007. ur 电压实部
  3008. ui 电压虚部
  3009. ir 电流实部
  3010. ii 电流虚部
  3011. k1 电压系数
  3012. k2 电流系数
  3013. 返回值: q值
  3014. 修改记录:
  3015. */
  3016. float _sw_q2( float Ur, float Ui,float Ir,float Ii,float k1, float k2)
  3017. {
  3018. float q ;
  3019. q =Ui*Ir - Ur*Ii;
  3020. q = q * k1* k2;
  3021. return q;
  3022. }
  3023. /******************************************************************************
  3024. 函数名称: _sw_cal_pq_3m
  3025. 函数版本: 01.01
  3026. 创建作者: sunxi
  3027. 创建日期: 2013-08-07
  3028. 函数说明: 3表法计算一个开关的pq,每次调用累加计算值。
  3029. 参数说明:
  3030. sw 开关序号
  3031. 返回值:
  3032. 修改记录:
  3033. */
  3034. void _sw_cal_pq_3m(u32 sw)
  3035. {
  3036. u32 i,j,U,I,baseI;
  3037. float p,q,pz,qz;
  3038. if(g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].chn_index != CFG_ADC_CHANNEL_ZERO)baseI=SW_AC_CIA;
  3039. else baseI=0;
  3040. U = pRunSet->tSwSet[sw].bTT_Power_v2 ? PUB_AC_UA2 : PUB_AC_UA1;
  3041. for(j=0; j<3; j++)
  3042. {
  3043. I = UI_SW_INDEX(sw,j+baseI);
  3044. p = 0;
  3045. q = 0;
  3046. pz=0;
  3047. qz=0;
  3048. for(i=1; i<=g_harmonic_num;i++)
  3049. {
  3050. p += _sw_p2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3051. q += _sw_q2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3052. }
  3053. pz=p*(1 + g_ui[I].pq_factor[0]) - q*g_ui[I].pq_factor[1];
  3054. qz=q*(1 + g_ui[I].pq_factor[0]) + p*g_ui[I].pq_factor[1];
  3055. g_sw[sw].ac_in_acc[SW_AC_IN_P] += pz;
  3056. g_sw[sw].ac_in_acc[SW_AC_IN_Q] += qz;
  3057. if(j==0)
  3058. {
  3059. g_sw[sw].ac_in_acc[SW_AC_IN_Pa] += pz;
  3060. g_sw[sw].ac_in_acc[SW_AC_IN_Qa] += qz;
  3061. }
  3062. else if(j==1)
  3063. {
  3064. g_sw[sw].ac_in_acc[SW_AC_IN_Pb] += pz;
  3065. g_sw[sw].ac_in_acc[SW_AC_IN_Qb] += qz;
  3066. }
  3067. else if(j==2)
  3068. {
  3069. g_sw[sw].ac_in_acc[SW_AC_IN_Pc] += pz;
  3070. g_sw[sw].ac_in_acc[SW_AC_IN_Qc] += qz;
  3071. }
  3072. U++;
  3073. }
  3074. return;
  3075. }
  3076. /******************************************************************************
  3077. 函数名称: _sw_cal_pq_2m
  3078. 函数版本: 01.01
  3079. 创建作者: sunxi
  3080. 创建日期: 2013-08-07
  3081. 函数说明: 2表法计算一个开关的pq,每次调用累加计算值。
  3082. 参数说明:
  3083. sw 开关序号
  3084. 返回值:
  3085. 修改记录:
  3086. */
  3087. void _sw_cal_pq_2m(u32 sw)
  3088. {
  3089. u32 i,U,I,baseI;
  3090. float p,q,pz,qz;
  3091. // IA
  3092. U = PUB_AC_UAB1;
  3093. if(g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].chn_index != CFG_ADC_CHANNEL_ZERO)baseI=SW_AC_CIA;
  3094. else baseI=0;
  3095. if(pRunSet->tSwSet[sw].bTT_Power_v2)
  3096. {
  3097. U = PUB_AC_UAB2;
  3098. }
  3099. else if ((g_ui[PUB_AC_UAB1].chn_index == CFG_ADC_CHANNEL_ZERO)
  3100. && (g_ui[PUB_AC_UAB2].chn_index != CFG_ADC_CHANNEL_ZERO))
  3101. {
  3102. U = PUB_AC_UAB2;
  3103. }
  3104. I = UI_SW_INDEX(sw,baseI);
  3105. p = 0;
  3106. q = 0;
  3107. for(i=1; i<=g_harmonic_num;i++)
  3108. {
  3109. p += _sw_p2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3110. q += _sw_q2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3111. }
  3112. pz=p*(1 + g_ui[I].pq_factor[0]) - q*g_ui[I].pq_factor[1];
  3113. qz=q*(1 + g_ui[I].pq_factor[0]) + p*g_ui[I].pq_factor[1];;
  3114. g_sw[sw].ac_in_acc[SW_AC_IN_P] += pz;
  3115. g_sw[sw].ac_in_acc[SW_AC_IN_Q] += qz;
  3116. g_sw[sw].ac_in_acc[SW_AC_IN_Pa] += pz;
  3117. g_sw[sw].ac_in_acc[SW_AC_IN_Qa] += qz;
  3118. // IC
  3119. U = PUB_AC_UBC1;
  3120. if(pRunSet->tSwSet[sw].bTT_Power_v2)
  3121. {
  3122. U = PUB_AC_UBC2;
  3123. }
  3124. else if ((g_ui[PUB_AC_UBC1].chn_index == CFG_ADC_CHANNEL_ZERO)
  3125. && (g_ui[PUB_AC_UBC2].chn_index != CFG_ADC_CHANNEL_ZERO))
  3126. {
  3127. U = PUB_AC_UBC2;
  3128. }
  3129. I = UI_SW_INDEX(sw,2+baseI);
  3130. p = 0;
  3131. q = 0;
  3132. for(i=1; i<=g_harmonic_num;i++)
  3133. {
  3134. p += _sw_p2(-g_ui[U].h[i].r,-g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3135. q += _sw_q2(-g_ui[U].h[i].r,-g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3136. }
  3137. pz=p*(1 + g_ui[I].pq_factor[0]) - q*g_ui[I].pq_factor[1];
  3138. qz=q*(1 + g_ui[I].pq_factor[0]) + p*g_ui[I].pq_factor[1];;
  3139. g_sw[sw].ac_in_acc[SW_AC_IN_P] += pz;
  3140. g_sw[sw].ac_in_acc[SW_AC_IN_Q] += qz;
  3141. g_sw[sw].ac_in_acc[SW_AC_IN_Pc] += pz;
  3142. g_sw[sw].ac_in_acc[SW_AC_IN_Qc] += qz;
  3143. g_sw[sw].ac_in_acc[SW_AC_IN_Pb] = 0;
  3144. g_sw[sw].ac_in_acc[SW_AC_IN_Qb] = 0;
  3145. return;
  3146. }
  3147. /******************************************************************************
  3148. 函数名称: _sw_cal_pq
  3149. 函数版本: 01.01
  3150. 创建作者: sunxi
  3151. 创建日期: 2013-08-07
  3152. 函数说明: 测量计算pq,区分3表法和2表法,每次调用累加计算值。
  3153. 参数说明:
  3154. 返回值:
  3155. 修改记录:
  3156. */
  3157. void _sw_cal_pq(void)
  3158. {
  3159. u32 sw,U;
  3160. for(sw=0; sw<g_sw_num; sw++)
  3161. {
  3162. bool b3U,b3I=false;
  3163. U = pRunSet->tSwSet[sw].bTT_Power_v2 ? PUB_AC_UA2 : PUB_AC_UA1;
  3164. b3U= (g_ui[U+0].chn_index != CFG_ADC_CHANNEL_ZERO
  3165. && g_ui[U+1].chn_index != CFG_ADC_CHANNEL_ZERO
  3166. && g_ui[U+2].chn_index != CFG_ADC_CHANNEL_ZERO);
  3167. b3I|= (g_ui[UI_SW_INDEX(sw,SW_AC_IA)].chn_index != CFG_ADC_CHANNEL_ZERO
  3168. && g_ui[UI_SW_INDEX(sw,SW_AC_IB)].chn_index != CFG_ADC_CHANNEL_ZERO
  3169. && g_ui[UI_SW_INDEX(sw,SW_AC_IC)].chn_index != CFG_ADC_CHANNEL_ZERO
  3170. &&g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].chn_index == CFG_ADC_CHANNEL_ZERO); //测量电流未配置
  3171. b3I|= (g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].chn_index != CFG_ADC_CHANNEL_ZERO
  3172. && g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].chn_index != CFG_ADC_CHANNEL_ZERO
  3173. && g_ui[UI_SW_INDEX(sw,SW_AC_CIC)].chn_index != CFG_ADC_CHANNEL_ZERO);
  3174. if(b3U&&b3I) //有三相电压,且有三相测量电流或无AC 测量电流有三相保护电流,用三表法
  3175. {
  3176. _sw_cal_pq_3m(sw);
  3177. }
  3178. else
  3179. {
  3180. _sw_cal_pq_2m(sw);
  3181. }
  3182. }
  3183. }
  3184. /******************************************************************************
  3185. 函数名称: _sw_cal_mea
  3186. 函数版本: 01.01
  3187. 创建作者: sunxi
  3188. 创建日期: 2013-08-07
  3189. 函数说明: 测量计算,每次调用累加计算值
  3190. 参数说明:
  3191. 返回值:
  3192. 修改记录:
  3193. */
  3194. int _sw_cal_mea(void)
  3195. {
  3196. static int g_cal_step = 0;
  3197. uint64_t us0;
  3198. us0 = bsp_ustimer_get_origin();
  3199. if(g_cal_step == 0)
  3200. {
  3201. // 得到采样点
  3202. _sw_get_dots();
  3203. // fft
  3204. _sw_cal_fft();
  3205. _sw_cal_ri_correct();
  3206. g_cal_step = 1;
  3207. rt_stat_other_in(3,bsp_ustimer_get_duration(us0)/USTIMER_US);
  3208. }
  3209. else
  3210. {
  3211. // 得到合成通道的向量值
  3212. _sw_cal_make();
  3213. // 计算有效值
  3214. _sw_cal_effect();
  3215. // 计算角度
  3216. _sw_cal_angle();
  3217. // 计算PQ
  3218. _sw_cal_pq();
  3219. g_cal_step = 0;
  3220. rt_stat_other_in(4,bsp_ustimer_get_duration(us0)/USTIMER_US);
  3221. }
  3222. return g_cal_step;
  3223. }
  3224. #ifdef FUN_JDXX
  3225. /*********************************************************
  3226. 函数名称:isTakeIsVal
  3227. 函数版本:v1.0
  3228. 作 者: Xzy
  3229. 日 期:2021.10.30
  3230. 函数说明:是否取Is通道的值
  3231. 参数说明:sw:开关号
  3232. I_chn:常规通道号
  3233. Is_chn:小值范围通道号
  3234. 返 回 值:true:取Is的值 false:不取Is的值
  3235. **********************************************************/
  3236. static bool isTakeIsVal(int sw,int I_chn,int Is_chn)
  3237. {
  3238. float I_val,Is_val,err_val;
  3239. if(g_ui[UI_SW_INDEX(sw,I_chn)].chn_index == CFG_ADC_CHANNEL_ZERO || g_ui[UI_SW_INDEX(sw,Is_chn)].chn_index == CFG_ADC_CHANNEL_ZERO){
  3240. return false;
  3241. }
  3242. I_val = (float)g_sw[sw].ac_in[I_chn]/65536;
  3243. Is_val = (float)g_sw[sw].ac_in[Is_chn]/65536;
  3244. if(Is_val == 0)
  3245. err_val = 1;
  3246. else
  3247. err_val = ((float)abs(I_val*1000-Is_val*1000))/(Is_val*1000);
  3248. if(Is_val > 0.5 || err_val >= 0.05)
  3249. return false;
  3250. return true;
  3251. }
  3252. #endif
  3253. /******************************************************************************
  3254. 函数名称: _sw_cal_average
  3255. 函数版本: 01.01
  3256. 创建作者: sunxi
  3257. 创建日期: 2013-08-07
  3258. 函数说明: 测量计算平均值
  3259. 参数说明:
  3260. cal_num 平均的次数
  3261. 返回值:
  3262. 修改记录:
  3263. */
  3264. void _sw_cal_average(int cal_num)
  3265. {
  3266. s32 i,sw;
  3267. s32 temp;
  3268. // 平均幅值和角度
  3269. for(i=0;i<UI_NUM;i++)
  3270. {
  3271. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[i].ui_base_make == -1)
  3272. {
  3273. continue;
  3274. }
  3275. // 幅值
  3276. g_ui[i].e = rt_round(g_ui[i].e_acc/cal_num*Q16_BASE);
  3277. rt_stat_in(&g_ui[i].e_stat,g_ui[i].e);
  3278. if(i<PUB_AC_NUM)
  3279. {
  3280. g_sw_pub.ac_in[i] = g_ui[i].e;
  3281. }
  3282. else
  3283. {
  3284. g_sw[(i-PUB_AC_NUM)/SW_AC_NUM].ac_in[(i-PUB_AC_NUM)%SW_AC_NUM] = g_ui[i].e;
  3285. }
  3286. // 角度
  3287. temp = (g_ui[i].p_acc + (cal_num/2))/cal_num;
  3288. if(g_ui[i].p_mark == -1)
  3289. {
  3290. if(temp >= 0)
  3291. {
  3292. temp = 180*Q16_BASE - temp;
  3293. }
  3294. else
  3295. {
  3296. temp = (-180)*Q16_BASE - temp;
  3297. }
  3298. }
  3299. g_ui[i].p = temp;
  3300. rt_stat_in(&g_ui[i].p_stat,g_ui[i].p);
  3301. g_ui[i].e_acc = 0;
  3302. g_ui[i].p_acc = 0;
  3303. g_ui[i].p_mark = 0;
  3304. }
  3305. #ifdef FUN_JDXX
  3306. // 电流值小于0.5A,取Is的,因为在这个范围I0s准确度高
  3307. for(sw=0;sw<g_sw_num;sw++){
  3308. if(isTakeIsVal(sw,SW_AC_I0,SW_AC_I0s)){
  3309. g_sw[sw].ac_in[SW_AC_I0] = g_sw[sw].ac_in[SW_AC_I0s];
  3310. }
  3311. }
  3312. #endif
  3313. // 角度清除
  3314. for(i=0;i<UI_NUM;i++)
  3315. {
  3316. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[i].ui_base_make == -1)
  3317. {
  3318. continue;
  3319. }
  3320. #ifdef MIN_SIGNAL_SAMPLE
  3321. if(g_ui_angle0 == -1 || g_ui[g_ui_angle0].e < 0.1*Q16_BASE)
  3322. #else
  3323. if(g_ui_angle0 == -1 || g_ui[g_ui_angle0].e < 10*Q16_BASE)
  3324. #endif
  3325. {
  3326. g_ui[i].p = ANGEL_INVALID;
  3327. }
  3328. }
  3329. // 平均开关内部测量值:P,Q,COS,电流不平衡度
  3330. for(sw=0;sw<g_sw_num;sw++)
  3331. {
  3332. #ifdef FUN_YC_POWER_S
  3333. float p,q;
  3334. p = g_sw[sw].ac_in_acc[SW_AC_IN_P]/cal_num;
  3335. q = g_sw[sw].ac_in_acc[SW_AC_IN_Q]/cal_num;
  3336. g_sw[sw].ac_in[SW_AC_IN_S] = sqrtf(p*p+q*q)*Q16_BASE;
  3337. #endif
  3338. g_sw[sw].ac_in[SW_AC_IN_P] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_P]/cal_num*Q16_BASE);
  3339. g_sw[sw].ac_in[SW_AC_IN_Q] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Q]/cal_num*Q16_BASE);
  3340. g_sw[sw].ac_in[SW_AC_IN_Pa] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Pa]/cal_num*Q16_BASE);
  3341. g_sw[sw].ac_in[SW_AC_IN_Pb] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Pb]/cal_num*Q16_BASE);
  3342. g_sw[sw].ac_in[SW_AC_IN_Pc] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Pc]/cal_num*Q16_BASE);
  3343. g_sw[sw].ac_in[SW_AC_IN_Qa] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Qa]/cal_num*Q16_BASE);
  3344. g_sw[sw].ac_in[SW_AC_IN_Qb] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Qb]/cal_num*Q16_BASE);
  3345. g_sw[sw].ac_in[SW_AC_IN_Qc] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_Qc]/cal_num*Q16_BASE);
  3346. // 如果电流反向,功率反向
  3347. if(pRunSet->tSwSet[sw].bTT_Current_Inv)
  3348. {
  3349. g_sw[sw].ac_in[SW_AC_IN_P] = -g_sw[sw].ac_in[SW_AC_IN_P];
  3350. g_sw[sw].ac_in[SW_AC_IN_Q] = -g_sw[sw].ac_in[SW_AC_IN_Q];
  3351. g_sw[sw].ac_in[SW_AC_IN_Pa] = -g_sw[sw].ac_in[SW_AC_IN_Pa];
  3352. g_sw[sw].ac_in[SW_AC_IN_Pb] = -g_sw[sw].ac_in[SW_AC_IN_Pb];
  3353. g_sw[sw].ac_in[SW_AC_IN_Pc] = -g_sw[sw].ac_in[SW_AC_IN_Pc];
  3354. g_sw[sw].ac_in[SW_AC_IN_Qa] = -g_sw[sw].ac_in[SW_AC_IN_Qa];
  3355. g_sw[sw].ac_in[SW_AC_IN_Qb] = -g_sw[sw].ac_in[SW_AC_IN_Qb];
  3356. g_sw[sw].ac_in[SW_AC_IN_Qc] = -g_sw[sw].ac_in[SW_AC_IN_Qc];
  3357. }
  3358. if( g_ui[UI_SW_INDEX(sw,SW_AC_IA)].e > g_unit[g_sw_ac_desc[SW_AC_IA].unit].zero
  3359. || g_ui[UI_SW_INDEX(sw,SW_AC_IB)].e > g_unit[g_sw_ac_desc[SW_AC_IB].unit].zero
  3360. || g_ui[UI_SW_INDEX(sw,SW_AC_IC)].e > g_unit[g_sw_ac_desc[SW_AC_IC].unit].zero)
  3361. {
  3362. g_sw[sw].ac_in[SW_AC_IN_BI_UNBALANCE] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_BI_UNBALANCE]/cal_num*Q16_BASE);
  3363. }
  3364. else
  3365. {
  3366. g_sw[sw].ac_in[SW_AC_IN_BI_UNBALANCE] = 0;
  3367. }
  3368. if( g_ui[UI_SW_INDEX(sw,SW_AC_CIA)].e > g_unit[g_sw_ac_desc[SW_AC_CIA].unit].zero
  3369. || g_ui[UI_SW_INDEX(sw,SW_AC_CIB)].e > g_unit[g_sw_ac_desc[SW_AC_CIB].unit].zero
  3370. || g_ui[UI_SW_INDEX(sw,SW_AC_CIC)].e > g_unit[g_sw_ac_desc[SW_AC_CIC].unit].zero)
  3371. {
  3372. g_sw[sw].ac_in[SW_AC_IN_CI_UNBALANCE] = rt_round(g_sw[sw].ac_in_acc[SW_AC_IN_CI_UNBALANCE]/cal_num*Q16_BASE);
  3373. }
  3374. else
  3375. {
  3376. g_sw[sw].ac_in[SW_AC_IN_CI_UNBALANCE] = 0;
  3377. }
  3378. // TODO:
  3379. // 功率因数,I1/I*COSφ1=COSφ ,I1基波电流有效值,I总电流有效值,COSφ1基波功率因数,COSφ含谐波电网的实际功率因数
  3380. if(_AbsL(g_sw[sw].ac_in[SW_AC_IN_Q]) > g_unit[g_sw_ac_desc[SW_AC_IN_Q].unit].zero)
  3381. {
  3382. g_sw[sw].ac_in[SW_AC_IN_COS] =_CosPQ((g_sw[sw].ac_in[SW_AC_IN_P]>>14),(g_sw[sw].ac_in[SW_AC_IN_Q]>>14));
  3383. }
  3384. else if(g_sw[sw].ac_in[SW_AC_IN_P]>=Q16_BASE)
  3385. {
  3386. g_sw[sw].ac_in[SW_AC_IN_COS]=Q16_BASE;
  3387. }
  3388. else if(g_sw[sw].ac_in[SW_AC_IN_P]<=-Q16_BASE)
  3389. {
  3390. g_sw[sw].ac_in[SW_AC_IN_COS]=-Q16_BASE;
  3391. }
  3392. else
  3393. {
  3394. g_sw[sw].ac_in[SW_AC_IN_COS]=0;
  3395. }
  3396. g_sw[sw].ac_in_acc[SW_AC_IN_P] = 0;
  3397. g_sw[sw].ac_in_acc[SW_AC_IN_Q] = 0;
  3398. g_sw[sw].ac_in_acc[SW_AC_IN_Pa] = 0;
  3399. g_sw[sw].ac_in_acc[SW_AC_IN_Pb] = 0;
  3400. g_sw[sw].ac_in_acc[SW_AC_IN_Pc] = 0;
  3401. g_sw[sw].ac_in_acc[SW_AC_IN_Qa] = 0;
  3402. g_sw[sw].ac_in_acc[SW_AC_IN_Qb] = 0;
  3403. g_sw[sw].ac_in_acc[SW_AC_IN_Qc] = 0;
  3404. g_sw[sw].ac_in_acc[SW_AC_IN_BI_UNBALANCE] = 0;
  3405. #if 0
  3406. //电子电流互感器小信号电压值
  3407. for(i=0;i<4;i++)
  3408. {
  3409. s16 cfg,scale;
  3410. cfg = g_sw[sw].ac_cfg_index[SW_AC_IA+i];
  3411. if(cfg != INDEX_INVALLID)
  3412. {
  3413. scale = equ_get_ac_scale(g_equ_config_ac[cfg].slot,g_equ_config_ac[cfg].index);
  3414. if(scale == EQU_SCALE_ECT_1V_1A || scale == EQU_SCALE_ECT_0V2_1A)
  3415. {
  3416. g_sw[sw].ac_in[SW_AC_IN_IA_ECT+i] = g_ui[UI_SW_INDEX(sw,SW_AC_IA+i)].e*g_e_k_ECVT[scale];
  3417. }
  3418. }
  3419. }
  3420. #endif
  3421. }
  3422. // 其它测量值
  3423. // 频率
  3424. g_sw_pub.ac_in[PUB_AC_IN_F1] = (qs16)(freq_get(0)*Q16_BASE); //第1路频率
  3425. g_sw_pub.ac_in[PUB_AC_IN_F2] = (qs16)(freq_get(1)*Q16_BASE); //第2路频率
  3426. // 直流、温度
  3427. {
  3428. float factor,t,f0,f1;
  3429. #if defined TMP_CHIP_DS18B20
  3430. t = ds18b20_get_temp();
  3431. #elif defined TMP_CHIP_GX21M15
  3432. t = gx21m15_get_temp();
  3433. #endif
  3434. #ifdef DC_TEST_ONE
  3435. f0 = (dc_get(0)-g_dcfactor[0].f_dcL)*g_dcfactor[0].f_dc+dc_adjust[0];
  3436. f1 = 0;
  3437. #else
  3438. f0 = (dc_get(0)-g_dcfactor[0].f_dcL)*g_dcfactor[0].f_dc+dc_adjust[0];
  3439. f1 = (dc_get(1)-g_dcfactor[1].f_dcL)*g_dcfactor[1].f_dc+dc_adjust[0];
  3440. #endif
  3441. factor = 1.0;
  3442. if(t > -80.0 && t < 125.0)
  3443. {
  3444. factor += (t - g_dc_temp)* pRunSet->f_temp_factor_dc/1000000;
  3445. }
  3446. f0 /= factor;
  3447. f1 /= factor;
  3448. #ifdef DC_NUM_SET
  3449. if(pRunSet->dDc_num==1)
  3450. f1=0;//只有一个通道,将第二个直流通道强制=0
  3451. #endif
  3452. #ifdef CPU_FUXI
  3453. if(f0 < tRunPara.wDC_ZERO)
  3454. {
  3455. f0 = 0.0;
  3456. }
  3457. if(f1 < tRunPara.wDC_ZERO)
  3458. {
  3459. f1 = 0.0;
  3460. }
  3461. #endif
  3462. g_sw_pub.ac_in[PUB_AC_IN_TEMP] = (qs16)(t*Q16_BASE);
  3463. g_sw_pub.ac_in[PUB_AC_IN_UZ1] = (qs16)(f0*Q16_BASE);
  3464. g_sw_pub.ac_in[PUB_AC_IN_UZ2] = (qs16)(f1*Q16_BASE);
  3465. if(g_sw_pub.ac_in[PUB_AC_IN_UZ1]<0)
  3466. g_sw_pub.ac_in[PUB_AC_IN_UZ1]=0;
  3467. if(g_sw_pub.ac_in[PUB_AC_IN_UZ2]<0)
  3468. g_sw_pub.ac_in[PUB_AC_IN_UZ2]=0;
  3469. }
  3470. // 电压不平衡度
  3471. if( g_ui[PUB_AC_UA1].e > g_unit[g_pub_ac_desc[PUB_AC_UA1].unit].zero
  3472. || g_ui[PUB_AC_UB1].e > g_unit[g_pub_ac_desc[PUB_AC_UB1].unit].zero
  3473. || g_ui[PUB_AC_UC1].e > g_unit[g_pub_ac_desc[PUB_AC_UC1].unit].zero)
  3474. {
  3475. g_sw_pub.ac_in[PUB_AC_IN_V_UNBALANCE1] = rt_round(g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE1]/cal_num*Q16_BASE);
  3476. }
  3477. else
  3478. {
  3479. g_sw_pub.ac_in[PUB_AC_IN_V_UNBALANCE1] = 0;
  3480. }
  3481. if( g_ui[PUB_AC_UA2].e > g_unit[g_pub_ac_desc[PUB_AC_UA2].unit].zero
  3482. || g_ui[PUB_AC_UB2].e > g_unit[g_pub_ac_desc[PUB_AC_UB2].unit].zero
  3483. || g_ui[PUB_AC_UC2].e > g_unit[g_pub_ac_desc[PUB_AC_UC2].unit].zero)
  3484. {
  3485. g_sw_pub.ac_in[PUB_AC_IN_V_UNBALANCE2] = rt_round(g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE2]/cal_num*Q16_BASE);
  3486. }
  3487. else
  3488. {
  3489. g_sw_pub.ac_in[PUB_AC_IN_V_UNBALANCE2] = 0;
  3490. }
  3491. g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE1] = 0;
  3492. g_sw_pub.ac_in_acc[PUB_AC_IN_V_UNBALANCE2] = 0;
  3493. #ifdef GD_AREA_YUNAN_LP // 云南涞浦
  3494. g_sw_pub.ac_in[PUB_AC_IN_DLTUAB] =_AbsL(g_ui[PUB_AC_UAB1].e -g_ui[PUB_AC_UAB2].e);
  3495. g_sw_pub.ac_in[PUB_AC_IN_DLTUBC] =_AbsL(g_ui[PUB_AC_UBC1].e -g_ui[PUB_AC_UBC2].e);
  3496. g_sw_pub.ac_in[PUB_AC_IN_DLTUCA] =_AbsL(g_ui[PUB_AC_UCA1].e -g_ui[PUB_AC_UCA2].e);
  3497. if(g_ui[PUB_AC_UAB1].e>10*Q16_BASE&&g_ui[PUB_AC_UAB2].e>10*Q16_BASE)
  3498. {
  3499. g_sw_pub.ac_in[PUB_AC_IN_ARGUAB] =_AbsL(CalcAngSub(g_ui[PUB_AC_UAB1].ri.r,g_ui[PUB_AC_UAB1].ri.i,g_ui[PUB_AC_UAB2].ri.r,g_ui[PUB_AC_UAB2].ri.i));
  3500. }
  3501. else
  3502. {
  3503. g_sw_pub.ac_in[PUB_AC_IN_ARGUAB]=0;
  3504. }
  3505. if(g_ui[PUB_AC_UBC1].e>10*Q16_BASE&&g_ui[PUB_AC_UBC2].e>10*Q16_BASE)
  3506. {
  3507. g_sw_pub.ac_in[PUB_AC_IN_ARGUBC] =_AbsL(CalcAngSub(g_ui[PUB_AC_UBC1].ri.r,g_ui[PUB_AC_UBC1].ri.i,g_ui[PUB_AC_UBC2].ri.r,g_ui[PUB_AC_UBC2].ri.i));
  3508. }
  3509. else
  3510. {
  3511. g_sw_pub.ac_in[PUB_AC_IN_ARGUBC]=0;
  3512. }
  3513. if(g_ui[PUB_AC_UCA1].e>10*Q16_BASE&&g_ui[PUB_AC_UCA2].e>10*Q16_BASE)
  3514. {
  3515. g_sw_pub.ac_in[PUB_AC_IN_ARGUCA] =_AbsL(CalcAngSub(g_ui[PUB_AC_UCA1].ri.r,g_ui[PUB_AC_UCA1].ri.i,g_ui[PUB_AC_UCA2].ri.r,g_ui[PUB_AC_UCA2].ri.i));
  3516. }
  3517. else
  3518. {
  3519. g_sw_pub.ac_in[PUB_AC_IN_ARGUCA]=0;
  3520. }
  3521. #endif
  3522. //版本号0x00010104
  3523. {
  3524. g_sw_pub.ac_in[PUB_AC_IN_VER] =((BYTE)((VER_NUM>>0)&0x0f)
  3525. +((BYTE)(VER_NUM>>4)&0x0f)*10
  3526. +((BYTE)(VER_NUM>>8)&0x0f)*100
  3527. +((BYTE)(VER_NUM>>12)&0x0f)*1000
  3528. +((BYTE)(VER_NUM>>16)&0x0f)*10000)*Q16_BASE;
  3529. }
  3530. #if 0
  3531. //电子电压互感器小信号电压值
  3532. for(i=0;i<8;i++)
  3533. {
  3534. u8 evt[8]={PUB_AC_UA1,PUB_AC_UB1,PUB_AC_UC1,PUB_AC_U01,PUB_AC_UA2,PUB_AC_UB2,PUB_AC_UC2,PUB_AC_U02};
  3535. s16 cfg,scale;
  3536. cfg = g_sw_pub.ac_cfg_index[evt[i]];
  3537. if(cfg != INDEX_INVALLID)
  3538. {
  3539. scale = equ_get_ac_scale(g_equ_config_ac[cfg].slot,g_equ_config_ac[cfg].index);
  3540. if(scale == EQU_SCALE_EVT_3V25_100V || scale == EQU_SCALE_EVT_6V50_100V)
  3541. {
  3542. g_sw_pub.ac_in[PUB_AC_IN_UA1_EVT+i] = g_ui[evt[i]].e*g_e_k_ECVT[scale];
  3543. }
  3544. }
  3545. }
  3546. #endif
  3547. }
  3548. void _sw_cal_zl(void)
  3549. {
  3550. // 直流、温度
  3551. {
  3552. float factor,t,f0,f1;
  3553. #if defined TMP_CHIP_DS18B20
  3554. t = ds18b20_get_temp();
  3555. #elif defined TMP_CHIP_GX21M15
  3556. t = gx21m15_get_temp();
  3557. #endif
  3558. f0 = (dc_get(0)-g_dcfactor[0].f_dcL)*g_dcfactor[0].f_dc+dc_adjust[0];
  3559. f1 = (dc_get(1)-g_dcfactor[1].f_dcL)*g_dcfactor[1].f_dc+dc_adjust[0];
  3560. factor = 1.0;
  3561. if(t > -80.0 && t < 125.0)
  3562. {
  3563. factor += (t - g_dc_temp)* pRunSet->f_temp_factor_dc/1000000;
  3564. }
  3565. f0 /= factor;
  3566. f1 /= factor;
  3567. g_sw_pub.ac_in[PUB_AC_IN_TEMP] = (qs16)(t*Q16_BASE);
  3568. g_sw_pub.ac_in[PUB_AC_IN_UZ1] = (qs16)(f0*Q16_BASE);
  3569. g_sw_pub.ac_in[PUB_AC_IN_UZ2] = (qs16)(f1*Q16_BASE);
  3570. }
  3571. }
  3572. /******************************************************************************
  3573. 函数名称: _sw_auto_adjust_pq
  3574. 函数版本: 01.01
  3575. 创建作者: sunxi
  3576. 创建日期: 2013-08-07
  3577. 函数说明: 自动校正PQ,累加校正系数
  3578. 参数说明:
  3579. 返回值:
  3580. 修改记录:
  3581. */
  3582. void _sw_auto_adjust_pq(void)
  3583. {
  3584. float RateP;
  3585. float RateQ;
  3586. u32 sw,i,j,U,I;
  3587. float pp[3],qq[3];
  3588. RateP = (float)100*5*0.5; //U*I*COS60
  3589. RateQ = (float)100*5*0.866; //U*I*SIN60
  3590. for(sw=0; sw<g_sw_num; sw++)
  3591. {
  3592. for(j=0; j<3; j++)
  3593. {
  3594. U = PUB_AC_UA1+j;
  3595. I = UI_SW_INDEX(sw,j);
  3596. pp[j] = 0;
  3597. qq[j] = 0;
  3598. for(i=1; i<=g_harmonic_num;i++)
  3599. {
  3600. pp[j] += _sw_p2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3601. qq[j] += _sw_q2(g_ui[U].h[i].r,g_ui[U].h[i].i,g_ui[I].h[i].r,g_ui[I].h[i].i,g_ui[U].e_factor,g_ui[I].e_factor) ;
  3602. }
  3603. g_pq_factor[sw][j].pq[0] += (RateQ*qq[j] + RateP*pp[j])/(pp[j]*pp[j] + qq[j]*qq[j]) - 1;
  3604. g_pq_factor[sw][j].pq[1] += (RateQ*pp[j] - RateP*qq[j])/(pp[j]*pp[j] + qq[j]*qq[j]);
  3605. }
  3606. }
  3607. return;
  3608. }
  3609. /******************************************************************************
  3610. 函数名称: _sw_ui_e_k
  3611. 函数版本: 01.01
  3612. 创建作者: sunxi
  3613. 创建日期: 2013-08-07
  3614. 函数说明: 通过g_ui的索引得到对应通道的理论比例系数。
  3615. 参数说明:
  3616. ui_index 通道在g_ui中的索引值
  3617. 返回值: 对应通道的理论比例系数。
  3618. 修改记录:
  3619. */
  3620. float _sw_ui_e_k(int ui_index)
  3621. {
  3622. int sw,i;
  3623. if(ui_index < PUB_AC_NUM)
  3624. {
  3625. i = g_sw_pub.ac_cfg_index[ui_index];
  3626. }
  3627. else
  3628. {
  3629. sw = (ui_index - PUB_AC_NUM)/SW_AC_NUM;
  3630. i = (ui_index - PUB_AC_NUM)%SW_AC_NUM;
  3631. i = g_sw[sw].ac_cfg_index[i];
  3632. }
  3633. return factor_e_k(g_equ_config_ac[i].scale);
  3634. }
  3635. /******************************************************************************
  3636. 函数名称: _sw_min_max
  3637. 函数版本: 01.01
  3638. 创建作者: sunxi
  3639. 创建日期: 2013-08-07
  3640. 函数说明: 计算g_ui中连续三个通道中的m2的最小值,最大值,供保护算法使用
  3641. 参数说明:
  3642. ui_index 通道在g_ui中的索引值
  3643. p_min 返回的最小值
  3644. p_max 返回的最大值
  3645. 返回值:
  3646. 修改记录:
  3647. */
  3648. void _sw_min_max(int ui_index,u32 *p_min,u32*p_max)
  3649. {
  3650. u32 min,max,m2;
  3651. int i;
  3652. min = -1;
  3653. max = 0;
  3654. for(i=0;i<3;i++)
  3655. {
  3656. if(g_ui[ui_index].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[ui_index].ui_base_make == -1)
  3657. {
  3658. ui_index++;
  3659. continue;
  3660. }
  3661. m2 = g_ui[ui_index].m2[0];
  3662. if(m2 < min)
  3663. {
  3664. min = m2;
  3665. }
  3666. if(m2 > max)
  3667. {
  3668. max = m2;
  3669. }
  3670. ui_index++;
  3671. }
  3672. *p_min = min;
  3673. *p_max = max;
  3674. return;
  3675. }
  3676. /******************************************************************************
  3677. 函数名称: _fz_min_max
  3678. 函数版本: 01.01
  3679. 创建作者: xxxxxx
  3680. 创建日期: 2013-08-07
  3681. 函数说明: 计算g_ui中连续通道中的幅值的最小值,最大值,供保护算法使用
  3682. 参数说明:
  3683. ui_index1 起始通道在g_ui中的索引值
  3684. ui_index2 结束通道在g_ui中的索引值
  3685. p_min 返回的最小值
  3686. p_max 返回的最大值
  3687. 返回值:
  3688. 修改记录:
  3689. */
  3690. void _fz_min_max(int ui_index1,int ui_index2,u32 *p_min,u32*p_max)
  3691. {
  3692. u32 min,max,m2;
  3693. int i;
  3694. min = -1;
  3695. max = 0;
  3696. for(i=ui_index1;i<ui_index2+1;i++)
  3697. {
  3698. if(g_ui[ui_index1].chn_index == CFG_ADC_CHANNEL_ZERO && g_ui[ui_index1].ui_base_make == -1)
  3699. {
  3700. ui_index1++;
  3701. continue;
  3702. }
  3703. m2 = g_ui[ui_index1].fz;
  3704. if(m2 < min)
  3705. {
  3706. min = m2;
  3707. }
  3708. if(m2 > max)
  3709. {
  3710. max = m2;
  3711. }
  3712. ui_index1++;
  3713. }
  3714. *p_min = min;
  3715. *p_max = max;
  3716. return;
  3717. }
  3718. /******************************************************************************
  3719. 函数名称: _sw_base_angle
  3720. 函数版本: 01.01
  3721. 创建作者: sunxi
  3722. 创建日期: 2013-08-07
  3723. 函数说明: 自动校准时,通道的基本参考角度
  3724. 参数说明:
  3725. ui_index 通道在g_ui中的索引值
  3726. 返回值: 参考的角度
  3727. 修改记录:
  3728. */
  3729. float _sw_base_angle(int ui_index)
  3730. {
  3731. static float angle_v[8] = {0,-120,120,0,-120,120,120,120}; // U0、US使用UC角度
  3732. #ifdef SW_AC_I0S_SAMPLE
  3733. static float angle_a [SW_AC_NUM] = {0,-120,120,-120,-120,0,-120,120}; // I0使用IB值
  3734. #else
  3735. static float angle_a [SW_AC_NUM] = {0,-120,120,-120,0,-120,120}; // I0使用IB值
  3736. #endif
  3737. float angle;
  3738. if(ui_index < PUB_AC_NUM)
  3739. {
  3740. // 电压
  3741. // 将第2组电压映射到第一组上面
  3742. ui_index = ui_index%(PUB_AC_NUM/2);
  3743. // 得到基准电压
  3744. angle = angle_v[ui_index];
  3745. // 如果配置不是相电压,U01、US1减30度。
  3746. if((g_ui[PUB_AC_UA1].chn_index == CFG_ADC_CHANNEL_ZERO)
  3747. && (ui_index == PUB_AC_U01 || ui_index == PUB_AC_US1))
  3748. {
  3749. angle -= 30;
  3750. }
  3751. }
  3752. else
  3753. {
  3754. // 电流
  3755. ui_index = (ui_index - PUB_AC_NUM)%SW_AC_NUM;
  3756. angle = angle_a[ui_index];
  3757. // 如果配置不是相电压,电流减30度。
  3758. if(g_ui[PUB_AC_UA1].chn_index == CFG_ADC_CHANNEL_ZERO)
  3759. {
  3760. angle -= 30;
  3761. }
  3762. }
  3763. return angle;
  3764. }
  3765. /******************************************************************************
  3766. 函数名称: _sw_save_dc_factor
  3767. 函数版本: 01.01
  3768. 创建作者: sunxi
  3769. 创建日期: 2013-08-07
  3770. 函数说明: 将直流量校正系数保存到内部定值
  3771. 参数说明:
  3772. dc1 直流量1的校正系数
  3773. dc2 只流量2的校正系数
  3774. 返回值:
  3775. 0: 成功
  3776. 其它: 失败
  3777. 修改记录:
  3778. */
  3779. int _sw_save_dc_factor(float dc1_H, float dc1_L,float dc2_H, float dc2_L)
  3780. {
  3781. struct dc_factor_save factor[2];
  3782. u8 id[8];
  3783. if(dc1_H != 0.0)
  3784. {
  3785. factor[0].dc_h = dc1_H;
  3786. factor[0].adjust_set = DC_ADJUST;
  3787. }
  3788. if(dc1_L!= 0.0)
  3789. {
  3790. factor[0].dc_l= dc1_L;
  3791. factor[0].adjust_set = DC_ADJUST;
  3792. }
  3793. if(dc2_H != 0.0)
  3794. {
  3795. factor[1].dc_h = dc2_H;
  3796. factor[1].adjust_set = DC_ADJUST;
  3797. }
  3798. if(dc2_L!= 0.0)
  3799. {
  3800. factor[1].dc_l = dc2_L;
  3801. factor[1].adjust_set = DC_ADJUST;
  3802. }
  3803. memcpy(id, g_auth_id, 8);
  3804. if(dcfactor_createfile(&id[0], (u8*)&factor) != 0)
  3805. {
  3806. rt_printf("直流系数文件保存失败\r\n");
  3807. return -1;
  3808. }
  3809. return 0;
  3810. }
  3811. float g_temp_factor[EQU_SLOT_AC_NUM];
  3812. void _sw_temp_factor(void)
  3813. {
  3814. int i;
  3815. float t;
  3816. #if defined TMP_CHIP_DS18B20
  3817. t = ds18b20_get_temp();
  3818. #elif defined TMP_CHIP_GX21M15
  3819. t = gx21m15_get_temp();
  3820. #endif
  3821. if(t < -80.0 || t > 125.0)
  3822. {
  3823. // 温度超范围,可能温度传感器坏,使用默认值
  3824. for(i=0; i<EQU_SLOT_AC_NUM; i++)
  3825. {
  3826. g_temp_factor[i] = 1.0;
  3827. }
  3828. }
  3829. else
  3830. {
  3831. //在正常范围内,使用温度校正
  3832. for(i=0; i<EQU_SLOT_AC_NUM; i++)
  3833. {
  3834. factor_temp_get(equ_ac_index_to_slot(i),&g_temp_factor[i]);
  3835. g_temp_factor[i] = t - g_temp_factor[i];
  3836. g_temp_factor[i] *= pRunSet->f_temp_factor_ac/1000000;
  3837. g_temp_factor[i] += 1.0;
  3838. }
  3839. }
  3840. for(i=0;i<UI_NUM;i++)
  3841. {
  3842. if(g_ui[i].chn_index != CFG_ADC_CHANNEL_ZERO)
  3843. {
  3844. g_ui[i].e_factor = g_ui[i].e_factor0*g_temp_factor[g_ui[i].chn_index/16];
  3845. }
  3846. else if(g_ui[i].ui_base_make != -1)
  3847. {
  3848. g_ui[i].e_factor = g_ui[i].e_factor0*g_temp_factor[g_ui[g_ui[i].ui_base_make].chn_index/16];
  3849. }
  3850. }
  3851. return;
  3852. }
  3853. int sw_get_chnl_ps(int index,bool prim)
  3854. {
  3855. int owner,type;
  3856. owner=g_equ_config_ac[index].owner;
  3857. type=g_equ_config_ac[index].type;
  3858. if(owner==0)
  3859. {
  3860. type-=1;
  3861. if(type==PUB_AC_U01||type==PUB_AC_U02) //零序 PT变比为默认10000/100
  3862. {
  3863. if(prim) return 10000;
  3864. else return 100;
  3865. }
  3866. else if(PUB_AC_UA2||PUB_AC_UB2||PUB_AC_UC2||PUB_AC_UAB2||PUB_AC_UBC2||PUB_AC_UCA2)
  3867. { //采用PT2变比 dlj 2019-6-5
  3868. if(prim)return 10000;
  3869. else return pRunSet->pt2_two;
  3870. }
  3871. else if(type<PUB_AC_NUM)
  3872. {
  3873. if(prim)return 10000;
  3874. else return pRunSet->pt1_two;
  3875. }
  3876. }
  3877. else
  3878. {
  3879. owner-=1;
  3880. type-=1;
  3881. if(type==SW_AC_I0) //零序 CT变比
  3882. {
  3883. if(prim) return pRunSet->ct0_one;
  3884. else return pRunSet->ct0_two;
  3885. }
  3886. else if(type==SW_AC_IA||type==SW_AC_IB||type==SW_AC_IC)
  3887. {
  3888. if(prim) return pRunSet->ct_one;
  3889. else return pRunSet->ct_two;
  3890. }
  3891. }
  3892. return 1;
  3893. }
  3894. /*------------------------------ 测试函数 -------------------------------------
  3895. 一个实体文件必须带一个本模块的测试函数来进行单元测试,如果的确不方便在本模块中
  3896. 进行单元测试,必须在此注明实际的测试位置(例如在哪个实体文件中使用哪个测试函数).
  3897. */
  3898. int sw_stat_reset(void)
  3899. {
  3900. int i;
  3901. for(i=0; i< UI_NUM; i++)
  3902. {
  3903. rt_stat_init(&g_ui[i].m2_stat,g_ui[i].name);
  3904. rt_stat_init(&g_ui[i].e_stat,g_ui[i].name);
  3905. rt_stat_init(&g_ui[i].p_stat,g_ui[i].name);
  3906. }
  3907. return 0;
  3908. }
  3909. int sw_pub_printf(void)
  3910. {
  3911. return 0;
  3912. }
  3913. int sw_pub_printf_v(void)
  3914. {
  3915. int i;
  3916. // rt_printf("PUB AC通道模值:\r\n");
  3917. // rt_printf("name\t\t\tmin\tmax\tavg\tsum\t\tcnt\r\n");
  3918. rt_printf("PUB AC通道有效值:\r\n");
  3919. rt_printf("name\t\t\tmin\tmax\tavg\tsum\t\tcnt\r\n");
  3920. for(i=0; i<PUB_AC_NUM; i++)
  3921. {
  3922. rt_stat_printf_q16(&g_ui[i].e_stat);
  3923. }
  3924. #if 1
  3925. rt_printf("PUB AC通道角度:\r\n");
  3926. rt_printf("name\t\t\tmin\tmax\tavg\tsum\t\tcnt\r\n");
  3927. for(i=0; i<PUB_AC_NUM; i++)
  3928. {
  3929. rt_stat_printf_q16(&g_ui[i].p_stat);
  3930. }
  3931. #endif
  3932. return 0;
  3933. }
  3934. int sw_printf(void)
  3935. {
  3936. return 0;
  3937. }
  3938. int sw_printf_v(void)
  3939. {
  3940. int i,sw;
  3941. rt_printf("SW AC通道有效值:\r\n");
  3942. rt_printf("name\t\t\tmin\tmax\tavg\tsum\t\tcnt\r\n");
  3943. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  3944. {
  3945. rt_printf("sw%02d\r\n",sw);
  3946. for(i=0; i<SW_AC_NUM; i++)
  3947. {
  3948. rt_stat_printf_q16(&g_ui[PUB_AC_NUM + sw*SW_AC_NUM + i].e_stat);
  3949. }
  3950. for(i=SW_AC_NUM; i<SW_AC_NUM_ALL; i++)
  3951. {
  3952. rt_printf("%s:%s.\r\n",g_sw_ac_desc[i].name,q16_to_str((long)g_sw[sw].ac_in[i]));
  3953. }
  3954. }
  3955. #if 0
  3956. rt_printf("SW AC通道角度:\r\n");
  3957. rt_printf("name\t\t\tmin\tmax\tavg\tsum\t\tcnt\r\n");
  3958. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  3959. {
  3960. for(i=0; i<SW_AC_NUM; i++)
  3961. {
  3962. rt_stat_printf_q16(&g_sw[sw].I.i_stat_p[i]);
  3963. }
  3964. }
  3965. #endif
  3966. return 0;
  3967. }
  3968. int sw_ui_printf(void)
  3969. {
  3970. int i;
  3971. rt_printf("谐波次数:%d\r\n",g_harmonic_num);
  3972. rt_printf("UI通道:\r\n");
  3973. rt_printf("\t\tm2_factor_k\tm2_factor_c\te_factor\tp_factor\te_ps\r\n");
  3974. for(i=0; i<UI_NUM; i++)
  3975. {
  3976. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  3977. {
  3978. // continue;
  3979. }
  3980. rt_printf("%s(%02d,%02d):\t%f\t%f\t%f\t%f\t%f\r\n",
  3981. g_ui[i].name,
  3982. g_ui[i].chn_index ,
  3983. g_ui[i].ui_base_make ,
  3984. (float)g_ui[i].m2_factor_k/Q08_BASE,
  3985. (float)g_ui[i].m2_factor_c/Q16_BASE,
  3986. g_ui[i].e_factor ,
  3987. g_ui[i].p_factor ,
  3988. g_ui[i].e_ps);
  3989. }
  3990. return 0;
  3991. }
  3992. #if 1
  3993. void rt_stat_printf_m2(int i,struct rt_stat *stat)
  3994. {
  3995. uint32_t avg = 0;
  3996. qs16 qs;
  3997. if(stat->cnt)
  3998. {
  3999. avg = stat->sum/stat->cnt;
  4000. }
  4001. rt_printf("%-24s",stat->name);
  4002. qs = _Mul_Div_U(sqrt_32fix(stat->min), 256, g_ui[i].m2_factor_k);
  4003. rt_printf("%f\t", (float)qs/Q16_BASE);
  4004. qs = _Mul_Div_U(sqrt_32fix(stat->max), 256, g_ui[i].m2_factor_k);
  4005. rt_printf("%f\t", (float)qs/Q16_BASE);
  4006. qs = _Mul_Div_U(sqrt_32fix(avg), 256, g_ui[i].m2_factor_k);
  4007. rt_printf("%f\t", (float)qs/Q16_BASE);
  4008. rt_printf("%-016d%d\r\n",stat->sum,stat->cnt);
  4009. return;
  4010. }
  4011. #else
  4012. void rt_stat_printf_m2(int i,struct rt_stat *stat)
  4013. {
  4014. uint32_t avg = 0;
  4015. float k;
  4016. if(stat->cnt)
  4017. {
  4018. avg = stat->sum/stat->cnt;
  4019. }
  4020. k = _sw_ui_e_k(i);
  4021. rt_printf("%-24s",stat->name);
  4022. rt_printf("%f\t", sqrtf((float)stat->min)/k);
  4023. rt_printf("%f\t", sqrtf((float)stat->max)/k);
  4024. rt_printf("%f\t", sqrtf((float)avg)/k);
  4025. rt_printf("%-016d%d\r\n",stat->sum,stat->cnt);
  4026. return;
  4027. }
  4028. #endif
  4029. int sw_ui_printf_e(void)
  4030. {
  4031. int i;
  4032. rt_printf("UI通道:\r\n");
  4033. rt_printf("name\t\t\tmin\t\tmax\t\tavg\t\tsum\t\tcnt\r\n");
  4034. for(i=0; i<UI_NUM; i++)
  4035. {
  4036. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  4037. {
  4038. // continue;
  4039. }
  4040. // rt_stat_printf_m2(i,&g_ui[i].m2_stat);
  4041. rt_stat_printf_q16(&g_ui[i].e_stat);
  4042. // rt_stat_printf_q16(&g_ui[i].p_stat);
  4043. }
  4044. return 0;
  4045. }
  4046. int sw_ui_printf_m(void)
  4047. {
  4048. int i;
  4049. rt_printf("UI通道:\r\n");
  4050. rt_printf("name\t\t\tmin\t\tmax\t\tavg\t\tsum\t\tcnt\r\n");
  4051. for(i=0; i<UI_NUM; i++)
  4052. {
  4053. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  4054. {
  4055. // continue;
  4056. }
  4057. rt_stat_printf_m2(i,&g_ui[i].m2_stat);
  4058. }
  4059. return 0;
  4060. }
  4061. int sw_ui_printf_p(void)
  4062. {
  4063. int i;
  4064. rt_printf("UI通道:\r\n");
  4065. rt_printf("name\t\t\tmin\t\tmax\t\tavg\t\tsum\t\tcnt\r\n");
  4066. for(i=0; i<UI_NUM; i++)
  4067. {
  4068. if(g_ui[i].chn_index == CFG_ADC_CHANNEL_ZERO)
  4069. {
  4070. // continue;
  4071. }
  4072. rt_stat_printf_q16(&g_ui[i].p_stat);
  4073. }
  4074. return 0;
  4075. }
  4076. int sw_ui_temp(void)
  4077. {
  4078. int i;
  4079. float t;
  4080. rt_printf("温度校正系数[当前温度:%f]:\r\n",
  4081. #if defined TMP_CHIP_DS18B20
  4082. ds18b20_get_temp()
  4083. #elif defined TMP_CHIP_GX21M15
  4084. gx21m15_get_temp()
  4085. #endif
  4086. );
  4087. for(i=0; i<EQU_SLOT_AC_NUM;i++)
  4088. {
  4089. factor_temp_get(equ_ac_index_to_slot(i),&t);
  4090. rt_printf("%d[slot=%02d,temp=%f]:%f.\r\n",i,equ_ac_index_to_slot(i),t,g_temp_factor[i]);
  4091. }
  4092. rt_printf("谐波校正系数[次数=%d]:\r\n",g_harmonic_num);
  4093. for(i=0; i<CFG_ADC_DOTS_PER_PERIOD/2;i++)
  4094. {
  4095. rt_printf("%02d\t%f.\r\n",i,g_harmonic_factor[i]);
  4096. }
  4097. return 0;
  4098. }
  4099. /*------------------------------ 文件结束 -------------------------------------
  4100. */