LimitEventnewService.java 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167
  1. package com.gyee.generation.service;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
  4. import com.gyee.common.contant.ContantXk;
  5. import com.gyee.common.model.PointData;
  6. import com.gyee.generation.init.CacheContext;
  7. import com.gyee.generation.model.auto.*;
  8. import com.gyee.generation.model.vo.StatData;
  9. import com.gyee.generation.model.vo.StatusDetailValue;
  10. import com.gyee.generation.model.vo.StatusValue;
  11. import com.gyee.generation.service.auto.IProEconBrownoutsEvent2Service;
  12. import com.gyee.generation.service.auto.IProEconBrownoutsEventService;
  13. import com.gyee.generation.service.auto.IProEconMainBrownouts2Service;
  14. import com.gyee.generation.service.auto.IProEconMainBrownoutsService;
  15. import com.gyee.generation.util.DateUtils;
  16. import com.gyee.generation.util.StringUtils;
  17. import com.gyee.generation.util.realtimesource.IEdosUtil;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import org.springframework.beans.factory.annotation.Value;
  21. import org.springframework.stereotype.Service;
  22. import javax.annotation.Resource;
  23. import java.util.*;
  24. import java.util.stream.Collectors;
  25. @Service
  26. public class LimitEventnewService {
  27. @Resource
  28. private IProEconBrownoutsEventService proEconBrownoutsEventService;
  29. @Resource
  30. private IProEconMainBrownoutsService proEconMainBrownoutsService;
  31. @Resource
  32. private IProEconBrownoutsEvent2Service proEconBrownoutsEvent2Service;
  33. @Resource
  34. private IProEconMainBrownouts2Service proEconMainBrownouts2Service;
  35. @Resource
  36. private IEdosUtil edosUtil;
  37. @Value("${frequency.powerrationing}")
  38. private Integer frequency;
  39. public static Logger logger = LoggerFactory.getLogger(ShutdownnewService.class);
  40. public void execBrownouts(Date recordDate) throws Exception {
  41. Map<String, ProEconBrownoutsEvent> oldBrownoutsStatusMap = new HashMap<>();
  42. Map<String, ProEconBrownoutsEvent2> oldBrownoutsStatus2Map = new HashMap<>();
  43. Map<String, ProEconMainBrownouts> oldMainBrownoutsMap = new HashMap<>();
  44. Map<String, ProEconMainBrownouts2> oldMainBrownouts2Map = new HashMap<>();
  45. List<String> wpStatusIdLs = new ArrayList<>();
  46. List<String> wtStatusIdLs = new ArrayList<>();
  47. List<String> wpSpeedIdLs = new ArrayList<>();
  48. List<String> wtSpeedIdLs = new ArrayList<>();
  49. List<String> wpPowerIdLs = new ArrayList<>();
  50. List<String> wtPowerIdLs = new ArrayList<>();
  51. Map<String, PointData> wpStatusMap = new HashMap<>();
  52. Map<String, PointData> wtStatusMap = new HashMap<>();
  53. Map<String, PointData> wpSpeedMap = new HashMap<>();
  54. Map<String, PointData> wtSpeedMap = new HashMap<>();
  55. Map<String, PointData> wpPowerMap = new HashMap<>();
  56. Map<String, PointData> wtPowerMap = new HashMap<>();
  57. List<ProBasicPowerstation> wpls=new ArrayList<>();
  58. for (ProBasicPowerstation wp : CacheContext.wpls) {
  59. if(wp.getId().contains("GDC"))
  60. {
  61. continue;
  62. }
  63. wpls.add(wp);
  64. }
  65. for (ProBasicPowerstation wp :wpls) {
  66. //初始化将所有风场编号作为key,value全部赋值为null
  67. oldMainBrownoutsMap.put(wp.getId(), null);
  68. oldMainBrownouts2Map.put(wp.getId(), null);
  69. Map<String, ProBasicPowerstationPoint> wppointmap = CacheContext.wppointmap.get(wp.getId());
  70. //取实时状态数据 赋值给status
  71. if (wppointmap.containsKey(ContantXk.CZZT)) {
  72. ProBasicPowerstationPoint mxztPoint = wppointmap.get(ContantXk.CZZT);
  73. wpStatusIdLs.add(mxztPoint.getNemCode());
  74. }
  75. //取实时风速数据
  76. if (wppointmap.containsKey(ContantXk.SSPJFS)) {
  77. ProBasicPowerstationPoint mxztPoint = wppointmap.get(ContantXk.SSPJFS);
  78. wpSpeedIdLs.add(mxztPoint.getNemCode());
  79. }
  80. //取实时功率数据
  81. if (wppointmap.containsKey(ContantXk.SSZGL)) {
  82. ProBasicPowerstationPoint mxztPoint = wppointmap.get(ContantXk.SSZGL);
  83. wpPowerIdLs.add(mxztPoint.getNemCode());
  84. }
  85. }
  86. List<PointData> wpStatusLs = edosUtil.getHistMatrix(wpStatusIdLs,recordDate.getTime()/1000);
  87. List<PointData> wpSpeedLs = edosUtil.getHistMatrix(wpSpeedIdLs,recordDate.getTime()/1000);
  88. List<PointData> wpPowerLs = edosUtil.getHistMatrix(wpPowerIdLs,recordDate.getTime()/1000);
  89. if (wpStatusLs.size() == wpls.size() && wpSpeedLs.size() ==wpls.size() && wpPowerLs.size() == wpls.size()) {
  90. for (int i = 0; i < wpls.size(); i++) {
  91. ProBasicPowerstation wp = wpls.get(i);
  92. wpStatusMap.put(wp.getId(), wpStatusLs.get(i));
  93. wpSpeedMap.put(wp.getId(), wpSpeedLs.get(i));
  94. wpPowerMap.put(wp.getId(), wpPowerLs.get(i));
  95. }
  96. }
  97. List<ProBasicEquipment> wtls=new ArrayList<>();
  98. for (ProBasicEquipment wt : CacheContext.wtls) {
  99. if(wt.getWindpowerstationId().contains("GDC"))
  100. {
  101. continue;
  102. }
  103. wtls.add(wt);
  104. }
  105. for (ProBasicEquipment wt :wtls) {
  106. //初始化将所有风机编号作为key,value全部赋值为null
  107. oldBrownoutsStatusMap.put(wt.getId(), null);
  108. oldBrownoutsStatus2Map.put(wt.getId(), null);
  109. Map<String, ProBasicEquipmentPoint> windturbinetestingpointnewMap = CacheContext.wtpAimap.get(wt.getId());
  110. //取实时状态数据 赋值给status
  111. if (windturbinetestingpointnewMap.containsKey(ContantXk.MXZT)) {
  112. ProBasicEquipmentPoint mxztPoint = windturbinetestingpointnewMap.get(ContantXk.MXZT);
  113. wtStatusIdLs.add(mxztPoint.getNemCode());
  114. }
  115. //取实时风速数据
  116. if (windturbinetestingpointnewMap.containsKey(ContantXk.CJ_SSFS)) {
  117. ProBasicEquipmentPoint mxztPoint = windturbinetestingpointnewMap.get(ContantXk.CJ_SSFS);
  118. wtSpeedIdLs.add(mxztPoint.getNemCode());
  119. }
  120. //取实时功率数据
  121. if (windturbinetestingpointnewMap.containsKey(ContantXk.CJ_SSGL)) {
  122. ProBasicEquipmentPoint mxztPoint = windturbinetestingpointnewMap.get(ContantXk.CJ_SSGL);
  123. wtPowerIdLs.add(mxztPoint.getNemCode());
  124. }
  125. }
  126. List<PointData> wtStatusLs = edosUtil.getRealData(wtStatusIdLs);
  127. List<PointData> wtSpeedLs = edosUtil.getRealData(wtSpeedIdLs);
  128. List<PointData> wtPowerLs = edosUtil.getRealData(wtPowerIdLs);
  129. if (wtStatusLs.size() == wtls.size() && wtSpeedLs.size() == wtls.size() && wtPowerLs.size() == wtls.size()) {
  130. for (int i = 0; i < wtls.size(); i++) {
  131. ProBasicEquipment wt = wtls.get(i);
  132. wtStatusMap.put(wt.getId(), wtStatusLs.get(i));
  133. wtSpeedMap.put(wt.getId(), wtSpeedLs.get(i));
  134. wtPowerMap.put(wt.getId(), wtPowerLs.get(i));
  135. }
  136. }
  137. //******************************************************************************************************/
  138. //读取数据库存在的恢复时间为NULL的数据,并通过风机编号把数据遍历到对应的map
  139. QueryWrapper<ProEconMainBrownouts> queryWrapper = new QueryWrapper<>();
  140. queryWrapper.isNull("start_Time");
  141. queryWrapper.orderByDesc("stop_Time");
  142. List<ProEconMainBrownouts> oldStatusQuery = proEconMainBrownoutsService.list(queryWrapper).stream().collect(Collectors.toList());
  143. for (ProEconMainBrownouts oldMainBrownouts : oldStatusQuery) {
  144. if (oldMainBrownoutsMap.containsKey(oldMainBrownouts.getWindpowerstationId())) {
  145. oldMainBrownoutsMap.put(oldMainBrownouts.getWindpowerstationId(), oldMainBrownouts);
  146. }
  147. }
  148. QueryWrapper<ProEconMainBrownouts2> queryWrapper2 = new QueryWrapper<>();
  149. queryWrapper2.isNull("start_Time");
  150. queryWrapper2.orderByDesc("stop_Time");
  151. List<ProEconMainBrownouts2> oldStatus2Query = proEconMainBrownouts2Service.list(queryWrapper2).stream().collect(Collectors.toList());
  152. for (ProEconMainBrownouts2 oldMainBrownouts2 : oldStatus2Query) {
  153. if (oldMainBrownouts2Map.containsKey(oldMainBrownouts2.getWindpowerstationId())) {
  154. oldMainBrownouts2Map.put(oldMainBrownouts2.getWindpowerstationId(), oldMainBrownouts2);
  155. }
  156. }
  157. QueryWrapper<ProEconBrownoutsEvent> queryWrapper3 = new QueryWrapper<>();
  158. queryWrapper3.isNull("start_Time");
  159. queryWrapper3.orderByDesc("stop_Time");
  160. List<ProEconBrownoutsEvent> oldStatus3Query = proEconBrownoutsEventService.list(queryWrapper3).stream().collect(Collectors.toList());
  161. for (ProEconBrownoutsEvent oldBrownouts : oldStatus3Query) {
  162. if (oldBrownoutsStatusMap.containsKey(oldBrownouts.getWindturbineId())) {
  163. oldBrownoutsStatusMap.put(oldBrownouts.getWindturbineId(), oldBrownouts);
  164. }
  165. }
  166. QueryWrapper<ProEconBrownoutsEvent2> queryWrapper4 = new QueryWrapper<>();
  167. queryWrapper4.isNull("start_Time");
  168. queryWrapper3.orderByDesc("stop_Time");
  169. List<ProEconBrownoutsEvent2> oldStatus4Query = proEconBrownoutsEvent2Service.list(queryWrapper4).stream().collect(Collectors.toList());
  170. for (ProEconBrownoutsEvent2 oldBrownouts2 : oldStatus4Query) {
  171. if (oldBrownoutsStatus2Map.containsKey(oldBrownouts2.getWindturbineId())) {
  172. oldBrownoutsStatus2Map.put(oldBrownouts2.getWindturbineId(), oldBrownouts2);
  173. }
  174. }
  175. //*************************主表数据计算*****************************************************************************/
  176. List<ProEconMainBrownouts2> updateMainBrownouts2ls = new ArrayList<>();
  177. List<ProEconMainBrownouts> updateMainBrownoutsls = new ArrayList<>();
  178. List<ProEconMainBrownouts2> insertMainBrownouts2ls = new ArrayList<>();
  179. List<ProEconMainBrownouts> insertMainBrownoutsls = new ArrayList<>();
  180. //遍历PG数据库中存在的记录,恢复时间为空的集合
  181. for (String wpId : oldMainBrownoutsMap.keySet()) {
  182. ProEconMainBrownouts mainBrownouts = null;
  183. ProEconMainBrownouts2 mainBrownouts2 = null;
  184. if (oldMainBrownoutsMap.containsKey(wpId)) {
  185. mainBrownouts = oldMainBrownoutsMap.get(wpId);
  186. }
  187. if (oldMainBrownouts2Map.containsKey(wpId)) {
  188. mainBrownouts2 = oldMainBrownouts2Map.get(wpId);
  189. }
  190. if (wpStatusMap.containsKey(wpId)) {
  191. PointData wpPoint = wpStatusMap.get(wpId);
  192. //获取当前时间
  193. Date currentTime = recordDate;
  194. if (wpPoint.getPointValueInDouble() == StatusValue.XD.getCode() ) {
  195. if (StringUtils.empty(mainBrownouts)) {
  196. mainBrownouts=new ProEconMainBrownouts();
  197. intialMainBrownouts(insertMainBrownoutsls, wpId, wpStatusMap, wpSpeedMap, wpPowerMap, currentTime, mainBrownouts);
  198. }
  199. if (StringUtils.empty(mainBrownouts2)) {
  200. mainBrownouts2=new ProEconMainBrownouts2();
  201. intialMainBrownouts2(insertMainBrownouts2ls, wpId, wpStatusMap, wpSpeedMap, wpPowerMap, currentTime, mainBrownouts2);
  202. }
  203. }else {
  204. if (StringUtils.notEmp(mainBrownouts) ) {
  205. finishMainBrownouts(updateMainBrownoutsls, wpId, mainBrownouts, currentTime);
  206. }
  207. if (StringUtils.notEmp(mainBrownouts2)) {
  208. finishMainBrownouts2(updateMainBrownouts2ls, wpId, wpStatusMap, wpSpeedMap, wpPowerMap, mainBrownouts2, currentTime);
  209. }
  210. }
  211. }
  212. List<ProEconMainBrownouts> templs = new ArrayList<>();
  213. for (ProEconMainBrownouts vo : insertMainBrownoutsls) {
  214. templs.add(vo);
  215. if (templs.size() == 100) {
  216. proEconMainBrownoutsService.saveBatch(templs);
  217. templs = new ArrayList<>();
  218. }
  219. }
  220. if (!templs.isEmpty()) {
  221. proEconMainBrownoutsService.saveBatch(templs);
  222. }
  223. List<ProEconMainBrownouts2> templs2 = new ArrayList<>();
  224. for (ProEconMainBrownouts2 vo : insertMainBrownouts2ls) {
  225. templs2.add(vo);
  226. if (templs2.size() == 100) {
  227. proEconMainBrownouts2Service.saveBatch(templs2);
  228. templs2 = new ArrayList<>();
  229. }
  230. }
  231. if (!templs2.isEmpty()) {
  232. proEconMainBrownouts2Service.saveBatch(templs2);
  233. }
  234. for (ProEconMainBrownouts vo : updateMainBrownoutsls) {
  235. UpdateWrapper<ProEconMainBrownouts> updateWrapper = new UpdateWrapper<>();
  236. // updateWrapper.set("start_time", vo.getStartTime());
  237. // updateWrapper.set("loss_power", vo.getLossPower());
  238. // updateWrapper.set("stop_hours", vo.getStopHours());
  239. // proEconMainBrownoutsService.update(vo, updateWrapper);
  240. proEconMainBrownoutsService.updateMainBrownouts(vo.getStartTime(),vo.getLossPower(),vo.getStopHours(),vo.getId());
  241. }
  242. for (ProEconMainBrownouts2 vo : updateMainBrownouts2ls) {
  243. UpdateWrapper<ProEconMainBrownouts2> updateWrapper = new UpdateWrapper<>();
  244. // updateWrapper.set("start_time", vo.getStartTime());
  245. // updateWrapper.set("loss_power", vo.getLossPower());
  246. // updateWrapper.set("stop_hours", vo.getStopHours());
  247. // proEconMainBrownouts2Service.update(vo, updateWrapper);
  248. proEconMainBrownouts2Service.updateMainBrownouts2(vo.getStartTime(),vo.getLossPower(),vo.getStopHours(),vo.getId());
  249. }
  250. }
  251. //*************************主表数据计算*****************************************************************************/
  252. //*************************子表数据计算*****************************************************************************/
  253. extractedBrownouts(oldBrownoutsStatusMap, wtStatusMap, wtSpeedMap, wtPowerMap, insertMainBrownoutsls);
  254. extractedBrownouts(oldBrownoutsStatusMap, wtStatusMap, wtSpeedMap, wtPowerMap, updateMainBrownoutsls);
  255. extractedBrownouts2(oldBrownoutsStatus2Map, wtStatusMap, wtSpeedMap, wtPowerMap, insertMainBrownouts2ls);
  256. extractedBrownouts2(oldBrownoutsStatus2Map, wtStatusMap, wtSpeedMap, wtPowerMap, updateMainBrownouts2ls);
  257. //*************************子表数据计算*****************************************************************************/
  258. //******************************************************************************************************/
  259. }
  260. private void extractedBrownouts(Map<String, ProEconBrownoutsEvent> oldBrownoutsStatusMap, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, List<ProEconMainBrownouts> mainBrownoutsls) throws Exception {
  261. //遍历PG数据库中存在的记录,恢复时间为空的集合
  262. for (ProEconMainBrownouts mb : mainBrownoutsls) {
  263. List<ProBasicEquipment> wtls = CacheContext.wpwtmap.get(mb.getWindpowerstationId());
  264. List<ProEconBrownoutsEvent> updateBrownoutsEventls = new ArrayList<>();
  265. List<ProEconBrownoutsEvent> insertBrownoutsEventls = new ArrayList<>();
  266. for (ProBasicEquipment wt : wtls) {
  267. extractedProBasicEquipment(mb, oldBrownoutsStatusMap, wtStatusMap, wtSpeedMap, wtPowerMap, updateBrownoutsEventls, insertBrownoutsEventls, wt);
  268. }
  269. List<ProEconBrownoutsEvent> templs = new ArrayList<>();
  270. for (ProEconBrownoutsEvent vo : insertBrownoutsEventls) {
  271. templs.add(vo);
  272. if (templs.size() == 100) {
  273. proEconBrownoutsEventService.saveBatch(templs);
  274. templs = new ArrayList<>();
  275. }
  276. }
  277. if (!templs.isEmpty()) {
  278. proEconBrownoutsEventService.saveBatch(templs);
  279. }
  280. for (ProEconBrownoutsEvent vo : updateBrownoutsEventls) {
  281. UpdateWrapper<ProEconBrownoutsEvent> updateWrapper = new UpdateWrapper<>();
  282. // updateWrapper.set("start_time", vo.getStartTime());
  283. // updateWrapper.set("loss_power", vo.getLossPower());
  284. // updateWrapper.set("stop_hours", vo.getStopHours());
  285. // proEconBrownoutsEventService.update(vo, updateWrapper);
  286. proEconBrownoutsEventService.updateBrownouts(vo.getStartTime(),vo.getLossPower(),vo.getStopHours(),vo.getId());
  287. }
  288. }
  289. }
  290. private void extractedBrownouts2( Map<String, ProEconBrownoutsEvent2> oldBrownoutsStatus2Map, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, List<ProEconMainBrownouts2> mainBrownouts2ls) throws Exception {
  291. //遍历PG数据库中存在的记录,恢复时间为空的集合
  292. for (ProEconMainBrownouts2 mb : mainBrownouts2ls) {
  293. List<ProBasicEquipment> wtls = CacheContext.wpwtmap.get(mb.getWindpowerstationId());
  294. List<ProEconBrownoutsEvent2> updateBrownoutsEvent2ls = new ArrayList<>();
  295. List<ProEconBrownoutsEvent> updateBrownoutsEventls = new ArrayList<>();
  296. List<ProEconBrownoutsEvent2> insertBrownoutsEvent2ls = new ArrayList<>();
  297. List<ProEconBrownoutsEvent> insertBrownoutsEventls = new ArrayList<>();
  298. for (ProBasicEquipment wt : wtls) {
  299. extractedProBasicEquipment(mb, oldBrownoutsStatus2Map, wtStatusMap, wtSpeedMap, wtPowerMap, updateBrownoutsEvent2ls, insertBrownoutsEvent2ls, wt);
  300. }
  301. List<ProEconBrownoutsEvent2> templs2 = new ArrayList<>();
  302. for (ProEconBrownoutsEvent2 vo : insertBrownoutsEvent2ls) {
  303. templs2.add(vo);
  304. if (templs2.size() == 100) {
  305. proEconBrownoutsEvent2Service.saveBatch(templs2);
  306. templs2 = new ArrayList<>();
  307. }
  308. }
  309. if (!templs2.isEmpty()) {
  310. proEconBrownoutsEvent2Service.saveBatch(templs2);
  311. }
  312. for (ProEconBrownoutsEvent2 vo : updateBrownoutsEvent2ls) {
  313. UpdateWrapper<ProEconBrownoutsEvent2> updateWrapper = new UpdateWrapper<>();
  314. // updateWrapper.set("start_time", vo.getStartTime());
  315. // updateWrapper.set("loss_power", vo.getLossPower());
  316. // updateWrapper.set("stop_hours", vo.getStopHours());
  317. // proEconBrownoutsEvent2Service.update(vo, updateWrapper);
  318. proEconBrownoutsEvent2Service.updateBrownouts2(vo.getStartTime(),vo.getLossPower(),vo.getStopHours(),vo.getId());
  319. }
  320. }
  321. }
  322. private void extractedProBasicEquipment(ProEconMainBrownouts mb, Map<String, ProEconBrownoutsEvent> oldBrownoutsStatusMap, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, List<ProEconBrownoutsEvent> updateBrownoutsEventls, List<ProEconBrownoutsEvent> insertBrownoutsEventls, ProBasicEquipment wt) throws Exception {
  323. String wtId = wt.getId();
  324. ProEconBrownoutsEvent brownouts = null;
  325. if (oldBrownoutsStatusMap.containsKey(wtId)) {
  326. brownouts = oldBrownoutsStatusMap.get(wtId);
  327. }
  328. if (wtStatusMap.containsKey(wtId)) {
  329. PointData wtPoint = wtStatusMap.get(wtId);
  330. //获取当前时间
  331. Date currentTime = new Date(wtPoint.getPointTime());
  332. if (wtPoint.getPointValueInDouble() == StatusDetailValue.XDJCL.getCode() || wtPoint.getPointValueInDouble() == StatusDetailValue.XDTJ.getCode()) {
  333. if (StringUtils.empty(brownouts)) {
  334. brownouts=new ProEconBrownoutsEvent();
  335. intialBrownoutsEvent(mb, insertBrownoutsEventls, wtId, wtStatusMap, wtSpeedMap, wtPowerMap, currentTime, brownouts);
  336. }
  337. } else {
  338. if (StringUtils.notEmp(brownouts)) {
  339. finishBrownoutsEvent(updateBrownoutsEventls, wtId, brownouts, currentTime);
  340. }
  341. }
  342. }
  343. }
  344. private void extractedProBasicEquipment(ProEconMainBrownouts2 mb, Map<String, ProEconBrownoutsEvent2> oldBrownoutsStatus2Map, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, List<ProEconBrownoutsEvent2> updateBrownoutsEvent2ls, List<ProEconBrownoutsEvent2> insertBrownoutsEvent2ls, ProBasicEquipment wt) throws Exception {
  345. String wtId = wt.getId();
  346. ProEconBrownoutsEvent2 brownouts2 = null;
  347. if (oldBrownoutsStatus2Map.containsKey(wtId)) {
  348. brownouts2 = oldBrownoutsStatus2Map.get(wtId);
  349. }
  350. if (wtStatusMap.containsKey(wtId)) {
  351. PointData wtPoint = wtStatusMap.get(wtId);
  352. //获取当前时间
  353. Date currentTime = new Date(wtPoint.getPointTime());
  354. if (wtPoint.getPointValueInDouble() == StatusDetailValue.XDJCL.getCode() || wtPoint.getPointValueInDouble() == StatusDetailValue.XDTJ.getCode()) {
  355. if (StringUtils.empty(brownouts2)) {
  356. brownouts2=new ProEconBrownoutsEvent2();
  357. intialBrownoutsEvent2(mb, insertBrownoutsEvent2ls, wtId, wtStatusMap, wtSpeedMap, wtPowerMap, currentTime, brownouts2);
  358. }
  359. } else {
  360. if (StringUtils.notEmp(brownouts2)) {
  361. finishBrownoutsEvent2(mb, updateBrownoutsEvent2ls, wtId, wtStatusMap, wtSpeedMap, wtPowerMap, brownouts2, currentTime);
  362. }
  363. }
  364. }
  365. }
  366. private void intialBrownoutsEvent(ProEconMainBrownouts mb, List<ProEconBrownoutsEvent> insertBrownoutsEventls, String wtId, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, Date currentTime, ProEconBrownoutsEvent brownouts) throws Exception {
  367. brownouts.setMainId(mb.getId());
  368. brownouts.setId(StringUtils.getUUID());
  369. brownouts.setStopTime(currentTime);
  370. brownouts.setStartTime(null);
  371. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDTJ.getCode()) {
  372. brownouts.setStopTypeId(StatusDetailValue.XDTJ.getName());
  373. }
  374. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDJCL.getCode()) {
  375. brownouts.setStopTypeId(StatusDetailValue.XDJCL.getName());
  376. }
  377. if (wtSpeedMap.containsKey(wtId)) {
  378. brownouts.setWindSpeed(StringUtils.round(wtSpeedMap.get(wtId).getPointValueInDouble(), 2));
  379. }
  380. if (wtPowerMap.containsKey(wtId)) {
  381. brownouts.setLimitLoad(StringUtils.round(wtPowerMap.get(wtId).getPointValueInDouble(), 2));
  382. }
  383. Map<String, ProBasicEquipmentPoint> wtpointmap = CacheContext.wtpAimap.get(wtId);
  384. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  385. List<PointData> hsls = edosUtil.getHistStat(wtpointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  386. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  387. brownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  388. }
  389. brownouts.setWindpowerstationId(wtId);
  390. brownouts.setLossPower(0.0);
  391. insertBrownoutsEventls.add(brownouts);
  392. }
  393. private void intialBrownoutsEvent2(ProEconMainBrownouts2 mb, List<ProEconBrownoutsEvent2> insertBrownoutsEvent2ls, String wtId, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, Date currentTime, ProEconBrownoutsEvent2 brownouts) throws Exception {
  394. brownouts.setMainId(mb.getId());
  395. brownouts.setId(StringUtils.getUUID());
  396. brownouts.setStopTime(currentTime);
  397. brownouts.setStartTime(null);
  398. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDTJ.getCode()) {
  399. brownouts.setStopTypeId(StatusDetailValue.XDTJ.getName());
  400. }
  401. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDJCL.getCode()) {
  402. brownouts.setStopTypeId(StatusDetailValue.XDJCL.getName());
  403. }
  404. if (wtSpeedMap.containsKey(wtId)) {
  405. brownouts.setWindSpeed(StringUtils.round(wtSpeedMap.get(wtId).getPointValueInDouble(), 2));
  406. }
  407. if (wtPowerMap.containsKey(wtId)) {
  408. brownouts.setLimitLoad(StringUtils.round(wtPowerMap.get(wtId).getPointValueInDouble(), 2));
  409. }
  410. Map<String, ProBasicEquipmentPoint> wtpointmap = CacheContext.wtpAimap.get(wtId);
  411. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  412. List<PointData> hsls = edosUtil.getHistStat(wtpointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  413. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  414. brownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  415. }
  416. brownouts.setWindpowerstationId(wtId);
  417. brownouts.setLossPower(0.0);
  418. insertBrownoutsEvent2ls.add(brownouts);
  419. }
  420. private ProEconBrownoutsEvent2 intialBrownoutsEventnew2(ProEconMainBrownouts2 mb, String wtId, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, Date currentTime) throws Exception {
  421. ProEconBrownoutsEvent2 brownouts=new ProEconBrownoutsEvent2();
  422. brownouts.setMainId(mb.getId());
  423. brownouts.setId(StringUtils.getUUID());
  424. brownouts.setStopTime(currentTime);
  425. brownouts.setStartTime(null);
  426. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDTJ.getCode()) {
  427. brownouts.setStopTypeId(StatusDetailValue.XDTJ.getName());
  428. }
  429. if (wtStatusMap.get(wtId).getPointValueInDouble() == StatusDetailValue.XDJCL.getCode()) {
  430. brownouts.setStopTypeId(StatusDetailValue.XDJCL.getName());
  431. }
  432. if (wtSpeedMap.containsKey(wtId)) {
  433. brownouts.setWindSpeed(StringUtils.round(wtSpeedMap.get(wtId).getPointValueInDouble(), 2));
  434. }
  435. if (wtPowerMap.containsKey(wtId)) {
  436. brownouts.setLimitLoad(StringUtils.round(wtPowerMap.get(wtId).getPointValueInDouble(), 2));
  437. }
  438. Map<String, ProBasicEquipmentPoint> wtpointmap = CacheContext.wtpAimap.get(wtId);
  439. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  440. List<PointData> hsls = edosUtil.getHistStat(wtpointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  441. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  442. brownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  443. }
  444. brownouts.setWindpowerstationId(wtId);
  445. brownouts.setLossPower(0.0);
  446. return brownouts;
  447. }
  448. private void finishBrownoutsEvent2(ProEconMainBrownouts2 mb, List<ProEconBrownoutsEvent2> proEconBrownoutsEvent2ls, String wtId, Map<String, PointData> wtStatusMap, Map<String, PointData> wtSpeedMap, Map<String, PointData> wtPowerMap, ProEconBrownoutsEvent2 brownouts2, Date currentTime) throws Exception {
  449. brownouts2.setStartTime(currentTime);
  450. double timehour = DateUtils.hoursDiff2(brownouts2.getStartTime(), brownouts2.getStopTime());
  451. brownouts2.setStopHours(timehour);
  452. double losspower = calWpLossPower(wtId, brownouts2.getStartTime(), brownouts2.getStopTime());
  453. brownouts2.setLossPower(losspower);
  454. if (timehour <= 24) {
  455. proEconBrownoutsEvent2ls.add(brownouts2);
  456. } else {
  457. int days = DateUtils.daysDiff1(brownouts2.getStartTime(), brownouts2.getStopTime());
  458. Calendar c = Calendar.getInstance();
  459. Date startTime = brownouts2.getStartTime();
  460. c.setTime(brownouts2.getStopTime());
  461. c.set(Calendar.HOUR_OF_DAY, 23);
  462. c.set(Calendar.MINUTE, 59);
  463. c.set(Calendar.SECOND, 59);
  464. for (int i = 0; i < days; i++) {
  465. if (i == 0) {
  466. brownouts2.setStartTime(c.getTime());
  467. losspower = calLossPower(wtId, brownouts2.getStartTime(), brownouts2.getStopTime());
  468. brownouts2.setLossPower(losspower);
  469. proEconBrownoutsEvent2ls.add(brownouts2);
  470. } else {
  471. ProEconBrownoutsEvent2 newto =intialBrownoutsEventnew2(mb, wtId, wtStatusMap, wtSpeedMap, wtPowerMap, DateUtils.truncate(c.getTime()));
  472. if (i == days - 1) {
  473. newto.setStartTime(startTime);
  474. } else {
  475. newto.setStartTime(c.getTime());
  476. }
  477. losspower = calLossPower(wtId, newto.getStartTime(), newto.getStopTime());
  478. newto.setLossPower(losspower);
  479. proEconBrownoutsEvent2ls.add(newto);
  480. }
  481. c.add(Calendar.DAY_OF_MONTH, 1);
  482. }
  483. }
  484. }
  485. private void finishBrownoutsEvent(List<ProEconBrownoutsEvent> proEconBrownoutsEventls, String wtId, ProEconBrownoutsEvent item, Date currentTime) throws Exception {
  486. // if(currentStatus != 4 )
  487. // {
  488. item.setStartTime(currentTime);
  489. double timehour = DateUtils.hoursDiff2(item.getStartTime(), item.getStopTime());
  490. item.setStopHours(timehour);
  491. double losspower = calLossPower(wtId, item.getStartTime(), item.getStopTime());
  492. item.setLossPower(losspower);
  493. proEconBrownoutsEventls.add(item);
  494. }
  495. private void intialMainBrownouts(List<ProEconMainBrownouts> insertMainBrownoutsls, String wpId, Map<String, PointData> wpStatusMap, Map<String, PointData> wpSpeedMap, Map<String, PointData> wpPowerMap, Date currentTime, ProEconMainBrownouts mainBrownouts) throws Exception {
  496. mainBrownouts.setId(StringUtils.getUUID());
  497. mainBrownouts.setStopTime(currentTime);
  498. mainBrownouts.setStartTime(null);
  499. if (wpStatusMap.get(wpId).getPointValueInDouble() == StatusValue.XD.getCode()) {
  500. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  501. }
  502. if (wpStatusMap.get(wpId).getPointValueInDouble() == StatusValue.XD.getCode()) {
  503. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  504. }
  505. if (wpSpeedMap.containsKey(wpId)) {
  506. mainBrownouts.setWindSpeed(StringUtils.round(wpSpeedMap.get(wpId).getPointValueInDouble(), 2));
  507. }
  508. if (wpPowerMap.containsKey(wpId)) {
  509. mainBrownouts.setLimitLoad(StringUtils.round(wpPowerMap.get(wpId).getPointValueInDouble(), 2));
  510. }
  511. Map<String, ProBasicPowerstationPoint> wppointmap = CacheContext.wppointmap.get(wpId);
  512. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  513. List<PointData> hsls = edosUtil.getHistStat(wppointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  514. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  515. mainBrownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  516. }
  517. mainBrownouts.setWindpowerstationId(wpId);
  518. mainBrownouts.setLossPower(0.0);
  519. insertMainBrownoutsls.add(mainBrownouts);
  520. }
  521. private void intialMainBrownouts2(List<ProEconMainBrownouts2> insertMainBrownouts2ls, String wpId, Map<String, PointData> wpStatusMap, Map<String, PointData> wpSpeedMap, Map<String, PointData> wpPowerMap, Date currentTime, ProEconMainBrownouts2 mainBrownouts) throws Exception {
  522. mainBrownouts.setId(StringUtils.getUUID());
  523. mainBrownouts.setStopTime(currentTime);
  524. mainBrownouts.setStartTime(null);
  525. if (wpStatusMap.get(wpId).getPointValueInDouble() ==StatusValue.XD.getCode()) {
  526. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  527. }
  528. if (wpStatusMap.get(wpId).getPointValueInDouble() == StatusValue.XD.getCode()) {
  529. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  530. }
  531. if (wpSpeedMap.containsKey(wpId)) {
  532. mainBrownouts.setWindSpeed(StringUtils.round(wpSpeedMap.get(wpId).getPointValueInDouble(), 2));
  533. }
  534. if (wpPowerMap.containsKey(wpId)) {
  535. mainBrownouts.setLimitLoad(StringUtils.round(wpPowerMap.get(wpId).getPointValueInDouble(), 2));
  536. }
  537. Map<String, ProBasicPowerstationPoint> wppointmap = CacheContext.wppointmap.get(wpId);
  538. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  539. List<PointData> hsls = edosUtil.getHistStat(wppointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  540. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  541. mainBrownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  542. }
  543. mainBrownouts.setWindpowerstationId(wpId);
  544. mainBrownouts.setLossPower(0.0);
  545. insertMainBrownouts2ls.add(mainBrownouts);
  546. }
  547. private ProEconMainBrownouts2 intialMainBrownoutsnew2(String wpId, Map<String, PointData> wpStatusMap, Map<String, PointData> wpSpeedMap, Map<String, PointData> wpPowerMap, Date currentTime) throws Exception {
  548. ProEconMainBrownouts2 mainBrownouts=new ProEconMainBrownouts2();
  549. mainBrownouts.setId(StringUtils.getUUID());
  550. mainBrownouts.setStopTime(currentTime);
  551. mainBrownouts.setStartTime(null);
  552. if (wpStatusMap.get(wpId).getPointValueInDouble() == StatusValue.XD.getCode()) {
  553. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  554. }
  555. if (wpStatusMap.get(wpId).getPointValueInDouble() == StatusValue.XD.getCode()) {
  556. mainBrownouts.setStopTypeId(StatusValue.XD.getName());
  557. }
  558. if (wpSpeedMap.containsKey(wpId)) {
  559. mainBrownouts.setWindSpeed(StringUtils.round(wpSpeedMap.get(wpId).getPointValueInDouble(), 2));
  560. }
  561. if (wpPowerMap.containsKey(wpId)) {
  562. mainBrownouts.setLimitLoad(StringUtils.round(wpPowerMap.get(wpId).getPointValueInDouble(), 2));
  563. }
  564. Map<String, ProBasicPowerstationPoint> wppointmap = CacheContext.wppointmap.get(wpId);
  565. long pried = DateUtils.secondsDiff(DateUtils.addMinutes(currentTime, -5), currentTime);
  566. List<PointData> hsls = edosUtil.getHistStat(wppointmap.get(ContantXk.SSZGL), DateUtils.addMinutes(currentTime, -5).getTime() / 1000, currentTime.getTime() / 1000, 1L, pried, StatData.MAX.getValue());
  567. if (StringUtils.notEmp(hsls) && hsls.size() > 0) {
  568. mainBrownouts.setThisLoad(hsls.get(0).getPointValueInDouble());
  569. }
  570. mainBrownouts.setWindpowerstationId(wpId);
  571. mainBrownouts.setLossPower(0.0);
  572. return mainBrownouts;
  573. }
  574. private void finishMainBrownouts2(List<ProEconMainBrownouts2> proEconMainBrownouts2ls, String wpId, Map<String, PointData> wpStatusMap, Map<String, PointData> wpSpeedMap, Map<String, PointData> wpPowerMap, ProEconMainBrownouts2 mainBrownouts2, Date currentTime) throws Exception {
  575. mainBrownouts2.setStartTime(currentTime);
  576. double timehour = DateUtils.hoursDiff2(mainBrownouts2.getStartTime(), mainBrownouts2.getStopTime());
  577. mainBrownouts2.setStopHours(timehour);
  578. double losspower = calWpLossPower(wpId, mainBrownouts2.getStartTime(), mainBrownouts2.getStopTime());
  579. mainBrownouts2.setLossPower(losspower);
  580. if (timehour <= 24) {
  581. proEconMainBrownouts2ls.add(mainBrownouts2);
  582. } else {
  583. int days = DateUtils.daysDiff1(mainBrownouts2.getStartTime(), mainBrownouts2.getStopTime());
  584. Calendar c = Calendar.getInstance();
  585. Date startTime = mainBrownouts2.getStartTime();
  586. c.setTime(mainBrownouts2.getStopTime());
  587. c.set(Calendar.HOUR_OF_DAY, 23);
  588. c.set(Calendar.MINUTE, 59);
  589. c.set(Calendar.SECOND, 59);
  590. for (int i = 0; i < days; i++) {
  591. if (i == 0) {
  592. mainBrownouts2.setStartTime(c.getTime());
  593. losspower = calWpLossPower(wpId, mainBrownouts2.getStartTime(), mainBrownouts2.getStopTime());
  594. mainBrownouts2.setLossPower(losspower);
  595. proEconMainBrownouts2ls.add(mainBrownouts2);
  596. } else {
  597. ProEconMainBrownouts2 newpo = intialMainBrownoutsnew2(wpId, wpStatusMap, wpSpeedMap, wpPowerMap, DateUtils.truncate(c.getTime()));
  598. if (i == days - 1) {
  599. newpo.setStartTime(startTime);
  600. } else {
  601. newpo.setStartTime(c.getTime());
  602. }
  603. losspower = calWpLossPower(wpId, newpo.getStartTime(), newpo.getStopTime());
  604. newpo.setLossPower(losspower);
  605. proEconMainBrownouts2ls.add(newpo);
  606. }
  607. c.add(Calendar.DAY_OF_MONTH, 1);
  608. }
  609. }
  610. }
  611. private void finishMainBrownouts(List<ProEconMainBrownouts> proEconMainBrownoutsls, String wpId, ProEconMainBrownouts item, Date currentTime) throws Exception {
  612. // if(currentStatus != 4 )
  613. // {
  614. item.setStartTime(currentTime);
  615. double timehour = DateUtils.hoursDiff2(item.getStartTime(), item.getStopTime());
  616. item.setStopHours(timehour);
  617. double losspower = calWpLossPower(wpId, item.getStartTime(), item.getStopTime());
  618. item.setLossPower(losspower);
  619. proEconMainBrownoutsls.add(item);
  620. }
  621. //修改后的限电损失统计,通过时序数据库历史切面计算
  622. private Double calWpLossPower(String wpId, Date startDate, Date endDate) throws Exception {
  623. double result = 0.0;
  624. Map<String, Map<String, ProBasicPowerstationPoint>> wppointmap = CacheContext.wppointmap;
  625. Map<String, ProBasicPowerstationPoint> pointmap = wppointmap.get(wpId);
  626. Calendar c1 = Calendar.getInstance();
  627. c1.setTime(startDate);
  628. Calendar c2 = Calendar.getInstance();
  629. c2.setTime(endDate);
  630. //判定限电是否跨年
  631. if (endDate.after(startDate) && c1.get(Calendar.YEAR) == c2.get(Calendar.YEAR)) {
  632. //年限电欠发损失电量
  633. if (pointmap.containsKey(ContantXk.NXDTJSSDL)) {
  634. double beginvalue;
  635. double endvalue;
  636. List<String> pointid = new ArrayList<>();
  637. pointid.add(pointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  638. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  639. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  640. if (xdbegin.size() == 1 && xdend.size() == 1) {
  641. beginvalue = xdbegin.get(0).getPointValueInDouble();
  642. endvalue = xdend.get(0).getPointValueInDouble();
  643. if (endvalue > beginvalue) {
  644. result = result + (endvalue - beginvalue);
  645. }
  646. }
  647. }
  648. //年限电损失电量
  649. if (pointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  650. double beginvalue;
  651. double endvalue;
  652. List<String> pointid = new ArrayList<>();
  653. pointid.add(pointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  654. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  655. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  656. if (xdbegin.size() == 1 && xdend.size() == 1) {
  657. beginvalue = xdbegin.get(0).getPointValueInDouble();
  658. endvalue = xdend.get(0).getPointValueInDouble();
  659. if (endvalue > beginvalue) {
  660. result = result + (endvalue - beginvalue);
  661. }
  662. }
  663. }
  664. } else {
  665. Calendar c = Calendar.getInstance();
  666. c.setTime(DateUtils.truncate(startDate));
  667. c.add(Calendar.DAY_OF_MONTH, 1);
  668. //获得1月1日零点值
  669. Date endtime = c.getTime();
  670. //年限电欠发损失电量
  671. if (pointmap.containsKey(ContantXk.NXDTJSSDL)) {
  672. double beginvalue;
  673. double endvalue;
  674. List<String> pointid = new ArrayList<>();
  675. pointid.add(pointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  676. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  677. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endtime.getTime() / 1000);
  678. if (xdbegin.size() == 1 && xdend.size() == 1) {
  679. beginvalue = xdbegin.get(0).getPointValueInDouble();
  680. endvalue = xdend.get(0).getPointValueInDouble();
  681. if (endvalue > beginvalue) {
  682. result = result + (endvalue - beginvalue);
  683. }
  684. }
  685. }
  686. //年限电损失电量
  687. if (pointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  688. double beginvalue;
  689. double endvalue;
  690. List<String> pointid = new ArrayList<>();
  691. pointid.add(pointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  692. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  693. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endtime.getTime() / 1000);
  694. if (xdbegin.size() == 1 && xdend.size() == 1) {
  695. beginvalue = xdbegin.get(0).getPointValueInDouble();
  696. endvalue = xdend.get(0).getPointValueInDouble();
  697. if (endvalue > beginvalue) {
  698. result = result + (endvalue - beginvalue);
  699. }
  700. }
  701. }
  702. //日限电欠发损失电量
  703. if (pointmap.containsKey(ContantXk.NXDTJSSDL)) {
  704. double endvalue;
  705. List<String> pointid = new ArrayList<>();
  706. pointid.add(pointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  707. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  708. if (xdend.size() == 1) {
  709. endvalue = xdend.get(0).getPointValueInDouble();
  710. if (endvalue > 0) {
  711. result = result + endvalue;
  712. }
  713. }
  714. }
  715. //日限电损失电量
  716. if (pointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  717. double endvalue;
  718. List<String> pointid = new ArrayList<>();
  719. pointid.add(pointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  720. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  721. if (xdend.size() == 1) {
  722. endvalue = xdend.get(0).getPointValueInDouble();
  723. if (endvalue > 0) {
  724. result = result + endvalue;
  725. }
  726. }
  727. }
  728. }
  729. return result;
  730. }
  731. //修改后的限电损失统计,通过时序数据库历史切面计算
  732. private Double calLossPower(String windturbineId, Date startDate, Date endDate) throws Exception {
  733. double result = 0.0;
  734. Map<String, Map<String, ProBasicEquipmentPoint>> wtpAimap = CacheContext.wtpAimap;
  735. Map<String, ProBasicEquipmentPoint> wtpointmap = wtpAimap.get(windturbineId);
  736. Calendar c1 = Calendar.getInstance();
  737. c1.setTime(startDate);
  738. Calendar c2 = Calendar.getInstance();
  739. c2.setTime(endDate);
  740. //判定限电是否跨年
  741. if (endDate.after(startDate) && c1.get(Calendar.YEAR) == c2.get(Calendar.YEAR)) {
  742. //年限电欠发损失电量
  743. if (wtpointmap.containsKey(ContantXk.NXDTJSSDL)) {
  744. double beginvalue;
  745. double endvalue;
  746. List<String> pointid = new ArrayList<>();
  747. pointid.add(wtpointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  748. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  749. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  750. if (xdbegin.size() == 1 && xdend.size() == 1) {
  751. beginvalue = xdbegin.get(0).getPointValueInDouble();
  752. endvalue = xdend.get(0).getPointValueInDouble();
  753. if (endvalue > beginvalue) {
  754. result = result + (endvalue - beginvalue);
  755. }
  756. }
  757. }
  758. //年限电损失电量
  759. if (wtpointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  760. double beginvalue;
  761. double endvalue;
  762. List<String> pointid = new ArrayList<>();
  763. pointid.add(wtpointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  764. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  765. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  766. if (xdbegin.size() == 1 && xdend.size() == 1) {
  767. beginvalue = xdbegin.get(0).getPointValueInDouble();
  768. endvalue = xdend.get(0).getPointValueInDouble();
  769. if (endvalue > beginvalue) {
  770. result = result + (endvalue - beginvalue);
  771. }
  772. }
  773. }
  774. } else {
  775. Calendar c = Calendar.getInstance();
  776. c.setTime(DateUtils.truncate(startDate));
  777. c.add(Calendar.DAY_OF_MONTH, 1);
  778. //获得1月1日零点值
  779. Date endtime = c.getTime();
  780. //年限电欠发损失电量
  781. if (wtpointmap.containsKey(ContantXk.NXDTJSSDL)) {
  782. double beginvalue;
  783. double endvalue;
  784. List<String> pointid = new ArrayList<>();
  785. pointid.add(wtpointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  786. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  787. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endtime.getTime() / 1000);
  788. if (xdbegin.size() == 1 && xdend.size() == 1) {
  789. beginvalue = xdbegin.get(0).getPointValueInDouble();
  790. endvalue = xdend.get(0).getPointValueInDouble();
  791. if (endvalue > beginvalue) {
  792. result = result + (endvalue - beginvalue);
  793. }
  794. }
  795. }
  796. //年限电损失电量
  797. if (wtpointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  798. double beginvalue;
  799. double endvalue;
  800. List<String> pointid = new ArrayList<>();
  801. pointid.add(wtpointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  802. List<PointData> xdbegin = edosUtil.getHistMatrix(pointid, startDate.getTime() / 1000);
  803. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endtime.getTime() / 1000);
  804. if (xdbegin.size() == 1 && xdend.size() == 1) {
  805. beginvalue = xdbegin.get(0).getPointValueInDouble();
  806. endvalue = xdend.get(0).getPointValueInDouble();
  807. if (endvalue > beginvalue) {
  808. result = result + (endvalue - beginvalue);
  809. }
  810. }
  811. }
  812. //日限电欠发损失电量
  813. if (wtpointmap.containsKey(ContantXk.NXDTJSSDL)) {
  814. double endvalue;
  815. List<String> pointid = new ArrayList<>();
  816. pointid.add(wtpointmap.get(ContantXk.NXDTJSSDL).getNemCode());
  817. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  818. if (xdend.size() == 1) {
  819. endvalue = xdend.get(0).getPointValueInDouble();
  820. if (endvalue > 0) {
  821. result = result + endvalue;
  822. }
  823. }
  824. }
  825. //日限电损失电量
  826. if (wtpointmap.containsKey(ContantXk.NXDJCLSSDL)) {
  827. double endvalue;
  828. List<String> pointid = new ArrayList<>();
  829. pointid.add(wtpointmap.get(ContantXk.NXDJCLSSDL).getNemCode());
  830. List<PointData> xdend = edosUtil.getHistMatrix(pointid, endDate.getTime() / 1000);
  831. if (xdend.size() == 1) {
  832. endvalue = xdend.get(0).getPointValueInDouble();
  833. if (endvalue > 0) {
  834. result = result + endvalue;
  835. }
  836. }
  837. }
  838. }
  839. return result;
  840. }
  841. }