WindTowerCalculationDataServiceImpl.java 151 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764
  1. package com.jiayue.biz.service.impl;
  2. import cn.hutool.core.convert.Convert;
  3. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.jiayue.biz.conf.RequestDataHelper;
  6. import com.jiayue.biz.domain.*;
  7. import com.jiayue.biz.dto.SpeedAndDensityDto;
  8. import com.jiayue.biz.mapper.WindTowerCalculationDataMapper;
  9. import com.jiayue.biz.service.EquipmentAttributeService;
  10. import com.jiayue.biz.service.WindTowerCalculationDataService;
  11. import com.jiayue.biz.service.WindTowerInfoService;
  12. import com.jiayue.biz.util.CalculationUtil;
  13. import com.jiayue.biz.util.DateTimeUtil;
  14. import com.jiayue.biz.util.SEDateUtil;
  15. import com.jiayue.common.utils.DateUtil;
  16. import flanagan.analysis.ProbabilityPlot;
  17. import lombok.AllArgsConstructor;
  18. import lombok.extern.slf4j.Slf4j;
  19. import org.springframework.stereotype.Service;
  20. import org.springframework.transaction.annotation.Transactional;
  21. import java.math.BigDecimal;
  22. import java.math.RoundingMode;
  23. import java.text.ParseException;
  24. import java.text.SimpleDateFormat;
  25. import java.util.*;
  26. import java.util.stream.Collectors;
  27. /**
  28. * 统计数据实现类
  29. *
  30. * @author zy
  31. * @date 2022-08-26
  32. */
  33. @Slf4j
  34. @Service
  35. @AllArgsConstructor
  36. public class WindTowerCalculationDataServiceImpl extends ServiceImpl<WindTowerCalculationDataMapper, WindTowerCalculationData> implements WindTowerCalculationDataService {
  37. //风功率密度和平均风速的统一标识
  38. private final String attributeFunction = "WindPowerDensity";
  39. private final String shearFunction = "shear";
  40. private final String turbulenceFunction = "turbulence";
  41. private final String wsFunction = "ws";
  42. private final String wsDayFunction = "wsDay";
  43. private final String wsMonthFunction = "wsMonth";
  44. private final String wpdFunction = "WindPowerDensity";
  45. private final String wsMaxMonthFunction = "maxWsMonth";
  46. private final String turbulenceDay = "turbulenceDay";
  47. private final String staDay = "staDay";
  48. private final String windShearFiledName = "windShear";
  49. private final String windShearDayFiledName = "windShearDay";
  50. //风切变计算指数
  51. private final BigDecimal lg30 = new BigDecimal("0.47712125471966244");//lg(30/10)
  52. private final BigDecimal lg50 = new BigDecimal("0.6989700043360189");//lg(50/10)
  53. private final BigDecimal lg60 = new BigDecimal("0.7781512503836436");//lg(60/10)
  54. private final BigDecimal lg70 = new BigDecimal("0.8450980400142568");//lg(70/10)
  55. private final BigDecimal lg80 = new BigDecimal("0.9030899869919435");//lg(80/10)
  56. private final BigDecimal lg90 = new BigDecimal("0.9542425094393249");//lg(90/10)
  57. private final BigDecimal lg100 = new BigDecimal("1.0");//lg(100/10)
  58. private final BigDecimal lg110 = new BigDecimal("1.0413926851582251");//lg(110/10)
  59. private final BigDecimal lg120 = new BigDecimal("1.0791812460476249");//lg(120/10)
  60. private final BigDecimal lg140 = new BigDecimal("1.146128035678238");//lg(140/10)
  61. private final BigDecimal lg150 = new BigDecimal("1.1760912590556813");//lg(150/10)
  62. private final WindTowerInfoService windTowerInfoService;
  63. private final EquipmentAttributeService equipmentAttributeService;
  64. // @Scheduled(cron = "0 0 2 1/1 * ? ")
  65. // @Scheduled(cron = "0 0 2 1/1 * ? ")
  66. /**
  67. * 风功率密度和平均风速计算方法
  68. */
  69. public ArrayList<WindTowerCalculationData> calculateWindPowerDensity(Long startTime, Long endTime, String eqNo, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<ProphaseWeatherData> prophaseWeatherDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerCalculationData> windTowerCalculationDataList) {
  70. //获取对应测风塔数据
  71. List<ProphaseAnemometryData> anemometryDataList = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startTime && p.getTs().getTime() <= endTime).collect(Collectors.toList());
  72. List<ProphaseWeatherData> weatherDataList = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= startTime && p.getTs().getTime() <= endTime).collect(Collectors.toList());
  73. long hour = 3600000L;
  74. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqNo).list();
  75. String[] height = windTowerInfos.get(0).getHeights().split(",");
  76. //定义数据空集合用来装载 结果数据
  77. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  78. try {
  79. //遍历出过滤出的平均风速属性
  80. for (String h : height) {
  81. EquipmentAttribute equipmentAttributeAws = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(h + "aws")).collect(Collectors.toList()).get(0);
  82. EquipmentAttribute equipmentAttributeWpd = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(h + "wpd")).collect(Collectors.toList()).get(0);
  83. //删除时间段所有数据
  84. removeByStartTimeBetweenAndEquipmentIdAndEbId(new Date(startTime), new Date(endTime), eqNo, equipmentAttributeAws.getId());
  85. removeByStartTimeBetweenAndEquipmentIdAndEbId(new Date(startTime), new Date(endTime), eqNo, equipmentAttributeWpd.getId());
  86. //遍历24小时,用来计算逐小时数据
  87. for (long time = startTime; time <= endTime; time += hour) {
  88. //过滤出对应测风塔数据
  89. long finalTime = time;
  90. //风数据过滤
  91. List<ProphaseAnemometryData> anemometryData = anemometryDataList.stream().filter(w -> w.getTs().getTime() >= finalTime && w.getTs().getTime() <= finalTime + hour - 1000 && w.getLayerHeight().equals(h)).collect(Collectors.toList());
  92. //环境数据过滤
  93. List<ProphaseWeatherData> weatherData = weatherDataList.stream().filter(w -> w.getTs().getTime() >= finalTime && w.getTs().getTime() <= finalTime + hour - 1000).collect(Collectors.toList());
  94. //根据层高获取所有风速数据
  95. List<BigDecimal> bigDecimals = anemometryData.stream().map((ProphaseAnemometryData p) -> {
  96. if (p.getWsAve() != null) {
  97. return BigDecimal.valueOf(p.getWsAve());
  98. }
  99. return BigDecimal.ZERO;
  100. }).collect(Collectors.toList());
  101. //风速数据时所有计算的根本,无数据不计算
  102. if (!bigDecimals.isEmpty()) {
  103. //计算平均风速和风功率密度到数据对象中
  104. if (bigDecimals.get(0) == null) {
  105. continue;
  106. }
  107. SpeedAndDensityDto speedAndDensityDto = getSpeedAndDensityDto(bigDecimals, anemometryData, weatherData);
  108. //保存风速
  109. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  110. windTowerCalculationData.setTime(new Date(time));
  111. windTowerCalculationData.setEbId(equipmentAttributeAws.getId());
  112. windTowerCalculationData.setEquipmentId(eqNo);
  113. windTowerCalculationData.setValue(speedAndDensityDto.getWindSpeed());
  114. windTowerCalculationDataList.add(windTowerCalculationData);
  115. list.add(windTowerCalculationData);
  116. //保存风功率密度
  117. WindTowerCalculationData windTowerCalculationDataWpd = new WindTowerCalculationData();
  118. windTowerCalculationDataWpd.setTime(new Date(time));
  119. windTowerCalculationDataWpd.setEbId(equipmentAttributeWpd.getId());
  120. windTowerCalculationDataWpd.setEquipmentId(eqNo);
  121. windTowerCalculationDataWpd.setValue(speedAndDensityDto.getWindPowerDensity());
  122. windTowerCalculationDataList.add(windTowerCalculationDataWpd);
  123. list.add(windTowerCalculationDataWpd);
  124. }
  125. }
  126. }
  127. } catch (Exception e) {
  128. log.error("计算{}设备平均风速和风功率密度失败^ ^", eqNo);
  129. e.printStackTrace();
  130. }
  131. //保存
  132. // saveBatchByEquipmentId(list, eqNo);
  133. if (list.size() > 0) {
  134. log.info("平均风速和风功率密度成功^ ^");
  135. }
  136. return list;
  137. }
  138. /**
  139. * 获取风况数据(平均风速,风功率密度)
  140. *
  141. * @param bigDecimalList 风速数据
  142. * @return
  143. */
  144. public SpeedAndDensityDto getSpeedAndDensityDto(List<BigDecimal> bigDecimalList, List<ProphaseAnemometryData> anemometryData, List<ProphaseWeatherData> weatherData) {
  145. SpeedAndDensityDto speedAndDensityDto = new SpeedAndDensityDto();
  146. speedAndDensityDto.setWindSpeed(windSpeed(bigDecimalList));
  147. speedAndDensityDto.setWindPowerDensity(CalculationUtil.windEnergyDensity(anemometryData, weatherData));
  148. return speedAndDensityDto;
  149. }
  150. /**
  151. * 计算平均风速
  152. *
  153. * @param bigDecimalList 风速数据
  154. * @return
  155. */
  156. public BigDecimal windSpeed(List<BigDecimal> bigDecimalList) {
  157. return BigDecimal.valueOf(bigDecimalList.stream().collect(Collectors.averagingDouble(BigDecimal::doubleValue)));
  158. }
  159. /**
  160. * 空气密度曲线图
  161. *
  162. * @param startTime 开始时间
  163. * @param endTime 结束时间
  164. * @param equipmentId 设备编号
  165. * @param uid 年月区分id
  166. * @return
  167. */
  168. public List<Object> getAirDensity(Long startTime, Long endTime, String equipmentId, String uid) {
  169. ArrayList<Object> onlyData = new ArrayList<>();
  170. ArrayList<Object> list = new ArrayList<>();
  171. SimpleDateFormat day = new SimpleDateFormat("dd");
  172. SimpleDateFormat dayForYear = new SimpleDateFormat("yyyy-MM");
  173. // 若当天时间为每个月一号, 结束时间为上个月得月末时间
  174. if (day.format(new Date()).equals("01") && dayForYear.format(new Date()).equals(dayForYear.format(new Date(endTime)))) {
  175. endTime = DateTimeUtil.getDayLastTime(DateTimeUtil.mouthLastDay(1).getTime()).getTime();
  176. } else {
  177. // 若当天时间不为每个月一号,结束时间为本月的当前时间-1(昨天)
  178. // long yesterday = new Date().getTime() - 1000 * 60 * 60 * 24;//昨天
  179. endTime = DateTimeUtil.endOfMonth(new Date(endTime)).getTime();
  180. }
  181. if (uid.equals("1")) {
  182. String airDensityFieldName = "airDensity";
  183. List<EquipmentAttribute> airDayFieldNameList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, airDensityFieldName).list();
  184. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  185. if (!airDayFieldNameList.isEmpty()) {
  186. String airDayEbId = airDayFieldNameList.get(0).getId();
  187. //开始时间
  188. Date startTimeOfCurrentMonth = SEDateUtil.getStartTimeOfCurrentDay(new Date(startTime));
  189. //结束时间
  190. // Date endTimeOfCurrentMonth = SEDateUtil.getEndTimeOfCurrentDay(new Date(endTime - 1));
  191. //获取所有空气密度数据
  192. List<WindTowerCalculationData> airDayList = getByStartTimeBetweenAndEquipmentIdAndEbId(startTimeOfCurrentMonth, new Date(endTime), equipmentId, airDayEbId);
  193. airDayList = airDayList.stream().sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  194. //平均空气密度的总和
  195. BigDecimal airAveSum = BigDecimal.ZERO;
  196. for (WindTowerCalculationData w : airDayList) {
  197. HashMap<Object, Object> airDayMap = new HashMap<>();
  198. airAveSum = airAveSum.add(w.getValue());
  199. String format = sdf.format(w.getTime());
  200. airDayMap.put("time", format);
  201. airDayMap.put("air", w.getValue());
  202. list.add(airDayMap);
  203. }
  204. HashMap<Object, Object> aveAirMap = new HashMap<>();
  205. if (!airDayList.isEmpty()) {
  206. aveAirMap.put("ave", airAveSum.divide(BigDecimal.valueOf(airDayList.size()), 2, RoundingMode.HALF_UP));
  207. }
  208. onlyData.add(list);
  209. onlyData.add(aveAirMap);
  210. }
  211. }
  212. if (uid.equals("2")) {
  213. //设置年份用的
  214. SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
  215. //给前端用的日期格式
  216. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM");
  217. //获取查询的年份
  218. int toYear = Integer.parseInt(sdf.format(startTime));
  219. int toYear2 = Integer.parseInt(sdf.format(endTime));
  220. Calendar calendar = Calendar.getInstance();
  221. calendar.clear();
  222. calendar.set(Calendar.YEAR, toYear);
  223. //当前年的开始时间
  224. long startHour = calendar.getTimeInMillis();
  225. //当前年的结束时间
  226. calendar.clear();
  227. calendar.set(Calendar.YEAR, toYear2);
  228. calendar.roll(Calendar.DAY_OF_YEAR, -1);
  229. long endHour = calendar.getTimeInMillis() - 1l;
  230. String airDensityFieldName = "airDensityMonth";
  231. List<EquipmentAttribute> turDayFieldNameList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, airDensityFieldName).list();
  232. if (!turDayFieldNameList.isEmpty()) {
  233. String airMonthEbId = turDayFieldNameList.get(0).getId();
  234. //开始时间
  235. Date startTimeOfCurrentMonth = SEDateUtil.getStartTimeOfCurrentDay(new Date(startHour));
  236. //结束时间
  237. Date endTimeOfCurrentMonth = SEDateUtil.getEndTimeOfCurrentDay(new Date(endHour));
  238. List<WindTowerCalculationData> airMonthList = getByStartTimeBetweenAndEquipmentIdAndEbId(startTimeOfCurrentMonth, endTimeOfCurrentMonth, equipmentId, airMonthEbId);
  239. airMonthList = airMonthList.stream().sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  240. BigDecimal airAveSum = BigDecimal.ZERO;
  241. for (WindTowerCalculationData w : airMonthList) {
  242. HashMap<Object, Object> airMonthMap = new HashMap<>();
  243. airAveSum = airAveSum.add(w.getValue());
  244. String format = sdf1.format(w.getTime());
  245. airMonthMap.put("time", format);
  246. airMonthMap.put("air", w.getValue());
  247. list.add(airMonthMap);
  248. }
  249. HashMap<Object, Object> aveAirMap = new HashMap<>();
  250. if (!airMonthList.isEmpty()) {
  251. aveAirMap.put("ave", airAveSum.divide(BigDecimal.valueOf(airMonthList.size()), 2, RoundingMode.HALF_UP));
  252. }
  253. onlyData.add(list);
  254. onlyData.add(aveAirMap);
  255. }
  256. }
  257. return onlyData;
  258. }
  259. /**
  260. * Gumbel分布概率
  261. *
  262. * @param startTime
  263. * @param endTime
  264. * @param eqId
  265. * @return
  266. */
  267. public List<Object> getGumbel(Long startTime, Long endTime, String eqId, String height) {
  268. //最终返回的集合
  269. ArrayList<Object> gumbelList = new ArrayList<>();
  270. //开始时间
  271. Date startTimeOfCurrentMonth = SEDateUtil.getStartTimeOfCurrentDay(new Date(startTime));
  272. //结束时间
  273. Date endTimeOfCurrentMonth = SEDateUtil.getEndTimeOfCurrentDay(new Date(endTime));
  274. //获取EquipmentAttribute表中的对应数据
  275. if (height == null || height.equals("")) {
  276. height = "80";
  277. }
  278. String[] heightAll = height.split(",");
  279. List<EquipmentAttribute> equipmentAttributeList1 = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getAttributeFunction, "maxWsMonth").list();
  280. List<WindTowerCalculationData> windTowerCalculationDataList1 = getByBetweenTimeAndEquipmentId(startTimeOfCurrentMonth, endTimeOfCurrentMonth, eqId);
  281. for (String h : heightAll) {
  282. //获取层高
  283. String heightGumbel = h + "maxwsMonth";
  284. List<EquipmentAttribute> equipmentAttributeList = equipmentAttributeList1.stream().filter(w -> w.getFieldName().equals(heightGumbel)).collect(Collectors.toList());
  285. //获取对应的数据
  286. List<WindTowerCalculationData> windTowerCalculationDataList = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(equipmentAttributeList.get(0).getId()) && w.getEquipmentId().equals(eqId) &&
  287. w.getTime().after(startTimeOfCurrentMonth) && w.getTime().before(endTimeOfCurrentMonth)).sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  288. //准备放入Gumbel算法的集合
  289. ArrayList<Object> list = new ArrayList<>();
  290. for (WindTowerCalculationData windTowerCalculationData : windTowerCalculationDataList) {
  291. list.add(windTowerCalculationData.getValue().doubleValue());
  292. }
  293. if (list.size() > 5) {
  294. //把查询的最大风速集合放入公式
  295. ProbabilityPlot probabilityPlot = new ProbabilityPlot(list);
  296. probabilityPlot.suppressDisplay();
  297. //尺度参数 β
  298. double v = probabilityPlot.gumbelMaxSigma();
  299. //位置参数 α
  300. double u = probabilityPlot.gumbelMaxMu();
  301. TreeMap<BigDecimal, BigDecimal> gumbelMap = new TreeMap<>();
  302. BigDecimal wsMax = BigDecimal.ZERO;
  303. for (WindTowerCalculationData w : windTowerCalculationDataList) {
  304. //最大风速值
  305. BigDecimal wsValue = w.getValue();
  306. //P(X)= exp {—exp[ -(X- α)/β]} 计算出在这个时间段的风速重现概率
  307. wsMax = BigDecimal.valueOf(Math.exp(-(Math.exp(-(w.getValue().doubleValue() - u) / v)))).setScale(2, RoundingMode.HALF_UP);
  308. //加入时间标识
  309. gumbelMap.put(wsValue, wsMax);
  310. }
  311. ArrayList<Object> list1 = new ArrayList<>();
  312. for (Map.Entry<BigDecimal, BigDecimal> g : gumbelMap.entrySet()) {
  313. HashMap<Object, Object> map = new HashMap<>();
  314. //风速
  315. map.put("wsMax", g.getKey());
  316. //概率
  317. map.put("gum", g.getValue());
  318. list1.add(map);
  319. }
  320. HashMap<String, Object> heightGumbelMap = new HashMap<>();
  321. heightGumbelMap.put(h, list1);
  322. //加入层高标识
  323. for (Map.Entry<String, Object> h1 : heightGumbelMap.entrySet()) {
  324. HashMap<Object, Object> map = new HashMap<>();
  325. map.put("height", h1.getKey());
  326. map.put("arr", h1.getValue());
  327. gumbelList.add(map);
  328. }
  329. }
  330. }
  331. return gumbelList;
  332. }
  333. /**
  334. * 湍流统计曲线图
  335. *
  336. * @param height 层高
  337. * @param eqId 设备编号
  338. * @return List<Object>
  339. */
  340. public List<Object> getTurbulence(Long startTime, Long endTime, String height, String eqId) {
  341. //最后返回的
  342. ArrayList<Object> onlyData = new ArrayList<>();
  343. //装所有风速数据
  344. ArrayList<Object> arrList = new ArrayList<>();
  345. //装平均值
  346. ArrayList<Object> list1 = new ArrayList<>();
  347. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqId).list();
  348. if (height == null || height.equals("")) {
  349. for (WindTowerInfo windTowerInfo : windTowerInfos) {
  350. height = windTowerInfo.getHeights();
  351. }
  352. }
  353. List<String> heightSort = new ArrayList<>();
  354. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
  355. String[] heightAll = height.split(",");
  356. for (String s : heightAll) {
  357. heightSort.add(s);
  358. }
  359. List<EquipmentAttribute> equipmentAttributeList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getAttributeFunction, "turbulenceMonth").list();
  360. // 根据开始时间、结束时间、设备id查询统计表
  361. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startTime), new Date(endTime), eqId);
  362. // 根据开始时间、结束时间分割的月份
  363. List<Long> timeList = DateTimeUtil.getIntervalTimeByMonth(new Date(startTime), new Date(endTime));
  364. for (String h : heightSort) {
  365. String turMonthFieldName = h + "turbulenceMonth";
  366. //存放数据
  367. // 获取EbId
  368. List<EquipmentAttribute> turDayFieldNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(turMonthFieldName)).collect(Collectors.toList());
  369. if (!turDayFieldNameList.isEmpty()) {
  370. String turDayEbId = turDayFieldNameList.get(0).getId();
  371. //平均风速集合
  372. List<WindTowerCalculationData> turDayList = new ArrayList<>();
  373. // 根据属性id过滤统计表
  374. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(turDayEbId)).collect(Collectors.toList());
  375. ArrayList<Object> list = new ArrayList<>();
  376. BigDecimal turAve = BigDecimal.ZERO; // 平均湍流
  377. for (Long time : timeList) {
  378. turDayList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(time)) == 0).collect(Collectors.toList());
  379. BigDecimal value = BigDecimal.ZERO;
  380. if (!turDayList.isEmpty()) {
  381. value = turDayList.get(0).getValue();
  382. }
  383. HashMap<Object, Object> map = new HashMap<>();
  384. String format = sdf.format(time);
  385. map.put("tur", value.setScale(2, RoundingMode.HALF_UP));
  386. map.put("time", format);
  387. list.add(map);
  388. }
  389. // 曲线list
  390. Map<String, Object> finalMap = new HashMap<>();
  391. finalMap.put("height", h);
  392. finalMap.put("arr", list);
  393. arrList.add(finalMap);
  394. // 湍流数值集合
  395. List<BigDecimal> turList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  396. if (!turList.isEmpty()) {
  397. turAve = turList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(turList.size()), 2, RoundingMode.HALF_UP);
  398. }
  399. }
  400. }
  401. onlyData.add(arrList);
  402. onlyData.add(list1);
  403. return onlyData;
  404. }
  405. /**
  406. * 年资源统计(空气密度)
  407. *
  408. * @param startTime 开始时间
  409. * @param endTime 结束时间
  410. * @param eqId 设备编号
  411. * @return List<Object>
  412. */
  413. public List<Object> getDensityYear(Long startTime, Long endTime, String eqId) {
  414. String fieldName = "airDensityMonth";
  415. List<EquipmentAttribute> densityTypeList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, fieldName).list();
  416. String densityId = densityTypeList.get(0).getId();
  417. //设置年份用的
  418. SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
  419. //获取查询的年份
  420. int toYearStart = Integer.parseInt(sdf.format(startTime));
  421. int toYearEnd = Integer.parseInt(sdf.format(endTime));
  422. ArrayList<Object> PDataList = new ArrayList<>();
  423. for (int i = toYearStart; i <= toYearEnd; i++) {
  424. Calendar calendar = Calendar.getInstance();
  425. calendar.clear();
  426. calendar.set(Calendar.YEAR, i);
  427. //当前年的开始时间
  428. long startHour = calendar.getTimeInMillis();
  429. calendar.clear();
  430. calendar.set(Calendar.YEAR, i);
  431. calendar.roll(Calendar.DAY_OF_YEAR, -1);
  432. //当前年的结束时间
  433. long endHour = calendar.getTimeInMillis() - 1l;
  434. //开始时间
  435. Date startTimeOfCurrentMonth = SEDateUtil.getStartTimeOfCurrentDay(new Date(startHour));
  436. //结束时间
  437. Date endTimeOfCurrentMonth = SEDateUtil.getEndTimeOfCurrentDay(new Date(endHour));
  438. List<WindTowerCalculationData> byBetweenTimeAndEquipmentId = getByBetweenTimeAndEquipmentId(startTimeOfCurrentMonth, endTimeOfCurrentMonth, eqId);
  439. List<WindTowerCalculationData> densityDataList = byBetweenTimeAndEquipmentId.stream().filter(w -> w.getEbId().equals(densityId)).sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  440. BigDecimal pSum = BigDecimal.ZERO;
  441. for (WindTowerCalculationData w : densityDataList) {
  442. pSum = pSum.add(w.getValue());
  443. }
  444. HashMap<Object, Object> PTMap = new HashMap<>();
  445. if (!densityDataList.isEmpty()) {
  446. PTMap.put(i, pSum.divide(BigDecimal.valueOf(densityDataList.size()), 2, RoundingMode.HALF_UP));
  447. }
  448. for (Map.Entry<Object, Object> pt : PTMap.entrySet()) {
  449. HashMap<String, Object> map = new HashMap<>();
  450. map.put("time", pt.getKey());
  451. map.put("p", pt.getValue());
  452. PDataList.add(map);
  453. }
  454. }
  455. return PDataList;
  456. }
  457. /**
  458. * 年风资源统计(风速+风功率密度)
  459. *
  460. * @param startTime 开始年份
  461. * @param endTime 结束年份
  462. * @param height 层高
  463. * @param eqId 设备编号
  464. * @return List<Object>
  465. */
  466. public List<Object> getWindResources(Long startTime, Long endTime, String height, String eqId) {
  467. ArrayList<Object> DataList = new ArrayList<>();
  468. ArrayList<Object> DataOneList = new ArrayList<>();
  469. ArrayList<Object> DataTWOList = new ArrayList<>();
  470. Calendar calendar1 = Calendar.getInstance();
  471. calendar1.clear();
  472. calendar1.set(Calendar.YEAR, DateUtil.year(new Date(endTime)));
  473. calendar1.roll(Calendar.DAY_OF_YEAR, -1);
  474. //获取年份最后一天
  475. endTime = calendar1.getTime().getTime();
  476. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqId).list();
  477. if (height == null || height.equals("")) {
  478. height = windTowerInfos.get(0).getHeights();
  479. }
  480. //设置年份用的
  481. SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
  482. //获取查询的年份
  483. int toYearStart = Integer.parseInt(sdf.format(startTime));
  484. int toYearEnd = Integer.parseInt(sdf.format(endTime));
  485. List<String> heightSort = new ArrayList<>();
  486. String[] heightAll = height.split(",");
  487. List<EquipmentAttribute> equipmentAttributeList = equipmentAttributeService.list();
  488. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startTime), new Date(endTime), eqId);
  489. //遍历层高
  490. for (String h : heightAll) {
  491. //设置 层高+fieldName(数据库字段 50awsMonth)
  492. String fieldNameWs = h + "awsMonth";
  493. String fieldNameWpd = h + "wpdMonth";
  494. List<EquipmentAttribute> allWsFiledNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(fieldNameWs)).collect(Collectors.toList());
  495. List<EquipmentAttribute> allWpdFiledNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(fieldNameWpd)).collect(Collectors.toList());
  496. //存放最后数据的map 防止重复数据 new外面
  497. HashMap<Object, Object> map1 = new HashMap<>();
  498. HashMap<String, Object> HDMap = new HashMap<>();
  499. //年平均风速存放的list
  500. ArrayList<Object> list = new ArrayList<>();
  501. //年风功率密度存放的list
  502. ArrayList<Object> list1 = new ArrayList<>();
  503. for (int i = toYearStart; i <= toYearEnd; i++) {
  504. Calendar calendar = Calendar.getInstance();
  505. calendar.clear();
  506. calendar.set(Calendar.YEAR, i);
  507. //当前年的开始时间
  508. long startHour = calendar.getTimeInMillis();
  509. calendar.clear();
  510. calendar.set(Calendar.YEAR, i);
  511. calendar.roll(Calendar.DAY_OF_YEAR, -1);
  512. //当前年的结束时间
  513. long endHour = calendar.getTimeInMillis() - 1L;
  514. //开始时间
  515. Date startTimeOfCurrentMonth = SEDateUtil.getStartTimeOfCurrentDay(new Date(startHour));
  516. //结束时间
  517. Date endTimeOfCurrentMonth = SEDateUtil.getEndTimeOfCurrentDay(new Date(endHour));
  518. if (!allWsFiledNameList.isEmpty()) {
  519. String awsMonthEqId = allWsFiledNameList.get(0).getId();
  520. List<WindTowerCalculationData> allDataWsList = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(eqId) && w.getEbId().equals(awsMonthEqId) &&
  521. w.getTime().after(startTimeOfCurrentMonth) && w.getTime().before(endTimeOfCurrentMonth)).sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  522. BigDecimal wsYearData = BigDecimal.ZERO;
  523. for (WindTowerCalculationData ws : allDataWsList) {
  524. wsYearData = wsYearData.add(ws.getValue());
  525. }
  526. HashMap<Object, Object> wsMap = new HashMap<>();
  527. if (!allDataWsList.isEmpty()) {
  528. wsMap.put(i, wsYearData.divide(BigDecimal.valueOf(allDataWsList.size()), 2, RoundingMode.HALF_UP));
  529. }
  530. //给时间和年平均数值添加标识
  531. for (Map.Entry<Object, Object> ws1 : wsMap.entrySet()) {
  532. HashMap<Object, Object> map = new HashMap<>();
  533. map.put("time", ws1.getKey());
  534. map.put("ws", ws1.getValue());
  535. list.add(map);
  536. }
  537. HashMap<String, Object> heightDataMap = new HashMap<>();
  538. //放入层高
  539. heightDataMap.put(h, list);
  540. for (Map.Entry<String, Object> hd : heightDataMap.entrySet()) {
  541. map1 = new HashMap<>();
  542. map1.put("height", hd.getKey());
  543. map1.put("arr", hd.getValue());
  544. }
  545. }
  546. if (!allWpdFiledNameList.isEmpty()) {
  547. String wpdMonthEqId = allWpdFiledNameList.get(0).getId();
  548. List<WindTowerCalculationData> allDataWpdList = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(eqId) && w.getEbId().equals(wpdMonthEqId) &&
  549. w.getTime().after(startTimeOfCurrentMonth) && w.getTime().before(endTimeOfCurrentMonth)).sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  550. BigDecimal wpdYearData = BigDecimal.ZERO;
  551. for (WindTowerCalculationData wpd : allDataWpdList) {
  552. wpdYearData = wpdYearData.add(wpd.getValue());
  553. }
  554. HashMap<Object, Object> wpdMap = new HashMap<>();
  555. //添加时间
  556. if (!allDataWpdList.isEmpty()) {
  557. wpdMap.put(i, wpdYearData.divide(BigDecimal.valueOf(allDataWpdList.size()), 2, RoundingMode.HALF_UP));
  558. }
  559. for (Map.Entry<Object, Object> wpd1 : wpdMap.entrySet()) {
  560. HashMap<Object, Object> map = new HashMap<>();
  561. map.put("time", wpd1.getKey());
  562. map.put("wpd", wpd1.getValue());
  563. list1.add(map);
  564. }
  565. HashMap<String, Object> heightDataMap = new HashMap<>();
  566. heightDataMap.put(h, list1);
  567. for (Map.Entry<String, Object> hd : heightDataMap.entrySet()) {
  568. HDMap = new HashMap<>();
  569. HDMap.put("height", hd.getKey());
  570. HDMap.put("arr", hd.getValue());
  571. }
  572. }
  573. }
  574. if (!map1.entrySet().isEmpty()) {
  575. DataOneList.add(map1);
  576. }
  577. if (!HDMap.entrySet().isEmpty()) {
  578. DataTWOList.add(HDMap);
  579. }
  580. }
  581. DataList.add(DataOneList);
  582. DataList.add(DataTWOList);
  583. return DataList;
  584. }
  585. /**
  586. * 时间段平均风速曲线图
  587. *
  588. * @param startTime 开始时间
  589. * @param endTime 结束时间
  590. * @param height 测高
  591. * @param eqId 设备编号
  592. * @return List<Object>
  593. */
  594. public List<Object> getWindSpeed(Long startTime, Long endTime, String height, String eqId, String uid) {
  595. //最后返回的
  596. ArrayList<Object> onlyData = new ArrayList<>();
  597. // endTime = endTime - 1L;
  598. // SimpleDateFormat day = new SimpleDateFormat("dd");
  599. // SimpleDateFormat dayForYear = new SimpleDateFormat("yyyy-MM");
  600. // 若当天时间为每个月一号, 结束时间为上个月得月末时间
  601. // if (day.format(new Date()).equals("01") && dayForYear.format(new Date()).equals(dayForYear.format(new Date(endTime)))) {
  602. // endTime = DateTimeUtil.getDayLastTime(DateTimeUtil.mouthLastDay(1).getTime()).getTime();
  603. // } else {
  604. // // 若当天时间不为每个月一号,结束时间为本月的当前时间-1(昨天)
  605. //// long yesterday = new Date().getTime() - 1000 * 60 * 60 * 24;//昨天
  606. // endTime = DateTimeUtil.endOfMonth(new Date(endTime)).getTime();
  607. // }
  608. //装所有风速数据
  609. ArrayList<Object> arrList = new ArrayList<>();
  610. BigDecimal minWs = BigDecimal.ZERO;
  611. BigDecimal maxWs = BigDecimal.ZERO;
  612. //装平均值
  613. ArrayList<Object> list1 = new ArrayList<>();
  614. ArrayList<Object> list2 = new ArrayList<>();
  615. ArrayList<Object> list3 = new ArrayList<>();
  616. List<EquipmentAttribute> equipmentAttributeList = equipmentAttributeService.lambdaQuery().like(EquipmentAttribute::getAttributeFunction, "ws").list();
  617. String[] heights = null;
  618. if (height == null || height.equals("")) {
  619. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqId).list();
  620. heights = windTowerInfos.get(0).getHeights().split(",");
  621. } else {
  622. heights = height.split(",");
  623. }
  624. List<String> heightList = Arrays.asList(heights);
  625. if (uid.equals("1")) {//月逐日
  626. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startTime), new Date(endTime), eqId);
  627. // 根据时间升序
  628. windTowerCalculationDataList.sort(Comparator.comparing(WindTowerCalculationData::getTime));
  629. //遍历所有层高
  630. for (String h : heightList) {
  631. String awsDayFieldName = h + "awsDay";
  632. List<EquipmentAttribute> awsDayFieldNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(awsDayFieldName)).collect(Collectors.toList());
  633. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  634. //存放数据
  635. if (!awsDayFieldNameList.isEmpty()) {
  636. String awsDayEbId = awsDayFieldNameList.get(0).getId();
  637. //平均风速集合
  638. List<WindTowerCalculationData> awsDayList = new ArrayList<>();
  639. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(awsDayEbId)).collect(Collectors.toList());
  640. BigDecimal awsAve = BigDecimal.ZERO;
  641. ArrayList<Object> list = new ArrayList<>();
  642. for (long i = startTime; i < endTime; i += 1000 * 60 * 60 * 24) {
  643. long finalI = i;
  644. awsDayList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(finalI)) == 0).collect(Collectors.toList());
  645. HashMap<Object, Object> map = new HashMap<>();
  646. String format = sdf.format(i);
  647. BigDecimal value = BigDecimal.ZERO;
  648. if (!awsDayList.isEmpty()) {
  649. value = awsDayList.get(0).getValue();
  650. }
  651. map.put("ws", value);
  652. map.put("time", format);
  653. list.add(map);
  654. }
  655. // 曲线
  656. HashMap<Object, Object> finalMap = new HashMap<>();
  657. finalMap.put("height", h);
  658. finalMap.put("arr", list);
  659. arrList.add(finalMap);
  660. //平均值
  661. List<BigDecimal> aveWsList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  662. if (!aveWsList.isEmpty()) {
  663. awsAve = aveWsList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(aveWsList.size()), 2, RoundingMode.HALF_UP);
  664. }
  665. HashMap<Object, Object> finalAveMap = new HashMap<>();
  666. finalAveMap.put("height", h);
  667. finalAveMap.put("aws", awsAve);
  668. list1.add(finalAveMap);
  669. //最小值 最大值
  670. if (!filterList.isEmpty()) {
  671. minWs = filterList.stream().min(Comparator.comparing(WindTowerCalculationData::getValue)).get().getValue();
  672. maxWs = filterList.stream().max(Comparator.comparing(WindTowerCalculationData::getValue)).get().getValue();
  673. }
  674. HashMap<Object, Object> finalMinMap = new HashMap<>();
  675. finalMinMap.put("height2", h);
  676. finalMinMap.put("min", minWs);
  677. list2.add(finalMinMap);
  678. HashMap<Object, Object> finalMaxMap = new HashMap<>();
  679. finalMaxMap.put("height3", h);
  680. finalMaxMap.put("max", maxWs);
  681. list3.add(finalMaxMap);
  682. }
  683. }
  684. onlyData.add(arrList);
  685. onlyData.add(list1);
  686. onlyData.add(list2);
  687. onlyData.add(list3);
  688. }
  689. if (uid.equals("2")) {
  690. //设置年份用的
  691. SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
  692. //给前端用的日期格式
  693. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM");
  694. //获取查询的年份
  695. int toYear = Integer.parseInt(sdf.format(startTime));
  696. int toYear2 = Integer.parseInt(sdf.format(endTime));
  697. Calendar calendar = Calendar.getInstance();
  698. calendar.clear();
  699. calendar.set(Calendar.YEAR, toYear);
  700. //当前年的开始时间
  701. long startHour = calendar.getTimeInMillis();
  702. calendar.clear();
  703. calendar.set(Calendar.YEAR, toYear2);
  704. calendar.roll(Calendar.DAY_OF_YEAR, -1);
  705. //当前年的结束时间
  706. endTime = endTime + 100l;
  707. // 根据开始时间、结束时间分割的月份
  708. List<Long> timeList = DateTimeUtil.getIntervalTimeByMonth(new Date(startHour), new Date(endTime));
  709. // 开始年和结束年相同 getIntervalTimeByMonth 最后一个月会重复两次
  710. if (toYear == toYear2) {
  711. timeList.remove(timeList.size() - 1);
  712. }
  713. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startHour), new Date(endTime), eqId);
  714. for (String h : heights) {
  715. String awsMonthFieldName = h + "awsMonth";
  716. //存放数据
  717. List<EquipmentAttribute> awsDayFieldNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(awsMonthFieldName)).collect(Collectors.toList());
  718. if (!awsDayFieldNameList.isEmpty()) {
  719. String awsDayEbId = awsDayFieldNameList.get(0).getId();
  720. //平均风速集合
  721. List<WindTowerCalculationData> awsDayList = new ArrayList<>();
  722. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(awsDayEbId)).collect(Collectors.toList());
  723. BigDecimal awsAve = BigDecimal.ZERO;
  724. ArrayList<Object> list = new ArrayList<>();
  725. for (long time : timeList) {
  726. awsDayList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(time)) == 0).collect(Collectors.toList());
  727. HashMap<Object, Object> map = new HashMap<>();
  728. String format = sdf1.format(time);
  729. BigDecimal value = BigDecimal.ZERO;
  730. if (!awsDayList.isEmpty()) {
  731. value = awsDayList.get(0).getValue();
  732. }
  733. map.put("ws", value);
  734. map.put("time", format);
  735. list.add(map);
  736. }
  737. // 曲线
  738. HashMap<Object, Object> finalMap = new HashMap<>();
  739. finalMap.put("height", h);
  740. finalMap.put("arr", list);
  741. arrList.add(finalMap);
  742. //平均值
  743. List<BigDecimal> aveWsList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  744. if (!aveWsList.isEmpty()) {
  745. awsAve = aveWsList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(aveWsList.size()), 2, RoundingMode.HALF_UP);
  746. }
  747. HashMap<Object, Object> finalAveMap = new HashMap<>();
  748. finalAveMap.put("height", h);
  749. finalAveMap.put("aws", awsAve);
  750. list1.add(finalAveMap);
  751. //最小值 最大值
  752. if (!filterList.isEmpty()) {
  753. minWs = filterList.stream().min(Comparator.comparing(WindTowerCalculationData::getValue)).get().getValue();
  754. maxWs = filterList.stream().max(Comparator.comparing(WindTowerCalculationData::getValue)).get().getValue();
  755. }
  756. HashMap<Object, Object> finalMinMap = new HashMap<>();
  757. finalMinMap.put("height2", h);
  758. finalMinMap.put("min", minWs);
  759. list2.add(finalMinMap);
  760. HashMap<Object, Object> finalMaxMap = new HashMap<>();
  761. finalMaxMap.put("height3", h);
  762. finalMaxMap.put("max", maxWs);
  763. list3.add(finalMaxMap);
  764. }
  765. }
  766. onlyData.add(arrList);
  767. onlyData.add(list1);
  768. onlyData.add(list2);
  769. onlyData.add(list3);
  770. }
  771. return onlyData;
  772. }
  773. /**
  774. * 时间段风功率密度曲线图(统计查询)
  775. *
  776. * @param startTime 开始时间
  777. * @param endTime 结束时间
  778. * @param height 测高
  779. * @param eqId 设备编号
  780. * @return List<Object>
  781. */
  782. public List<Object> getWpd(Long startTime, Long endTime, String height, String eqId, String uid) {
  783. //最后返回的
  784. ArrayList<Object> onlyData = new ArrayList<>();
  785. // endTime = endTime - 1L;
  786. // SimpleDateFormat day = new SimpleDateFormat("dd");
  787. // SimpleDateFormat dayForYear = new SimpleDateFormat("yyyy-MM");
  788. // // 若当天时间为每个月一号, 结束时间为上个月得月末时间
  789. // if (day.format(new Date()).equals("01") && dayForYear.format(new Date()).equals(dayForYear.format(new Date(endTime)))) {
  790. // endTime = DateTimeUtil.getDayLastTime(DateTimeUtil.mouthLastDay(1).getTime()).getTime();
  791. // } else {
  792. // // 若当天时间不为每个月一号,结束时间为本月的当前时间-1(昨天)
  793. //// long yesterday = new Date().getTime() - 1000 * 60 * 60 * 24;//昨天
  794. // endTime = DateTimeUtil.endOfMonth(new Date(endTime)).getTime();
  795. // }
  796. //装所有风功率密度数据
  797. ArrayList<Object> arrList = new ArrayList<>();
  798. //装平均值
  799. ArrayList<Object> list1 = new ArrayList<>();
  800. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqId).list();
  801. if (height == null || height.equals("")) {
  802. height = windTowerInfos.get(0).getHeights();
  803. }
  804. // List<String> heightSort = new ArrayList<>();
  805. String[] heightAll = height.split(",");
  806. // for (String s : heightAll) {
  807. // heightSort.add(s);
  808. // }
  809. // heightSort = heightSort.stream().sorted().collect(Collectors.toList());
  810. List<String> heightSort = Arrays.asList(heightAll);
  811. //查询统计属性表
  812. List<EquipmentAttribute> equipmentAttributeList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getAttributeFunction, "WindPowerDensity").list();
  813. //查询统计数据表
  814. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startTime), new Date(endTime), eqId);
  815. if (uid.equals("1")) {
  816. //遍历所有层高
  817. for (String h : heightSort) {
  818. String wpdDayFieldName = h + "wpdDay";
  819. List<EquipmentAttribute> wpdDayFieldNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(wpdDayFieldName)).collect(Collectors.toList());
  820. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  821. //存放数据
  822. if (!wpdDayFieldNameList.isEmpty()) {
  823. String wpdDayEbId = wpdDayFieldNameList.get(0).getId();
  824. //平均风速集合
  825. List<WindTowerCalculationData> wpdDayList = new ArrayList<>();
  826. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(wpdDayEbId)).collect(Collectors.toList());
  827. BigDecimal wpdAve = BigDecimal.ZERO;
  828. ArrayList<Object> list = new ArrayList<>();
  829. for (long i = startTime; i < endTime; i += 1000 * 60 * 60 * 24) {
  830. long finalI = i;
  831. wpdDayList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(finalI)) == 0).collect(Collectors.toList());
  832. HashMap<Object, Object> map = new HashMap<>();
  833. String format = sdf.format(i);
  834. BigDecimal value = BigDecimal.ZERO;
  835. if (!wpdDayList.isEmpty()) {
  836. value = wpdDayList.get(0).getValue();
  837. }
  838. map.put("wpd", value);
  839. map.put("time", format);
  840. list.add(map);
  841. }
  842. // 曲线
  843. HashMap<Object, Object> finalMap = new HashMap<>();
  844. finalMap.put("height", h);
  845. finalMap.put("arr", list);
  846. arrList.add(finalMap);
  847. //平均值
  848. List<BigDecimal> aveWsList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  849. if (!aveWsList.isEmpty()) {
  850. wpdAve = aveWsList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(aveWsList.size()), 2, RoundingMode.HALF_UP);
  851. }
  852. HashMap<Object, Object> finalAveMap = new HashMap<>();
  853. finalAveMap.put("height", h);
  854. finalAveMap.put("wpdAve", wpdAve);
  855. list1.add(finalAveMap);
  856. }
  857. }
  858. onlyData.add(arrList);
  859. onlyData.add(list1);
  860. }
  861. if (uid.equals("2")) {
  862. //设置年份用的
  863. SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
  864. //给前端用的日期格式
  865. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM");
  866. //获取查询的年份
  867. int toYear = Integer.parseInt(sdf.format(startTime));
  868. int toYear2 = Integer.parseInt(sdf.format(endTime));
  869. Calendar calendar = Calendar.getInstance();
  870. calendar.clear();
  871. calendar.set(Calendar.YEAR, toYear);
  872. //当前年的开始时间
  873. long startHour = calendar.getTimeInMillis();
  874. calendar.clear();
  875. calendar.set(Calendar.YEAR, toYear2);
  876. calendar.roll(Calendar.DAY_OF_YEAR, -1);
  877. //当前年的结束时间
  878. endTime = endTime + 100L;
  879. // 根据开始时间、结束时间分割的月份
  880. List<Long> timeList = DateTimeUtil.getIntervalTimeByMonth(new Date(startHour), new Date(endTime));
  881. // 开始年和结束年相同 getIntervalTimeByMonth 最后一个月会重复两次
  882. if (toYear == toYear2) {
  883. timeList.remove(timeList.size() - 1);
  884. }
  885. windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startHour), new Date(endTime), eqId);
  886. for (String h : heightSort) {
  887. String wpdMonthFieldName = h + "wpdMonth";
  888. //存放数据
  889. List<EquipmentAttribute> wpdDayFieldNameList = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(wpdMonthFieldName)).collect(Collectors.toList());
  890. if (!wpdDayFieldNameList.isEmpty()) {
  891. //获取对应的ebId
  892. String wpdDayEbId = wpdDayFieldNameList.get(0).getId();
  893. //平均风速集合
  894. List<WindTowerCalculationData> wpdMonthList = new ArrayList<>();
  895. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(wpdDayEbId)).collect(Collectors.toList());
  896. BigDecimal wpdAve = BigDecimal.ZERO;
  897. ArrayList<Object> list = new ArrayList<>();
  898. for (long time : timeList) {
  899. wpdMonthList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(time)) == 0).collect(Collectors.toList());
  900. HashMap<Object, Object> map = new HashMap<>();
  901. String format = sdf1.format(time);
  902. BigDecimal value = BigDecimal.ZERO;
  903. if (!wpdMonthList.isEmpty()) {
  904. value = wpdMonthList.get(0).getValue();
  905. }
  906. map.put("wpd", value);
  907. map.put("time", format);
  908. list.add(map);
  909. }
  910. // 曲线
  911. HashMap<Object, Object> finalMap = new HashMap<>();
  912. finalMap.put("height", h);
  913. finalMap.put("arr", list);
  914. arrList.add(finalMap);
  915. //平均值
  916. List<BigDecimal> aveWsList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  917. if (!aveWsList.isEmpty()) {
  918. wpdAve = aveWsList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(aveWsList.size()), 2, RoundingMode.HALF_UP);
  919. }
  920. HashMap<Object, Object> finalAveMap = new HashMap<>();
  921. finalAveMap.put("height", h);
  922. finalAveMap.put("wpdAve", wpdAve);
  923. list1.add(finalAveMap);
  924. }
  925. }
  926. onlyData.add(arrList);
  927. onlyData.add(list1);
  928. }
  929. return onlyData;
  930. }
  931. /**
  932. * 时间段(年逐月)风切变曲线图(统计查询)
  933. *
  934. * @param height 测高
  935. * @param eqId 设备编号
  936. * @return List<Object>
  937. */
  938. public List<Object> getShear(Long startTime, Long endTime, String height, String eqId) {
  939. //最后返回的
  940. ArrayList<Object> onlyData = new ArrayList<>();
  941. //装所有风功率密度数据
  942. ArrayList<Object> arrList = new ArrayList<>();
  943. //装平均值
  944. ArrayList<Object> list1 = new ArrayList<>();
  945. List<String> heightSort = new ArrayList<>();
  946. List<WindTowerInfo> windTowerInfos = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, eqId).list();
  947. //给前端用的日期格式
  948. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM");
  949. //获取统计属性表
  950. List<EquipmentAttribute> shearDayFieldNameList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, "windShearMonth").list();
  951. //获取统计数据表
  952. List<WindTowerCalculationData> windTowerCalculationDataList = getByBetweenTimeAndEquipmentId(new Date(startTime), new Date(endTime), eqId).stream().sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());;
  953. // 根据开始时间、结束时间分割的月份
  954. List<Long> timeList = DateTimeUtil.getIntervalTimeByMonth(new Date(startTime), new Date(endTime));
  955. //存放数据
  956. if (!shearDayFieldNameList.isEmpty()) {
  957. String shearDayEbId = shearDayFieldNameList.get(0).getId();
  958. //风切变集合
  959. List<WindTowerCalculationData> shearMonthList = new ArrayList<>();
  960. List<WindTowerCalculationData> filterList = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(shearDayEbId)).collect(Collectors.toList());
  961. BigDecimal shearAve = BigDecimal.ZERO;
  962. ArrayList<Object> list = new ArrayList<>();
  963. for (long time : timeList) {
  964. shearMonthList = filterList.stream().filter(w -> w.getTime().compareTo(new Date(time)) == 0).collect(Collectors.toList());
  965. HashMap<Object, Object> map = new HashMap<>();
  966. String format = sdf1.format(time);
  967. BigDecimal value = BigDecimal.ZERO;
  968. if (!shearMonthList.isEmpty()) {
  969. value = shearMonthList.get(0).getValue();
  970. }
  971. map.put("shear", value);
  972. map.put("time", format);
  973. list.add(map);
  974. }
  975. // 曲线
  976. HashMap<Object, Object> finalMap = new HashMap<>();
  977. finalMap.put("height", "综合风切变");
  978. finalMap.put("arr", list);
  979. arrList.add(finalMap);
  980. //平均值
  981. List<BigDecimal> aveWsList = filterList.stream().map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  982. if (!aveWsList.isEmpty()) {
  983. shearAve = aveWsList.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(aveWsList.size()), 2, RoundingMode.HALF_UP);
  984. }
  985. HashMap<Object, Object> finalAveMap = new HashMap<>();
  986. finalAveMap.put("height", "综合风切变");
  987. finalAveMap.put("shearAve", shearAve);
  988. list1.add(finalAveMap);
  989. }
  990. onlyData.add(arrList);
  991. onlyData.add(list1);
  992. return onlyData;
  993. }
  994. /**
  995. * 计算日平均空气密度
  996. *
  997. * @param startTime 开始时间
  998. * @param endTime 结束时间
  999. * @param equipmentId 设备ID
  1000. * @return
  1001. */
  1002. public ArrayList<WindTowerCalculationData> airDensityDay(Date startTime, Date endTime, String equipmentId, List<ProphaseWeatherData> prophaseWeatherDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerCalculationData> windTowerCalculationDataList) {
  1003. long startHour = startTime.getTime();
  1004. long endHour = endTime.getTime();
  1005. Long dayTime = 86400000L;
  1006. //空气密度属性
  1007. EquipmentAttribute equipmentAttribute = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals("airDensity")).collect(Collectors.toList()).get(0);
  1008. //删除时间段所有数据
  1009. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, equipmentAttribute.getId());
  1010. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1011. try {
  1012. for (long start1 = startHour; start1 < endHour; start1 = start1 + dayTime) {
  1013. //每天的结束时间
  1014. long start2 = start1 + dayTime - 1L;
  1015. BigDecimal airDensityDay = new BigDecimal(0);
  1016. long start = start1;
  1017. List<ProphaseWeatherData> collect = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= start && p.getTs().getTime() <= start2).collect(Collectors.toList());
  1018. for (ProphaseWeatherData map : collect) {
  1019. airDensityDay = airDensityDay.add(CalculationUtil.getBigDecimal(map.getAirDensity()));
  1020. }
  1021. //存平均值
  1022. if (!collect.isEmpty()) {
  1023. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1024. windTowerCalculationData.setEbId(equipmentAttribute.getId());
  1025. windTowerCalculationData.setTime(new Date(start1));
  1026. windTowerCalculationData.setValue(airDensityDay.divide(new BigDecimal(collect.size()), 2, RoundingMode.HALF_UP));
  1027. windTowerCalculationData.setEquipmentId(equipmentId);
  1028. windTowerCalculationDataList.add(windTowerCalculationData);
  1029. list.add(windTowerCalculationData);
  1030. }
  1031. }
  1032. } catch (Exception e) {
  1033. log.error("计算日平均空气密度失败");
  1034. e.printStackTrace();
  1035. }
  1036. // saveBatchByEquipmentId(list, equipmentId);
  1037. log.info("计算日平均空气密度完成");
  1038. return list;
  1039. }
  1040. /**
  1041. * 计算月最大风速
  1042. *
  1043. * @param startTime 开始时间
  1044. * @param endTime 结束时间
  1045. * @param equipmentId 设备id
  1046. * @return
  1047. */
  1048. public ArrayList<WindTowerCalculationData> wsMaxMonth(Date startTime, Date endTime, String equipmentId, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1049. //获取时间段所有统计数据
  1050. // List<Map<String, Object>> collects = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startTime.getTime()
  1051. // && Long.parseLong(w.get("time").toString()) <= endTime.getTime() && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  1052. List<ProphaseAnemometryData> collect = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startTime.getTime() && p.getTs().getTime() <= endTime.getTime()).collect(Collectors.toList());
  1053. //获取所有层高
  1054. String[] height = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1055. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1056. try {
  1057. for (String h : height) {
  1058. //获取对应层高的字段
  1059. String ebIdMonth = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "maxwsMonth")).collect(Collectors.toList()).get(0).getId();
  1060. //删除时间段所有数据
  1061. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebIdMonth);
  1062. if (!collect.isEmpty()) {
  1063. BigDecimal max = CalculationUtil.getBigDecimal(collect.stream().filter(c -> c.getLayerHeight().equals(h)).mapToDouble(ProphaseAnemometryData::getWsMax).sum());
  1064. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1065. windTowerCalculationData.setEbId(ebIdMonth);
  1066. windTowerCalculationData.setTime(startTime);
  1067. windTowerCalculationData.setEquipmentId(equipmentId);
  1068. windTowerCalculationData.setValue(max.divide(BigDecimal.valueOf(collect.size()), 2, RoundingMode.HALF_UP));
  1069. list.add(windTowerCalculationData);
  1070. } else {
  1071. log.info("设备编号{},{}月,{}米层高月最大风速计算失败,缺少数据^ ^", equipmentId, startTime.getMonth() + 1, h);
  1072. }
  1073. }
  1074. } catch (Exception e) {
  1075. log.error("设备编号{}月最大风速计算失败^ ^", equipmentId);
  1076. }
  1077. // saveBatchByEquipmentId(list, equipmentId);
  1078. log.info("设备编号{}月最大风速计算成功^ ^", equipmentId);
  1079. return list;
  1080. }
  1081. /**
  1082. * 计算月平均空气密度
  1083. *
  1084. * @param startTime 开始时间
  1085. * @param endTime 结束时间
  1086. * @param equipmentId 设备ID
  1087. * @return
  1088. */
  1089. public ArrayList<WindTowerCalculationData> airDensityMonth(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList) {
  1090. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1091. //时间-1防止0点数据查不到
  1092. Date startHour = new Date(startTime.getTime() - 1);
  1093. //获取时间段所有统计数据
  1094. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startHour) && w.getTime().before(endTime)).collect(Collectors.toList());
  1095. EquipmentAttribute equipmentAttribute = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals("airDensity")).collect(Collectors.toList()).get(0);
  1096. EquipmentAttribute equipmentAttributeMonth = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals("airDensityMonth")).collect(Collectors.toList()).get(0);
  1097. //删除
  1098. removeByStartTimeBetweenAndEquipmentIdAndEbId(startHour, endTime, equipmentId, equipmentAttributeMonth.getId());
  1099. BigDecimal airDensityMonth = new BigDecimal(0);
  1100. try {
  1101. //找出空气密度和月空气密度属性
  1102. //所有数据日空气密度
  1103. List<WindTowerCalculationData> windCalDataList = windTowerCalculationDataList1.stream().filter(w -> w.getTime().after(startHour) &&
  1104. w.getTime().before(endTime) && w.getEquipmentId().equals(equipmentId) && w.getEbId().equals(equipmentAttribute.getId())).collect(Collectors.toList());
  1105. for (WindTowerCalculationData w : windCalDataList) {
  1106. airDensityMonth = airDensityMonth.add(w.getValue());
  1107. }
  1108. //平均值
  1109. if (!windCalDataList.isEmpty()) {
  1110. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1111. windTowerCalculationData.setEbId(equipmentAttributeMonth.getId());
  1112. windTowerCalculationData.setTime(startTime);
  1113. windTowerCalculationData.setValue(airDensityMonth.divide(new BigDecimal(windCalDataList.size()), 2, RoundingMode.HALF_UP));
  1114. windTowerCalculationData.setEquipmentId(equipmentId);
  1115. list.add(windTowerCalculationData);
  1116. // saveByEquipmentId(windTowerCalculationData, equipmentId);
  1117. log.info("计算月平均空气密度完成");
  1118. } else {
  1119. log.info("月平均空气密度缺少数据,无法计算");
  1120. }
  1121. } catch (Exception e) {
  1122. log.error("计算月平均空气密度失败");
  1123. e.printStackTrace();
  1124. }
  1125. return list;
  1126. }
  1127. /**
  1128. * 计算日平均风速
  1129. *
  1130. * @param startTime 开始时间
  1131. * @param endTime 结束时间
  1132. * @param equipmentId 设备id
  1133. * @return
  1134. */
  1135. public ArrayList<WindTowerCalculationData> wsDay(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1136. long startHour = startTime.getTime();
  1137. long endHour = endTime.getTime();
  1138. Long dayTime = 86400000L;
  1139. //获取测风塔所有层高
  1140. String heights = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights();
  1141. String[] strings = heights.split(",");
  1142. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startTime) && w.getTime().before(endTime)).collect(Collectors.toList());
  1143. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1144. try {
  1145. //遍历测风塔所有层高
  1146. for (String h : strings) {
  1147. //获取小时风速表
  1148. List<EquipmentAttribute> awsList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + "aws")).collect(Collectors.toList());
  1149. //获取日风速表
  1150. List<EquipmentAttribute> awsDayList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + "awsDay")).collect(Collectors.toList());
  1151. //删除
  1152. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, awsDayList.get(0).getId());
  1153. for (long start1 = startHour; start1 < endHour; start1 = start1 + dayTime) {
  1154. long start2 = start1 + dayTime - 1L;
  1155. //获取小时风速数据
  1156. long start = start1;
  1157. List<WindTowerCalculationData> wsCalDataList = windTowerCalculationDataList1.stream().filter(
  1158. w -> w.getTime().after(new Date(start)) &&
  1159. w.getTime().before(new Date(start2)) &&
  1160. w.getEquipmentId().equals(equipmentId) &&
  1161. w.getEbId().equals(awsList.get(0).getId()))
  1162. .collect(Collectors.toList()
  1163. );
  1164. //小时风功率总值
  1165. BigDecimal awsSum = BigDecimal.ZERO;
  1166. for (WindTowerCalculationData ws : wsCalDataList) {
  1167. awsSum = awsSum.add(ws.getValue()).setScale(4, RoundingMode.HALF_UP);
  1168. }
  1169. if (!wsCalDataList.isEmpty()) {
  1170. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1171. windTowerCalculationData.setEquipmentId(equipmentId);
  1172. windTowerCalculationData.setValue(awsSum.divide(new BigDecimal(wsCalDataList.size()), 2, RoundingMode.HALF_UP));
  1173. windTowerCalculationData.setEbId(awsDayList.get(0).getId());
  1174. windTowerCalculationData.setTime(new Date(start1));
  1175. windTowerCalculationDataList.add(windTowerCalculationData);
  1176. list.add(windTowerCalculationData);
  1177. } else {
  1178. log.info("设备编号{},{},{}米层高日平均风速计算失败,缺少数据^ ^", equipmentId, DateTimeUtil.dateToStrLong(new Date(start1)), h);
  1179. }
  1180. }
  1181. }
  1182. } catch (Exception e) {
  1183. log.error("设备编号{}日平均风速计算失败^ ^", equipmentId);
  1184. e.printStackTrace();
  1185. }
  1186. // saveBatchByEquipmentId(list, equipmentId);
  1187. log.info("设备编号{}米层高日平均风速计算成功^ ^", equipmentId);
  1188. return list;
  1189. }
  1190. /**
  1191. * 计算月平均风速
  1192. *
  1193. * @param startTime 开始时间
  1194. * @param endTime 结束时间
  1195. * @param equipmentId 设备编号
  1196. * @return
  1197. */
  1198. public ArrayList<WindTowerCalculationData> wsMonth(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1199. //时间-1防止0点数据查不到
  1200. Date startHour = new Date(startTime.getTime() - 1);
  1201. //获取时间段所有统计数据
  1202. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startHour) && w.getTime().before(endTime)).collect(Collectors.toList());
  1203. //获取所有层高
  1204. String[] height = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1205. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1206. //遍历层高
  1207. try {
  1208. for (String h : height) {
  1209. //获取对应层高的月平均风速字段
  1210. String ebIdMonth = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "awsMonth")).collect(Collectors.toList()).get(0).getId();
  1211. String ebIdDay = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "awsDay")).collect(Collectors.toList()).get(0).getId();
  1212. //删除时间段所有数据
  1213. removeByStartTimeBetweenAndEquipmentIdAndEbId(startHour, endTime, equipmentId, ebIdMonth);
  1214. //获取所有日平均风速
  1215. List<WindTowerCalculationData> windTowerCalculationDatas = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(ebIdDay) && w.getTime().after(startHour) && w.getTime().before(endTime) && w.getEquipmentId().equals(equipmentId)).collect(Collectors.toList());
  1216. BigDecimal wsSum = new BigDecimal(0);
  1217. for (WindTowerCalculationData w : windTowerCalculationDatas) {
  1218. wsSum = wsSum.add(w.getValue());
  1219. }
  1220. if (!windTowerCalculationDatas.isEmpty()) {
  1221. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1222. windTowerCalculationData.setEbId(ebIdMonth);
  1223. windTowerCalculationData.setTime(startTime);
  1224. windTowerCalculationData.setEquipmentId(equipmentId);
  1225. windTowerCalculationData.setValue(wsSum.divide(new BigDecimal(windTowerCalculationDatas.size()), 2, RoundingMode.HALF_UP).setScale(2, RoundingMode.HALF_UP));
  1226. list.add(windTowerCalculationData);
  1227. } else {
  1228. log.info("设备编号{},{}月,{}米层高月平均风速计算失败,缺少数据^ ^", equipmentId, startTime.getMonth() + 1, h);
  1229. }
  1230. }
  1231. } catch (Exception e) {
  1232. log.error("设备编号{}月平均风速计算失败^ ^", equipmentId);
  1233. e.printStackTrace();
  1234. }
  1235. // saveBatchByEquipmentId(list, equipmentId);
  1236. log.info("{}设备月平均风速统计完成", equipmentId);
  1237. return list;
  1238. }
  1239. /**
  1240. * 计算日平均风功率密度
  1241. *
  1242. * @param startTime 开始时间
  1243. * @param endTime 结束时间
  1244. * @param equipmentId 设备id
  1245. * @return
  1246. */
  1247. public ArrayList<WindTowerCalculationData> wpdDay(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1248. long startHour = startTime.getTime();
  1249. long endHour = endTime.getTime();
  1250. long dayTime = 86400000L;
  1251. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startTime) && w.getTime().before(endTime)).collect(Collectors.toList());
  1252. //获取所有层高
  1253. String heights = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights();
  1254. String[] strings = heights.split(",");
  1255. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1256. try {
  1257. //遍历层高
  1258. for (String h : strings) {
  1259. //获取所有小时风功率表
  1260. List<EquipmentAttribute> wpdList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + "wpd")).collect(Collectors.toList());
  1261. //获取所有日风功率表
  1262. List<EquipmentAttribute> wpdDayList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + "wpdDay")).collect(Collectors.toList());
  1263. //删除
  1264. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, wpdDayList.get(0).getId());
  1265. for (long start1 = startHour; start1 < endHour; start1 = start1 + dayTime) {
  1266. long start2 = start1 + dayTime - 1L;
  1267. //获取所有小时风功率数据
  1268. long start = start1;
  1269. List<WindTowerCalculationData> wpdCalDataList = windTowerCalculationDataList1.stream().filter(w -> w.getTime().after(new Date(start)) &&
  1270. w.getTime().before(new Date(start2)) && w.getEquipmentId().equals(equipmentId) && w.getEbId().equals(wpdList.get(0).getId())).collect(Collectors.toList());
  1271. //小时风功率总值
  1272. BigDecimal wpdSum = BigDecimal.ZERO;
  1273. for (WindTowerCalculationData wpd : wpdCalDataList) {
  1274. wpdSum = wpdSum.add(wpd.getValue());
  1275. }
  1276. if (!wpdCalDataList.isEmpty()) {
  1277. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1278. windTowerCalculationData.setEquipmentId(equipmentId);
  1279. windTowerCalculationData.setValue(wpdSum.divide(new BigDecimal(wpdCalDataList.size()), 2, RoundingMode.HALF_UP));
  1280. windTowerCalculationData.setEbId(wpdDayList.get(0).getId());
  1281. windTowerCalculationData.setTime(new Date(start1));
  1282. windTowerCalculationDataList.add(windTowerCalculationData);
  1283. list.add(windTowerCalculationData);
  1284. } else {
  1285. log.info("设备编号{},{},{}米层高日平均风功率计算失败,缺少数据^ ^", equipmentId, DateTimeUtil.dateToStrLong(new Date(start1)), h);
  1286. }
  1287. }
  1288. }
  1289. } catch (Exception e) {
  1290. log.error("设备编号{}日平均风功率计算失败^ ^", equipmentId);
  1291. e.printStackTrace();
  1292. }
  1293. // saveBatchByEquipmentId(list, equipmentId);
  1294. log.info("设备编号{}日平均风功率计算成功^ ^", equipmentId);
  1295. return list;
  1296. }
  1297. /**
  1298. * 计算月平均风功率密度
  1299. *
  1300. * @param startTime 开始时间
  1301. * @param endTime 结束时间
  1302. * @param equipmentId 设备id
  1303. * @return
  1304. */
  1305. @Transactional
  1306. public ArrayList<WindTowerCalculationData> wpdMonth(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1307. //时间-1防止0点数据查不到
  1308. Date startHour = new Date(startTime.getTime() - 1);
  1309. //获取时间段所有统计数据
  1310. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startHour) && w.getTime().before(endTime)).collect(Collectors.toList());
  1311. //获取所有层高
  1312. String[] height = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1313. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1314. try {
  1315. for (String h : height) {
  1316. //获取对应层高的月平均风速字段
  1317. String ebIdMonth = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "wpdMonth")).collect(Collectors.toList()).get(0).getId();
  1318. String ebIdDay = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "wpdDay")).collect(Collectors.toList()).get(0).getId();
  1319. //删除时间段所有数据
  1320. removeByStartTimeBetweenAndEquipmentIdAndEbId(startHour, endTime, equipmentId, ebIdMonth);
  1321. //获取所有日平均风功率密度
  1322. List<WindTowerCalculationData> windTowerCalculationDatas = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(ebIdDay) && w.getTime().after(startHour) && w.getTime().before(endTime) && w.getEquipmentId().equals(equipmentId)).collect(Collectors.toList());
  1323. BigDecimal sum = new BigDecimal(0);
  1324. for (WindTowerCalculationData w : windTowerCalculationDatas) {
  1325. sum = sum.add(w.getValue());
  1326. }
  1327. if (!windTowerCalculationDatas.isEmpty()) {
  1328. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1329. windTowerCalculationData.setEbId(ebIdMonth);
  1330. windTowerCalculationData.setTime(startTime);
  1331. windTowerCalculationData.setEquipmentId(equipmentId);
  1332. windTowerCalculationData.setValue(sum.divide(new BigDecimal(windTowerCalculationDatas.size()), 2, RoundingMode.HALF_UP).setScale(2, RoundingMode.HALF_UP));
  1333. list.add(windTowerCalculationData);
  1334. } else {
  1335. log.info("设备编号{},{}月,{}米层高月平均风功率密度计算失败,缺少数据^ ^", equipmentId, startTime.getMonth() + 1, h);
  1336. }
  1337. }
  1338. } catch (Exception e) {
  1339. log.error("设备编号{}月平均风功率计算失败^ ^", equipmentId);
  1340. e.printStackTrace();
  1341. }
  1342. // saveBatchByEquipmentId(list, equipmentId);
  1343. log.info("设备编号{}高月平均风功率计算成功^ ^", equipmentId);
  1344. return list;
  1345. }
  1346. /**
  1347. * 计算日平均风速标差
  1348. *
  1349. * @param startTime 开始时间
  1350. * @param endTime 结束时间
  1351. * @param equipmentId 测风塔编号
  1352. * @param equipmentAttributeList 属性表
  1353. * @param windTowerInfoList 测风塔数据
  1354. * @return
  1355. */
  1356. public ArrayList<WindTowerCalculationData> calculateStaDay(Date startTime, Date endTime, String equipmentId, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList, List<WindTowerCalculationData> windTowerCalculationDataList) {
  1357. ArrayList<WindTowerCalculationData> dataList = new ArrayList<>();
  1358. long startHour = startTime.getTime();
  1359. long endHour = endTime.getTime();
  1360. long Hour = 86400000;
  1361. String[] heights = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1362. try {
  1363. for (String h : heights) {
  1364. //获取对应层高的属性
  1365. List<EquipmentAttribute> equipmentAttributes = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "staDay")).collect(Collectors.toList());
  1366. //删除数据
  1367. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, equipmentAttributes.get(0).getId());
  1368. //每天循环
  1369. for (long time = startHour; time < endHour; time = time + Hour) {
  1370. long startDate = time;
  1371. //过滤一天的数据
  1372. List<ProphaseAnemometryData> collect = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startDate && p.getTs().getTime() < startDate + Hour && p.getLayerHeight().equals(h)).collect(Collectors.toList());
  1373. BigDecimal staSum = CalculationUtil.getBigDecimal(collect.stream().filter(c -> c.getWsSta() != null && c.getWsSta() != 0).mapToDouble(ProphaseAnemometryData::getWsSta).sum());
  1374. if (collect.size() > 0) {
  1375. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1376. windTowerCalculationData.setEquipmentId(equipmentId);
  1377. windTowerCalculationData.setTime(new Date(startDate));
  1378. windTowerCalculationData.setValue(staSum.divide(CalculationUtil.getBigDecimal(collect.size()), 2, RoundingMode.HALF_UP));
  1379. windTowerCalculationData.setEbId(equipmentAttributes.get(0).getId());
  1380. windTowerCalculationDataList.add(windTowerCalculationData);
  1381. dataList.add(windTowerCalculationData);
  1382. }
  1383. }
  1384. }
  1385. } catch (Exception e) {
  1386. log.error("设备编号{}日平均风速标差计算失败^ ^", equipmentId);
  1387. e.printStackTrace();
  1388. }
  1389. // saveBatchByEquipmentId(dataList);
  1390. log.info("设备编号{},风速标差数据计算完成", equipmentId);
  1391. return dataList;
  1392. }
  1393. /**
  1394. * 计算日平均湍流
  1395. *
  1396. * @param startTime 开始时间
  1397. * @param endTime 结束时间
  1398. * @param equipmentId 设备id
  1399. * @return
  1400. */
  1401. public ArrayList<WindTowerCalculationData> turbulenceDay(Date startTime, Date endTime, String equipmentId, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList, List<WindTowerCalculationData> windTowerCalculationDataList) {
  1402. long startHour = startTime.getTime();
  1403. long endHour = endTime.getTime();
  1404. long dayTime = 86400000L;
  1405. String heights = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights();
  1406. String[] heightAll = heights.split(",");
  1407. //获取对应测风塔数据
  1408. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1409. try {
  1410. for (String h : heightAll) {
  1411. List<EquipmentAttribute> turList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + turbulenceDay)).collect(Collectors.toList());
  1412. List<EquipmentAttribute> staList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + staDay)).collect(Collectors.toList());
  1413. List<EquipmentAttribute> wsList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(h + "awsDay")).collect(Collectors.toList());
  1414. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, turList.get(0).getId());
  1415. for (long start1 = startHour; start1 < endHour; start1 = start1 + dayTime) {
  1416. long finalStart = start1;
  1417. List<WindTowerCalculationData> staDay = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(staList.get(0).getId()) && w.getTime().getTime() == finalStart).collect(Collectors.toList());
  1418. List<WindTowerCalculationData> wsDay = windTowerCalculationDataList.stream().filter(w -> w.getEbId().equals(wsList.get(0).getId()) && w.getTime().getTime() == finalStart).collect(Collectors.toList());
  1419. if (!staDay.isEmpty() && !wsDay.isEmpty()) {
  1420. //数据入库
  1421. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1422. windTowerCalculationData.setTime(new Date(start1));
  1423. windTowerCalculationData.setEbId(turList.get(0).getId());
  1424. windTowerCalculationData.setEquipmentId(equipmentId);
  1425. windTowerCalculationData.setValue(CalculationUtil.caTurbulenceIntensity(staDay.get(0).getValue(), wsDay.get(0).getValue()));
  1426. windTowerCalculationDataList.add(windTowerCalculationData);
  1427. list.add(windTowerCalculationData);
  1428. } else {
  1429. log.info("设备编号{},{},{}米层高日平均湍流计算失败,缺少数据^ ^", equipmentId, DateTimeUtil.dateToStrLong(new Date(start1)), h);
  1430. }
  1431. }
  1432. }
  1433. } catch (NumberFormatException e) {
  1434. log.error("设备编号{}日平均湍流计算失败^ ^", equipmentId);
  1435. e.printStackTrace();
  1436. }
  1437. // saveBatchByEquipmentId(list, equipmentId);
  1438. log.info("设备编号{}日平均湍流计算成功^ ^", equipmentId);
  1439. return list;
  1440. }
  1441. /**
  1442. * 月平均湍流
  1443. *
  1444. * @param startTime 开始时间
  1445. * @param endTime 结束时间
  1446. * @param equipmentId 设备编号
  1447. * @return
  1448. */
  1449. public ArrayList<WindTowerCalculationData> turbulenceMonth(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1450. //时间-1防止0点数据查不到
  1451. Date startHour = new Date(startTime.getTime() - 1);
  1452. //获取时间段所有统计数据
  1453. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startHour) && w.getTime().before(endTime)).collect(Collectors.toList());
  1454. //获取所有层高
  1455. String[] height = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1456. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1457. try {
  1458. for (String h : height) {
  1459. //获取对应层高的月平均风速字段
  1460. String ebIdDay = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "turbulenceDay")).collect(Collectors.toList()).get(0).getId();
  1461. String ebIdMonth = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "turbulenceMonth")).collect(Collectors.toList()).get(0).getId();
  1462. //删除时间段所有数据
  1463. removeByStartTimeBetweenAndEquipmentIdAndEbId(startHour, endTime, equipmentId, ebIdMonth);
  1464. //获取所有日平均湍流风速
  1465. List<WindTowerCalculationData> windTowerCalculationDatas = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(ebIdDay) && w.getTime().after(startHour) && w.getTime().before(endTime) && w.getEquipmentId().equals(equipmentId)).collect(Collectors.toList());
  1466. BigDecimal sum = new BigDecimal(0);
  1467. for (WindTowerCalculationData w : windTowerCalculationDatas) {
  1468. sum = sum.add(w.getValue());
  1469. }
  1470. if (!windTowerCalculationDatas.isEmpty()) {
  1471. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1472. windTowerCalculationData.setEbId(ebIdMonth);
  1473. windTowerCalculationData.setTime(startTime);
  1474. windTowerCalculationData.setEquipmentId(equipmentId);
  1475. windTowerCalculationData.setValue(sum.divide(new BigDecimal(windTowerCalculationDatas.size()), 2, RoundingMode.HALF_UP).setScale(2, RoundingMode.HALF_UP));
  1476. list.add(windTowerCalculationData);
  1477. } else {
  1478. log.info("设备编号{},{}月,{}米层高月平均湍流计算失败,缺少数据^ ^", equipmentId, startTime.getMonth() + 1, h);
  1479. }
  1480. }
  1481. } catch (Exception e) {
  1482. log.error("设备编号{}月平均湍流计算失败^ ^", equipmentId);
  1483. }
  1484. // saveBatchByEquipmentId(list, equipmentId);
  1485. log.info("设备编号{}月平均湍流计算成功^ ^", equipmentId);
  1486. return list;
  1487. }
  1488. /**
  1489. * 计算日风切变入库
  1490. *
  1491. * @param startTime 开始时间
  1492. * @param endTime 结束时间
  1493. * @param equipmentId 设备id
  1494. * @return
  1495. */
  1496. public ArrayList<WindTowerCalculationData> shearDay(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1497. long startHour = startTime.getTime();
  1498. long endHour = endTime.getTime();
  1499. long dayTime = 86400000L;
  1500. //日平均所需要的集合
  1501. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startTime) && w.getTime().before(endTime)).collect(Collectors.toList());
  1502. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1503. try {
  1504. //遍历层高
  1505. //获取所有小时综合风切变
  1506. List<EquipmentAttribute> shearList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(windShearFiledName)).collect(Collectors.toList());
  1507. //获取日综合风切变
  1508. List<EquipmentAttribute> shearDayList = equipmentAttributeList.stream().filter(equipmentAttribute -> equipmentAttribute.getFieldName().equals(windShearDayFiledName)).collect(Collectors.toList());
  1509. //删除统计时间段所有数据
  1510. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, shearDayList.get(0).getId());
  1511. for (long start1 = startHour; start1 < endHour; start1 = start1 + dayTime) {
  1512. long start2 = start1 + dayTime - 1L;
  1513. //获取所有小时风切变数据
  1514. long start = start1;
  1515. List<WindTowerCalculationData> shearCalDataList = windTowerCalculationDataList1.stream().filter(w -> w.getTime().after(new Date(start)) &&
  1516. w.getTime().before(new Date(start2)) && w.getEquipmentId().equals(equipmentId) && w.getEbId().equals(shearList.get(0).getId())).collect(Collectors.toList());
  1517. //小时风切变总值
  1518. BigDecimal shearSum = BigDecimal.ZERO;
  1519. for (WindTowerCalculationData shear : shearCalDataList) {
  1520. shearSum = shearSum.add(shear.getValue());
  1521. }
  1522. if (!shearCalDataList.isEmpty()) {
  1523. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1524. windTowerCalculationData.setEquipmentId(equipmentId);
  1525. windTowerCalculationData.setValue(shearSum.divide(new BigDecimal(shearCalDataList.size()), 2, RoundingMode.HALF_UP));
  1526. windTowerCalculationData.setEbId(shearDayList.get(0).getId());
  1527. windTowerCalculationData.setTime(new Date(start1));
  1528. windTowerCalculationDataList.add(windTowerCalculationData);
  1529. list.add(windTowerCalculationData);
  1530. } else {
  1531. log.info("设备编号{},{},{}米层高日平均风切变计算失败,缺少数据^ ^", equipmentId, DateTimeUtil.dateToStrLong(new Date(start1)));
  1532. }
  1533. }
  1534. } catch (Exception e) {
  1535. log.error("设备编号{}日平均风切变计算失败^ ^", equipmentId);
  1536. e.printStackTrace();
  1537. }
  1538. // saveBatchByEquipmentId(list, equipmentId);
  1539. log.info("设备编号{}日平均风切变计算成功^ ^", equipmentId);
  1540. return list;
  1541. }
  1542. /**
  1543. * 计算月风切变入库
  1544. *
  1545. * @param startTime 开始时间
  1546. * @param endTime 结束时间
  1547. * @param equipmentId 设备id
  1548. * @return
  1549. */
  1550. public ArrayList<WindTowerCalculationData> shearMonth(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1551. //时间-1防止0点数据查不到
  1552. Date startHour = new Date(startTime.getTime() - 1);
  1553. //获取时间段所有统计数据
  1554. List<WindTowerCalculationData> windTowerCalculationDataList1 = windTowerCalculationDataList.stream().filter(w -> w.getEquipmentId().equals(equipmentId) && w.getTime().after(startHour) && w.getTime().before(endTime)).collect(Collectors.toList());
  1555. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1556. try {
  1557. //获取月平均综合风切变字段
  1558. String ebIdMonth = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("windShearMonth")).collect(Collectors.toList()).get(0).getId();
  1559. String ebIdDay = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("windShearDay")).collect(Collectors.toList()).get(0).getId();
  1560. //删除时间段所有数据
  1561. removeByStartTimeBetweenAndEquipmentIdAndEbId(startHour, endTime, equipmentId, ebIdMonth);
  1562. //获取所有日平均风切变
  1563. List<WindTowerCalculationData> windTowerCalculationDatas = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(ebIdDay) && w.getTime().after(startHour) && w.getTime().before(endTime) && w.getEquipmentId().equals(equipmentId))
  1564. .collect(Collectors.toList());
  1565. BigDecimal sum = new BigDecimal(0);
  1566. for (WindTowerCalculationData w : windTowerCalculationDatas) {
  1567. sum = sum.add(w.getValue());
  1568. }
  1569. if (!windTowerCalculationDatas.isEmpty()) {
  1570. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1571. windTowerCalculationData.setEbId(ebIdMonth);
  1572. windTowerCalculationData.setTime(startTime);
  1573. windTowerCalculationData.setEquipmentId(equipmentId);
  1574. windTowerCalculationData.setValue(sum.divide(new BigDecimal(windTowerCalculationDatas.size()), 2, RoundingMode.HALF_UP).setScale(2, RoundingMode.HALF_UP));
  1575. list.add(windTowerCalculationData);
  1576. } else {
  1577. log.info("设备编号{},{}月平均风切变指数计算失败,缺少数据^ ^", equipmentId, startTime.getMonth() + 1);
  1578. }
  1579. } catch (Exception e) {
  1580. log.error("设备编号{}月平均风月切变计算失败^ ^", equipmentId);
  1581. e.printStackTrace();
  1582. }
  1583. // saveBatchByEquipmentId(list, equipmentId);
  1584. log.info("设备编号{}月平均风切变计算成功^ ^", equipmentId);
  1585. return list;
  1586. }
  1587. /**
  1588. * 威布尔AK计算
  1589. *
  1590. * @param startTime 开始时间
  1591. * @param endTime 结束时间
  1592. * @param equipmentId 测风塔Id
  1593. * @param windTowerCalculationDataList 统计库数据
  1594. * @param equipmentAttributeList 统计表数据
  1595. * @param windTowerInfoList 测风塔表数据
  1596. */
  1597. public void statisticsWeiBullForAKForYear(Date startTime, Date endTime, String equipmentId, List<WindTowerCalculationData> windTowerCalculationDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  1598. //获取时间段测风塔数据
  1599. List<WindTowerCalculationData> windTowerCalculationDataList1 = getByBetweenTimeAndEquipmentId(startTime, endTime, equipmentId);
  1600. String[] heights = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights().split(",");
  1601. //存数据用的集合
  1602. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1603. //遍历层高
  1604. try {
  1605. for (String h : heights) {
  1606. ArrayList<Object> wsList = new ArrayList<>();
  1607. //获取AK的ebId 以及小时风速id
  1608. String ebIdA = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(h + "weibullA")).collect(Collectors.toList()).get(0).getId();
  1609. String ebIdK = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(h + "weibullK")).collect(Collectors.toList()).get(0).getId();
  1610. String id = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(h + "aws")).collect(Collectors.toList()).get(0).getId();
  1611. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebIdK);
  1612. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebIdA);
  1613. List<WindTowerCalculationData> windTowerCalculationDataWsList = windTowerCalculationDataList1.stream().filter(w -> w.getEbId().equals(id)).collect(Collectors.toList());
  1614. for (WindTowerCalculationData w : windTowerCalculationDataWsList) {
  1615. if (w.getValue() != null) {
  1616. wsList.add(w.getValue());
  1617. }
  1618. }
  1619. if (!wsList.isEmpty()) {
  1620. //放入风速集合
  1621. ProbabilityPlot probabilityPlot = new ProbabilityPlot(wsList);
  1622. probabilityPlot.suppressDisplay();
  1623. //计算AK
  1624. double K = probabilityPlot.weibullTwoParGamma();
  1625. double A = probabilityPlot.weibullTwoParSigma();
  1626. WindTowerCalculationData windTowerCalculationDataK = new WindTowerCalculationData();
  1627. windTowerCalculationDataK.setValue(BigDecimal.valueOf(K));
  1628. windTowerCalculationDataK.setEbId(ebIdK);
  1629. windTowerCalculationDataK.setTime(DateUtil.beginOfDay(new Date(startTime.getTime() + 86400000 * 2)));
  1630. windTowerCalculationDataK.setEquipmentId(equipmentId);
  1631. WindTowerCalculationData windTowerCalculationDataA = new WindTowerCalculationData();
  1632. windTowerCalculationDataA.setValue(BigDecimal.valueOf(A));
  1633. windTowerCalculationDataA.setEbId(ebIdA);
  1634. windTowerCalculationDataA.setTime(DateUtil.beginOfDay(new Date(startTime.getTime() + 86400000 * 2)));
  1635. windTowerCalculationDataA.setEquipmentId(equipmentId);
  1636. list.add(windTowerCalculationDataK);
  1637. list.add(windTowerCalculationDataA);
  1638. } else {
  1639. log.info("缺少风速数据,无法计算威布尔AK值");
  1640. }
  1641. }
  1642. } catch (NumberFormatException e) {
  1643. log.error("威布尔AK计算异常");
  1644. e.printStackTrace();
  1645. }
  1646. saveBatchByEquipmentId(list, equipmentId);
  1647. log.info("设备{},威布尔AK计算成功", equipmentId);
  1648. }
  1649. /**
  1650. * 日平均温度入库
  1651. *
  1652. * @param startTime 开始时间
  1653. * @param endTime 结束时间
  1654. * @param equipmentId 设备Id
  1655. * @param equipmentAttributeList 属性集合
  1656. */
  1657. public ArrayList<WindTowerCalculationData> tDay(Date startTime, Date endTime, String equipmentId, List<ProphaseWeatherData> prophaseWeatherDataList, List<EquipmentAttribute> equipmentAttributeList) {
  1658. String ebId = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("tDay")).collect(Collectors.toList()).get(0).getId();
  1659. long day = 86400000L;
  1660. ArrayList<WindTowerCalculationData> tList = new ArrayList<>();
  1661. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebId);
  1662. try {
  1663. for (long time = startTime.getTime(); time < endTime.getTime(); time += day) {
  1664. long dayTime = time;
  1665. //过滤一天数据
  1666. List<ProphaseWeatherData> collect = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= dayTime && p.getTs().getTime() < dayTime + day).collect(Collectors.toList());
  1667. //计算时间段内所有温度
  1668. BigDecimal tSum = CalculationUtil.getBigDecimal(collect.stream().filter(c -> c.getTAve() != null && c.getTAve() != 0).mapToDouble(ProphaseWeatherData::getTAve).sum());
  1669. if (!collect.isEmpty()) {
  1670. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1671. windTowerCalculationData.setEbId(ebId);
  1672. windTowerCalculationData.setTime(new Date(dayTime));
  1673. windTowerCalculationData.setValue(tSum.divide(BigDecimal.valueOf(collect.size()), 2, RoundingMode.HALF_UP));
  1674. windTowerCalculationData.setEquipmentId(equipmentId);
  1675. tList.add(windTowerCalculationData);
  1676. }
  1677. }
  1678. } catch (Exception e) {
  1679. log.error("设备{}日平均温度统计异常", equipmentId);
  1680. e.printStackTrace();
  1681. }
  1682. // saveBatchByEquipmentId(list, equipmentId);
  1683. log.info("{}设备日平均温度计算完成", equipmentId);
  1684. return tList;
  1685. }
  1686. /**
  1687. * 日平均气压入库
  1688. *
  1689. * @param startTime 开始时间
  1690. * @param endTime 结束时间
  1691. * @param equipmentId 设备Id
  1692. * @param equipmentAttributeList 属性集合
  1693. */
  1694. public ArrayList<WindTowerCalculationData> paDay(Date startTime, Date endTime, String equipmentId, List<ProphaseWeatherData> prophaseWeatherDataList, List<EquipmentAttribute> equipmentAttributeList) {
  1695. String ebId = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("paDay")).collect(Collectors.toList()).get(0).getId();
  1696. long day = 86400000L;
  1697. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  1698. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebId);
  1699. try {
  1700. for (long time = startTime.getTime(); time < endTime.getTime(); time += day) {
  1701. long dayTime = time;
  1702. //过滤一天数据
  1703. List<ProphaseWeatherData> collect = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= dayTime && p.getTs().getTime() < dayTime + day).collect(Collectors.toList());
  1704. BigDecimal paSum = CalculationUtil.getBigDecimal(collect.stream().filter(c -> c.getPaAve() != null && c.getPaAve() != 0).mapToDouble(ProphaseWeatherData::getTAve).sum());
  1705. if (!collect.isEmpty()) {
  1706. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1707. windTowerCalculationData.setEbId(ebId);
  1708. windTowerCalculationData.setTime(new Date(dayTime));
  1709. windTowerCalculationData.setValue(paSum.divide(BigDecimal.valueOf(collect.size()), 2, RoundingMode.HALF_UP));
  1710. windTowerCalculationData.setEquipmentId(equipmentId);
  1711. list.add(windTowerCalculationData);
  1712. }
  1713. }
  1714. } catch (Exception e) {
  1715. log.error("设备{}日平均气压统计异常", equipmentId);
  1716. e.printStackTrace();
  1717. }
  1718. // saveBatchByEquipmentId(list, equipmentId);
  1719. log.info("{}设备日平均气压计算完成", equipmentId);
  1720. return list;
  1721. }
  1722. /**
  1723. * 计算上一个小时 每10分钟的风切变指数
  1724. */
  1725. public ArrayList<WindTowerCalculationData> calculateWindPowerShear(Date startTime, Date endTime, String equipmentId, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<WindTowerCalculationData> windTowerCalculationDataList) {
  1726. log.info("开始计算小时风切变指数");
  1727. long startHour = startTime.getTime();
  1728. long endHour = endTime.getTime();
  1729. List<WindTowerInfo> windTowerInfoList = windTowerInfoService.lambdaQuery().eq(WindTowerInfo::getEquipmentNo, equipmentId).list();
  1730. String[] heights = windTowerInfoList.get(0).getHeights().split(",");
  1731. ArrayList<WindTowerCalculationData> listAll = new ArrayList<>();
  1732. //时间段内所有风数据
  1733. List<ProphaseAnemometryData> prophaseAnemometryData = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startTime.getTime() && p.getTs().getTime() <= endTime.getTime()).collect(Collectors.toList());
  1734. EquipmentAttribute equipmentAttribute = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, windShearFiledName).list().get(0);
  1735. //删除综合风切变
  1736. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, equipmentAttribute.getId());
  1737. try {
  1738. for (long start1 = startHour; start1 <= endHour; start1 = start1 + 3600000) {
  1739. //开始时间--->start1 结束时间---->start2
  1740. long start2 = start1 + 3600000L;
  1741. BigDecimal oneHourWindShear = BigDecimal.ZERO;
  1742. BigDecimal total = BigDecimal.ZERO;
  1743. for (long i = start1; i < start2; i = i + 600000) {
  1744. long finalI = i;
  1745. List<ProphaseAnemometryData> collect = prophaseAnemometryData.stream().filter(p -> p.getTs().getTime() >= finalI && p.getTs().getTime() <= finalI + 600000 - 1).collect(Collectors.toList());
  1746. //计算十分钟综合风切变
  1747. BigDecimal windShear = CalculationUtil.getWindShear(collect, heights);
  1748. if (windShear.compareTo(BigDecimal.ZERO) != 0) {
  1749. oneHourWindShear = oneHourWindShear.add(windShear);
  1750. total = total.add(BigDecimal.ONE);
  1751. }
  1752. }
  1753. if (total.compareTo(BigDecimal.ZERO) > 0) {
  1754. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  1755. windTowerCalculationData.setEquipmentId(equipmentId);
  1756. windTowerCalculationData.setTime(new Date(start1));
  1757. windTowerCalculationData.setValue(oneHourWindShear.divide(total, 2, RoundingMode.HALF_UP));
  1758. windTowerCalculationData.setEbId(equipmentAttribute.getId());
  1759. windTowerCalculationDataList.add(windTowerCalculationData);
  1760. listAll.add(windTowerCalculationData);
  1761. }
  1762. }
  1763. } catch (Exception e) {
  1764. e.printStackTrace();
  1765. log.error("设备{}小时风切变统计异常", equipmentId);
  1766. }
  1767. //保存风切变指数
  1768. // saveBatchByEquipmentId(listAll, equipmentId);
  1769. log.info("{}设备风切变指数计算完成", equipmentId);
  1770. return listAll;
  1771. }
  1772. /**
  1773. * 根据 时间,层高,设备id 查询风切变数据
  1774. *
  1775. * @param time 时间
  1776. * @param height 层高
  1777. * @param eqId 设备id
  1778. * @return map: 一天一条
  1779. */
  1780. @Override
  1781. public List<Map<String, Object>> getWindShearByEqidAndAverageAndTime(Long time, String height, String eqId) {
  1782. List<Map<String, Object>> list = new ArrayList<>();
  1783. List<Map<String, Object>> tableList = new ArrayList<>();
  1784. Map<String, Object> map = new TreeMap<>();
  1785. String shearFieldName = height + "shearDay";
  1786. List<EquipmentAttribute> shearFieldNameList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, shearFieldName).list();
  1787. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  1788. Date currentDate = new Date(time);
  1789. if (!shearFieldNameList.isEmpty()) {
  1790. String ebId = shearFieldNameList.get(0).getId(); //属性id
  1791. //查询风切变 月平均数据 根据时间,层高,设备id 并根据时间升序排列
  1792. List<WindTowerCalculationData> windTowerCalculationDataLists = getByBetweenTimeAndEquipmentId(SEDateUtil.getStartTimeOfCurrentMonth(currentDate), SEDateUtil.getEndTimeOfCurrentMonth(currentDate), eqId);
  1793. List<WindTowerCalculationData> windTowerCalculationDataList = windTowerCalculationDataLists.stream().filter(w -> ebId.equals(w.getEbId())).sorted(Comparator.comparing(WindTowerCalculationData::getTime)).collect(Collectors.toList());
  1794. BigDecimal sum = BigDecimal.ZERO;
  1795. BigDecimal avgShear = BigDecimal.ZERO;
  1796. if (!windTowerCalculationDataList.isEmpty()) {
  1797. // //月平均风切变数据放入map返回,key为整- 小时:00
  1798. // long hour = 3600000L;
  1799. // Date systemDate = new Date();
  1800. // SimpleDateFormat simpleDateFormat = new SimpleDateFormat("HH");
  1801. // //获取昨日开始和结束时间
  1802. // long startTime = DateMomentUtil.getDayStartTime(DateUtils.addDays(systemDate, -1).getTime());
  1803. // long endTime = startTime + 86399000;
  1804. // // 一个月或多个月数据 按照24小时分割
  1805. // for (long hourStr = startTime; hourStr <= endTime; hourStr += hour) {
  1806. // Map<String, Object> tableMap = new TreeMap<>();
  1807. // String finalTime = simpleDateFormat.format(hourStr);
  1808. // List<BigDecimal> collect = windTowerCalculationDataList.stream().filter(w -> simpleDateFormat.format(w.getTime()).equals(finalTime) &&
  1809. // w.getValue().compareTo(new BigDecimal(-99)) != 0).map(WindTowerCalculationData::getValue).collect(Collectors.toList());
  1810. // BigDecimal avg = BigDecimal.ZERO;
  1811. // if (!collect.isEmpty()) {
  1812. // avg = collect.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(collect.size()), 4, RoundingMode.HALF_UP);
  1813. // }
  1814. // tableMap.put("time", finalTime + ":00");
  1815. // tableMap.put("windShear", avg);
  1816. // tableList.add(tableMap);
  1817. // }
  1818. for (WindTowerCalculationData windTowerCalculationData : windTowerCalculationDataList) {
  1819. Map<String, Object> tableMap = new TreeMap<>();
  1820. BigDecimal value = windTowerCalculationData.getValue().compareTo(new BigDecimal(-99)) != 0 ? windTowerCalculationData.getValue() : BigDecimal.ZERO;
  1821. tableMap.put("time", sdf.format(windTowerCalculationData.getTime()));
  1822. tableMap.put("windShear", value.setScale(2, RoundingMode.HALF_UP));
  1823. tableList.add(tableMap);
  1824. sum = sum.add(value);
  1825. }
  1826. if (sum.compareTo(new BigDecimal(0)) != 0) {
  1827. avgShear = sum.divide(new BigDecimal(windTowerCalculationDataList.size()), 2, RoundingMode.HALF_UP);
  1828. }
  1829. }
  1830. map.put("tableList", tableList);
  1831. map.put("avgShear", avgShear);
  1832. list.add(map);
  1833. // //计算月平均值
  1834. // double sum = 0;
  1835. // long count = 0;
  1836. // for (WindTowerCalculationData windTowerCalculationData : windTowerCalculationDataList) {
  1837. // double value = windTowerCalculationData.getValue().doubleValue();
  1838. // sum += value;
  1839. // count++;
  1840. // }
  1841. // BigDecimal avgShear = BigDecimal.valueOf(count > 0 ? sum / count : 0L).setScale(4, RoundingMode.HALF_UP);
  1842. // map.put("tableList", tableList);
  1843. // map.put("avgShear", avgShear);
  1844. // list.add(map);
  1845. }
  1846. return list;
  1847. }
  1848. /**
  1849. * 查询当前月的24个小时对应的风切变指数
  1850. * 每月1号的0-1点之间查询上个月的
  1851. *
  1852. * @return Map<String, WindTowerCalculationData>
  1853. */
  1854. private Map<String, WindTowerCalculationData> queryHistoryWindTowerCalculationDatas(List<WindTowerCalculationData> windTowerCalculationDataList) {
  1855. Map<String, WindTowerCalculationData> windTowerCalculationDataMap = new HashMap<>();
  1856. //查询风切变 月平均数据 根据时间,层高,设备id 并根据时间升序排列
  1857. windTowerCalculationDataList.forEach(windTowerCalculationData -> windTowerCalculationDataMap.put(windTowerCalculationData.getTime() + windTowerCalculationData.getEquipmentId() + windTowerCalculationData.getEbId(), windTowerCalculationData));
  1858. return windTowerCalculationDataMap;
  1859. }
  1860. /**
  1861. * 遍历查询到的风速数据,计算每隔10分钟的风切变指数
  1862. *
  1863. * @param map map
  1864. * @return Map<String, List < BigDecimal>>
  1865. */
  1866. private Map<String, List<BigDecimal>> traverseWindDataListCalcuShear(Map<String, BigDecimal> map, Integer heightMin) {
  1867. Map<String, List<BigDecimal>> windTowerShearMap = new HashMap<>();
  1868. map.forEach((key, value) -> {
  1869. String[] keys = key.split("-");//0:层高 1:整10分的时间点 2:设备ID 3:日
  1870. //10米层高不计算,没有更低的
  1871. if (!String.valueOf(heightMin).equals(keys[0]) && null != value) {
  1872. calculateShearByHeight10(keys, value, windTowerShearMap, map, heightMin);
  1873. }
  1874. });
  1875. return windTowerShearMap;
  1876. }
  1877. /**
  1878. * 查询数据类型表,获取所有风切变指数参数
  1879. *
  1880. * @return Map<String, String>
  1881. */
  1882. private Map<String, String> queryEquipmentAttributeMap() {
  1883. List<EquipmentAttribute> shearFieldNameList = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getAttributeFunction, shearFunction).list();
  1884. return shearFieldNameList.stream().collect(Collectors.toMap(EquipmentAttribute::getFieldName, EquipmentAttribute::getId));
  1885. }
  1886. /**
  1887. * 查询当前月份的风速数据,如果是1号0点-1点执行则查询上一个月的数据
  1888. *
  1889. * @return Map<String, BigDecimal>
  1890. */
  1891. private Map<String, BigDecimal> queryWindForShear(Date startTimeOfCurrentDay, Date endTimeOfCurrentDay, String equipmentId, List<ProphaseAnemometryData> prophaseAnemometryData, String[] heights) {
  1892. Map<String, BigDecimal> windTowerStatusDataResult = new HashMap<>();
  1893. // List<Map<String, Object>> collect = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startTimeOfCurrentDay.getTime() && Long.parseLong(w.get("time").toString()) <= endTimeOfCurrentDay.getTime() && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  1894. List<ProphaseAnemometryData> collect = prophaseAnemometryData.stream().filter(p -> p.getTs().getTime() >= startTimeOfCurrentDay.getTime() && p.getTs().getTime() <= endTimeOfCurrentDay.getTime()).collect(Collectors.toList());
  1895. //只取上一个小时的数据
  1896. int curentHour = startTimeOfCurrentDay.getHours();
  1897. //构造当前小时的风速map 以层高和分钟,日为key,风速为value
  1898. for (ProphaseAnemometryData map : collect) {
  1899. for (String height : heights) {
  1900. Date time = new Date(map.getTs().getTime());
  1901. if (curentHour == time.getHours() && map.getLayerHeight().equals(height)) {
  1902. //获取 毫秒数
  1903. Integer minutes = time.getMinutes();
  1904. String keyEndStr = minutes + "-" + equipmentId + "-" + DateTimeUtil.getDay(time.getTime());
  1905. windTowerStatusDataResult.put(height + "-" + keyEndStr, CalculationUtil.getBigDecimal(map.getWsAve()));
  1906. }
  1907. }
  1908. }
  1909. return windTowerStatusDataResult;
  1910. }
  1911. /**
  1912. * 查询当前月份的风速数据,如果是1号0点-1点执行则查询上一个月的数据
  1913. *
  1914. * @return Map<String, BigDecimal>
  1915. */
  1916. private Map<String, BigDecimal> queryWindForShear(Date startTimeOfCurrentDay, Date endTimeOfCurrentDay, String equipmentId, List<Map<String, Object>> mapList) {
  1917. Map<String, BigDecimal> windTowerStatusDataResult = new HashMap<>();
  1918. List<Map<String, Object>> collect = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startTimeOfCurrentDay.getTime() && Long.parseLong(w.get("time").toString()) <= endTimeOfCurrentDay.getTime() && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  1919. //只取上一个小时的数据
  1920. int curentHour = startTimeOfCurrentDay.getHours();
  1921. //构造当前小时的风速map 以层高和分钟,日为key,风速为value
  1922. for (Map<String, Object> map : collect) {
  1923. Date time = new Date(Long.parseLong(map.get("time").toString()));
  1924. if (curentHour == time.getHours()) {
  1925. //获取 毫秒数
  1926. Integer minutes = time.getMinutes();
  1927. String keyEndStr = minutes + "-" + equipmentId + "-" + DateTimeUtil.getDay(time.getTime());
  1928. if (null != map.get("abnormal_data")) {
  1929. judgeWsDataIsError(windTowerStatusDataResult, map, keyEndStr);
  1930. } else {
  1931. windTowerStatusDataResult.put("10-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave10")));
  1932. windTowerStatusDataResult.put("30-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave30")));
  1933. windTowerStatusDataResult.put("50-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave50")));
  1934. windTowerStatusDataResult.put("70-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave70")));
  1935. windTowerStatusDataResult.put("80-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave80")));
  1936. windTowerStatusDataResult.put("90-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave90")));
  1937. windTowerStatusDataResult.put("100-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave100")));
  1938. windTowerStatusDataResult.put("110-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave110")));
  1939. windTowerStatusDataResult.put("120-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave120")));
  1940. windTowerStatusDataResult.put("120A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave120A")));
  1941. windTowerStatusDataResult.put("140-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave140")));
  1942. windTowerStatusDataResult.put("140A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave140A")));
  1943. windTowerStatusDataResult.put("150-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave150")));
  1944. windTowerStatusDataResult.put("150A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave150A")));
  1945. }
  1946. }
  1947. }
  1948. return windTowerStatusDataResult;
  1949. }
  1950. /**
  1951. * 异常风速值不进行计算,忽略处理
  1952. *
  1953. * @param windTowerStatusDataResult windTowerStatusDataResult
  1954. * @param map map
  1955. * @param keyEndStr keyEndStr
  1956. */
  1957. private void judgeWsDataIsError(Map<String, BigDecimal> windTowerStatusDataResult, Map<String, Object> map, String keyEndStr) {
  1958. String abnormalType = map.get("abnormal_type").toString();
  1959. if (!abnormalType.contains("Ave10")) {
  1960. windTowerStatusDataResult.put("10-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave10")));
  1961. }
  1962. if (!abnormalType.contains("Ave30")) {
  1963. windTowerStatusDataResult.put("30-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave30")));
  1964. }
  1965. if (!abnormalType.contains("Ave50")) {
  1966. windTowerStatusDataResult.put("50-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave50")));
  1967. }
  1968. if (!abnormalType.contains("Ave70")) {
  1969. windTowerStatusDataResult.put("70-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave70")));
  1970. }
  1971. if (!abnormalType.contains("Ave80")) {
  1972. windTowerStatusDataResult.put("80-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave80")));
  1973. }
  1974. if (!abnormalType.contains("Ave90")) {
  1975. windTowerStatusDataResult.put("90-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave90")));
  1976. }
  1977. if (!abnormalType.contains("Ave100")) {
  1978. windTowerStatusDataResult.put("100-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave100")));
  1979. }
  1980. if (!abnormalType.contains("Ave110")) {
  1981. windTowerStatusDataResult.put("110-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave110")));
  1982. }
  1983. if (!abnormalType.contains("Ave120")) {
  1984. windTowerStatusDataResult.put("120-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave120")));
  1985. }
  1986. if (!abnormalType.contains("Ave120A")) {
  1987. windTowerStatusDataResult.put("120A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave120A")));
  1988. }
  1989. if (!abnormalType.contains("Ave140")) {
  1990. windTowerStatusDataResult.put("140-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave140")));
  1991. }
  1992. if (!abnormalType.contains("Ave150")) {
  1993. windTowerStatusDataResult.put("150-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave150")));
  1994. }
  1995. if (!abnormalType.contains("Ave140A")) {
  1996. windTowerStatusDataResult.put("140A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave140A")));
  1997. }
  1998. if (!abnormalType.contains("Ave150A")) {
  1999. windTowerStatusDataResult.put("150A-" + keyEndStr, CalculationUtil.getBigDecimal(map.get("ws_ave150A")));
  2000. }
  2001. }
  2002. /**
  2003. * 以10米风速为基准 计算层高风切变指数
  2004. *
  2005. * @param keys keys
  2006. * @param ws ws
  2007. * @param windTowerShearMap 各层高风切结果集
  2008. * @param map
  2009. */
  2010. private void calculateShearByHeight10(String[] keys, BigDecimal ws, Map<String, List<BigDecimal>> windTowerShearMap, Map<String, BigDecimal> map, Integer heightMin) {
  2011. String height = keys[0];
  2012. String MINUTE = keys[1];
  2013. String equipmentId = keys[2];
  2014. String day = keys[3];
  2015. String keyEndStr = MINUTE + "-" + equipmentId + "-" + day;
  2016. String key = height + "-00-" + equipmentId;
  2017. //10米风速
  2018. BigDecimal wsMin = Convert.toBigDecimal(map.get(heightMin + "-" + keyEndStr));
  2019. //计算各风速风切变
  2020. BigDecimal shear = BigDecimal.ZERO;
  2021. if (wsMin != null) {
  2022. double z = new BigDecimal(getNumberFromString(height)).divide(new BigDecimal(heightMin), 4, RoundingMode.HALF_UP).doubleValue();
  2023. double z1 = Math.log10(z);
  2024. shear = Convert.toBigDecimal(Math.log10(Convert.toDouble(ws.divide(wsMin, 8, RoundingMode.HALF_UP))))
  2025. .divide(BigDecimal.valueOf(z1), 8, RoundingMode.HALF_UP);
  2026. }
  2027. //将计算的风切变结果放入结果集合中
  2028. if (null != windTowerShearMap.get(key)) {
  2029. List<BigDecimal> list = windTowerShearMap.get(key);
  2030. list.add(shear);
  2031. } else {
  2032. List<BigDecimal> list = new ArrayList<>();
  2033. list.add(shear);
  2034. windTowerShearMap.put(key, list);
  2035. }
  2036. }
  2037. /**
  2038. * 计算月平均风速标差
  2039. *
  2040. * @param startTime 开始时间
  2041. * @param endTime 结束时间
  2042. * @param equipmentId 设备id
  2043. * @return
  2044. */
  2045. public ArrayList<WindTowerCalculationData> staMonth(Date startTime, Date endTime, String equipmentId, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  2046. //时间-1防止0点数据查不到
  2047. Date startHour = new Date(startTime.getTime() - 1);
  2048. List<ProphaseAnemometryData> collect = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startTime.getTime() && p.getTs().getTime() <= endTime.getTime()).collect(Collectors.toList());
  2049. ArrayList<WindTowerCalculationData> windTowerCalculationDataList = new ArrayList<>();
  2050. String h = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights();
  2051. String[] heights = h.split(",");
  2052. //计算标差
  2053. for (String height : heights) {
  2054. List<EquipmentAttribute> equipmentAttributeList1 = equipmentAttributeList.stream().filter(e -> e.getFieldName().equals(height + "staMonth")).collect(Collectors.toList());
  2055. if (!collect.isEmpty()) {
  2056. BigDecimal sumSta = CalculationUtil.getBigDecimal(collect.stream().filter(c -> c.getWsSta() != null && c.getLayerHeight().equals(height)).mapToDouble(ProphaseAnemometryData::getWsSta).sum());
  2057. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  2058. windTowerCalculationData.setEbId(equipmentAttributeList1.get(0).getId());
  2059. windTowerCalculationData.setTime(startHour);
  2060. windTowerCalculationData.setValue(sumSta.divide(new BigDecimal(collect.size()), 2, RoundingMode.HALF_UP));
  2061. windTowerCalculationData.setEquipmentId(equipmentId);
  2062. windTowerCalculationDataList.add(windTowerCalculationData);
  2063. }
  2064. }
  2065. List<EquipmentAttribute> equipmentAttributeList1 = equipmentAttributeList.stream().filter(e -> "staMonth".equals(e.getAttributeFunction())).collect(Collectors.toList());
  2066. for (EquipmentAttribute e : equipmentAttributeList1) {
  2067. List<WindTowerCalculationData> windTowerCalculationDataList1 = getByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, e.getId());
  2068. if (!windTowerCalculationDataList1.isEmpty()) {
  2069. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, e.getId());
  2070. }
  2071. }
  2072. // saveBatchByEquipmentId(windTowerCalculationDataList, equipmentId);
  2073. return windTowerCalculationDataList;
  2074. }
  2075. /**
  2076. * @param startTime 开始时间
  2077. * @param endTime 结束时间
  2078. * @param equipmentId 设备id
  2079. * @param equipmentAttributeList 属性集合
  2080. * @return
  2081. */
  2082. public ArrayList<WindTowerCalculationData> environmentData(Date startTime, Date endTime, String equipmentId, List<ProphaseWeatherData> prophaseWeatherDataList, List<EquipmentAttribute> equipmentAttributeList) {
  2083. ArrayList<WindTowerCalculationData> windTowerCalculationDataList = null;
  2084. try {
  2085. //时间-1防止0点数据查不到
  2086. Date startHour = new Date(startTime.getTime() - 1);
  2087. // List<Map<String, Object>> collect = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startHour.getTime() && Long.parseLong(w.get("time").toString()) <= endTime.getTime() && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  2088. List<ProphaseWeatherData> prophaseWeatherData = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= startHour.getTime() && p.getTs().getTime() <= endTime.getTime()).collect(Collectors.toList());
  2089. equipmentAttributeList = equipmentAttributeList.stream().filter(w -> "environment".equals(w.getAttributeFunction())).collect(Collectors.toList());
  2090. BigDecimal sumPa = new BigDecimal(0);
  2091. BigDecimal avePa = new BigDecimal(0);
  2092. BigDecimal sumRh = new BigDecimal(0);
  2093. BigDecimal aveRh = new BigDecimal(0);
  2094. BigDecimal sumT = new BigDecimal(0);
  2095. BigDecimal aveT = new BigDecimal(0);
  2096. windTowerCalculationDataList = new ArrayList<>();
  2097. if (!prophaseWeatherData.isEmpty()) {
  2098. List<BigDecimal> paList = new ArrayList<>();
  2099. List<BigDecimal> rhList = new ArrayList<>();
  2100. List<BigDecimal> tList = new ArrayList<>();
  2101. /*计算平均值数值为null 不计算*/
  2102. for (ProphaseWeatherData map : prophaseWeatherData) {
  2103. if (map.getPaAve() != null && map.getPaAve() != 0) {
  2104. paList.add(CalculationUtil.getBigDecimal(map.getPaAve()));
  2105. }
  2106. if (map.getRhAve() != null && map.getRhAve() != 0) {
  2107. rhList.add(CalculationUtil.getBigDecimal(map.getRhAve()));
  2108. }
  2109. if (map.getTAve() != null && map.getTAve() != 0) {
  2110. tList.add(CalculationUtil.getBigDecimal(map.getTAve()));
  2111. }
  2112. }
  2113. /*气压*/
  2114. BigDecimal maxPa = new BigDecimal(0);
  2115. BigDecimal minPa = new BigDecimal(0);
  2116. if (!paList.isEmpty()) {
  2117. maxPa = paList.stream().max(BigDecimal::compareTo).get();
  2118. minPa = paList.stream().min(BigDecimal::compareTo).get();
  2119. for (BigDecimal pa : paList) {
  2120. sumPa = sumPa.add(pa);
  2121. }
  2122. avePa = sumPa.divide(new BigDecimal(paList.size()), 2, RoundingMode.HALF_UP);
  2123. }
  2124. /*温度*/
  2125. BigDecimal maxT = new BigDecimal(0);
  2126. BigDecimal minT = new BigDecimal(0);
  2127. if (!tList.isEmpty()) {
  2128. maxT = tList.stream().max(BigDecimal::compareTo).get();
  2129. minT = tList.stream().min(BigDecimal::compareTo).get();
  2130. for (BigDecimal t : tList) {
  2131. sumT = sumT.add(t);
  2132. }
  2133. aveT = sumT.divide(new BigDecimal(tList.size()), 2, RoundingMode.HALF_UP);
  2134. }
  2135. /*湿度*/
  2136. BigDecimal maxRh = new BigDecimal(0);
  2137. BigDecimal minRh = new BigDecimal(0);
  2138. if (!rhList.isEmpty()) {
  2139. maxRh = rhList.stream().max(BigDecimal::compareTo).get();
  2140. minRh = rhList.stream().min(BigDecimal::compareTo).get();
  2141. for (BigDecimal rh : rhList) {
  2142. sumRh = sumRh.add(rh);
  2143. }
  2144. aveRh = sumRh.divide(new BigDecimal(rhList.size()), 2, RoundingMode.HALF_UP);
  2145. }
  2146. List<EquipmentAttribute> paMax = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("paMAX")).collect(Collectors.toList());
  2147. List<EquipmentAttribute> paMin = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("paMIN")).collect(Collectors.toList());
  2148. List<EquipmentAttribute> paAve = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("paAVE")).collect(Collectors.toList());
  2149. List<EquipmentAttribute> rhMax = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("rhMAX")).collect(Collectors.toList());
  2150. List<EquipmentAttribute> rhMin = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("rhMIN")).collect(Collectors.toList());
  2151. List<EquipmentAttribute> rhAve = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("rhAVE")).collect(Collectors.toList());
  2152. List<EquipmentAttribute> tMax = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("tMAX")).collect(Collectors.toList());
  2153. List<EquipmentAttribute> tMin = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("tMIN")).collect(Collectors.toList());
  2154. List<EquipmentAttribute> tAve = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals("tAVE")).collect(Collectors.toList());
  2155. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, paMax.get(0).getId());
  2156. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, paMin.get(0).getId());
  2157. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, paAve.get(0).getId());
  2158. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, rhMax.get(0).getId());
  2159. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, rhMin.get(0).getId());
  2160. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, rhAve.get(0).getId());
  2161. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, tMax.get(0).getId());
  2162. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, tMin.get(0).getId());
  2163. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, tAve.get(0).getId());
  2164. WindTowerCalculationData paMaxData = new WindTowerCalculationData();
  2165. paMaxData.setEbId(paMax.get(0).getId());
  2166. paMaxData.setValue(maxPa);
  2167. paMaxData.setTime(startTime);
  2168. paMaxData.setEquipmentId(equipmentId);
  2169. WindTowerCalculationData paMinData = new WindTowerCalculationData();
  2170. paMinData.setEbId(paMin.get(0).getId());
  2171. paMinData.setValue(minPa);
  2172. paMinData.setTime(startTime);
  2173. paMinData.setEquipmentId(equipmentId);
  2174. WindTowerCalculationData paAveData = new WindTowerCalculationData();
  2175. paAveData.setEbId(paAve.get(0).getId());
  2176. paAveData.setValue(avePa);
  2177. paAveData.setTime(startTime);
  2178. paAveData.setEquipmentId(equipmentId);
  2179. WindTowerCalculationData rhMaxData = new WindTowerCalculationData();
  2180. rhMaxData.setEbId(rhMax.get(0).getId());
  2181. rhMaxData.setValue(maxRh);
  2182. rhMaxData.setTime(startTime);
  2183. rhMaxData.setEquipmentId(equipmentId);
  2184. WindTowerCalculationData rhMinData = new WindTowerCalculationData();
  2185. rhMinData.setEbId(rhMin.get(0).getId());
  2186. rhMinData.setValue(minRh);
  2187. rhMinData.setTime(startTime);
  2188. rhMinData.setEquipmentId(equipmentId);
  2189. WindTowerCalculationData rhAveData = new WindTowerCalculationData();
  2190. rhAveData.setEbId(rhAve.get(0).getId());
  2191. rhAveData.setValue(aveRh);
  2192. rhAveData.setTime(startTime);
  2193. rhAveData.setEquipmentId(equipmentId);
  2194. WindTowerCalculationData tMaxData = new WindTowerCalculationData();
  2195. tMaxData.setEbId(tMax.get(0).getId());
  2196. tMaxData.setValue(maxT);
  2197. tMaxData.setTime(startTime);
  2198. tMaxData.setEquipmentId(equipmentId);
  2199. WindTowerCalculationData tMinData = new WindTowerCalculationData();
  2200. tMinData.setEbId(tMin.get(0).getId());
  2201. tMinData.setValue(minT);
  2202. tMinData.setTime(startTime);
  2203. tMinData.setEquipmentId(equipmentId);
  2204. WindTowerCalculationData tAveData = new WindTowerCalculationData();
  2205. tAveData.setEbId(tAve.get(0).getId());
  2206. tAveData.setValue(aveT);
  2207. tAveData.setTime(startTime);
  2208. tAveData.setEquipmentId(equipmentId);
  2209. windTowerCalculationDataList.add(paAveData);
  2210. windTowerCalculationDataList.add(paMaxData);
  2211. windTowerCalculationDataList.add(paMinData);
  2212. windTowerCalculationDataList.add(rhAveData);
  2213. windTowerCalculationDataList.add(rhMaxData);
  2214. windTowerCalculationDataList.add(rhMinData);
  2215. windTowerCalculationDataList.add(tAveData);
  2216. windTowerCalculationDataList.add(tMaxData);
  2217. windTowerCalculationDataList.add(tMinData);
  2218. // saveBatchByEquipmentId(windTowerCalculationDataList, equipmentId);
  2219. }
  2220. } catch (Exception e) {
  2221. e.printStackTrace();
  2222. }
  2223. return windTowerCalculationDataList;
  2224. }
  2225. /**
  2226. * 湍流月逐时
  2227. *
  2228. * @param equipmentId 设备Id
  2229. * @param startTime 开始时间
  2230. * @param endTime 结束时间
  2231. * @param equipmentAttributeList 属性集合
  2232. * @param windTowerInfoList 测风塔信息
  2233. * @return
  2234. */
  2235. public ArrayList<WindTowerCalculationData> turbulenceHourForMonth(String equipmentId, Date startTime, Date endTime, List<ProphaseAnemometryData> prophaseAnemometryDataList, List<EquipmentAttribute> equipmentAttributeList, List<WindTowerInfo> windTowerInfoList) {
  2236. String height = windTowerInfoList.stream().filter(w -> w.getEquipmentNo().equals(equipmentId)).collect(Collectors.toList()).get(0).getHeights();
  2237. String[] heights = height.split(",");
  2238. long hour = 3600000L;
  2239. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  2240. try {
  2241. //遍历层高
  2242. for (String h : heights) {
  2243. //获取湍流年逐时ebId
  2244. String ebId = equipmentAttributeList.stream().filter(w -> w.getFieldName().equals(h + "turDayForMonth")).collect(Collectors.toList()).get(0).getId();
  2245. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, endTime, equipmentId, ebId);
  2246. HashMap<Integer, BigDecimal> timeAndTurMap = new HashMap<>();
  2247. HashMap<Integer, BigDecimal> totalAndTurMap = new HashMap<>();
  2248. //循环开始时间到时间一小时为间隔
  2249. for (long time = startTime.getTime(); time <= endTime.getTime(); time = time + hour) {
  2250. long startHour = time;
  2251. long endHour = time + hour;
  2252. //筛选小时数据
  2253. // List<Map<String, Object>> collect = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startHour && Long.parseLong(w.get("time").toString()) <= endHour && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  2254. List<ProphaseAnemometryData> anemometryDataList = prophaseAnemometryDataList.stream().filter(p -> p.getTs().getTime() >= startHour && p.getTs().getTime() <= endHour && p.getLayerHeight().equals(h)).collect(Collectors.toList());
  2255. if (anemometryDataList.size() > 0) {
  2256. BigDecimal turAve = BigDecimal.ZERO;
  2257. //循环实时数据计算总风速和标差
  2258. BigDecimal wsSun = CalculationUtil.getBigDecimal(anemometryDataList.stream().filter(a -> a.getWsAve() != null).mapToDouble(ProphaseAnemometryData::getWsAve).sum());
  2259. BigDecimal staSun = CalculationUtil.getBigDecimal(anemometryDataList.stream().filter(a -> a.getWsSta() != null).mapToDouble(ProphaseAnemometryData::getWsSta).sum());
  2260. //除以一小时的个数 求小时的平均值
  2261. BigDecimal wsAve = wsSun.divide(BigDecimal.valueOf(anemometryDataList.size()), 2, RoundingMode.HALF_UP);
  2262. BigDecimal staAve = staSun.divide(BigDecimal.valueOf(anemometryDataList.size()), 2, RoundingMode.HALF_UP);
  2263. //如果除数等于0就跳过本次循环
  2264. if (wsAve.compareTo(BigDecimal.ZERO) == 0 || staAve.compareTo(BigDecimal.ZERO) == 0) {
  2265. continue;
  2266. }
  2267. turAve = staAve.divide(wsAve, 2, RoundingMode.HALF_UP);
  2268. //判断map中是否存在此小时的key 如果存在就把数值相加 个数加一
  2269. if (timeAndTurMap.get(new Date(startHour).getHours()) != null) {
  2270. BigDecimal Average = timeAndTurMap.get(new Date(startHour).getHours()).add(turAve);
  2271. BigDecimal total = totalAndTurMap.get(new Date(startHour).getHours()).add(BigDecimal.ONE);
  2272. timeAndTurMap.put(new Date(startHour).getHours(), Average);
  2273. totalAndTurMap.put(new Date(startHour).getHours(), total);
  2274. } else {
  2275. //如果map中不存在这个key则直接把平均值加入 个数加一
  2276. timeAndTurMap.put(new Date(startHour).getHours(), turAve);
  2277. totalAndTurMap.put(new Date(startHour).getHours(), BigDecimal.ONE);
  2278. }
  2279. }
  2280. }
  2281. if (!timeAndTurMap.entrySet().isEmpty()) {
  2282. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyyMMdd");
  2283. SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHH");
  2284. //设置数据时间为开始时间
  2285. String start = sdf1.format(new Date(startTime.getTime()));
  2286. for (Map.Entry<Integer, BigDecimal> a : timeAndTurMap.entrySet()) {
  2287. Date timeMonth = sdf.parse(start + String.valueOf(a.getKey()));
  2288. BigDecimal airAve = a.getValue().divide(totalAndTurMap.get(a.getKey()), 2, RoundingMode.HALF_UP);
  2289. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  2290. windTowerCalculationData.setEbId(ebId);
  2291. windTowerCalculationData.setTime(timeMonth);
  2292. windTowerCalculationData.setEquipmentId(equipmentId);
  2293. windTowerCalculationData.setValue(airAve);
  2294. list.add(windTowerCalculationData);
  2295. }
  2296. }
  2297. }
  2298. } catch (ParseException e) {
  2299. log.error("设备编号{},湍流年逐时计算错误", equipmentId);
  2300. e.printStackTrace();
  2301. }
  2302. // saveBatchByEquipmentId(list, equipmentId);
  2303. log.info("设备编号{},湍流年逐时,计算完成", equipmentId);
  2304. return list;
  2305. }
  2306. /**
  2307. * 空气密度月逐时入库
  2308. *
  2309. * @param equipmentId 设备id
  2310. * @param startTime 开始时间
  2311. * @param endTime 结束时间
  2312. * @return
  2313. */
  2314. public ArrayList<WindTowerCalculationData> airDensityMonth(String equipmentId, Date startTime, Date endTime, List<ProphaseWeatherData> prophaseWeatherDataList) {
  2315. //获取ebId
  2316. String ebId = equipmentAttributeService.lambdaQuery().eq(EquipmentAttribute::getFieldName, "airDensityDayForYear").list().get(0).getId();
  2317. removeByStartTimeBetweenAndEquipmentIdAndEbId(startTime, new Date(endTime.getTime() + 86400000L), equipmentId, ebId);
  2318. ArrayList<WindTowerCalculationData> list = new ArrayList<>();
  2319. long hour = 3600000L;
  2320. try {
  2321. HashMap<Integer, BigDecimal> timeAndAirMap = new HashMap<>();
  2322. HashMap<Integer, BigDecimal> totalAndAirMap = new HashMap<>();
  2323. for (long time = startTime.getTime(); time <= endTime.getTime(); time = time + hour) {
  2324. BigDecimal airSun = BigDecimal.ZERO;
  2325. long startHour = time;
  2326. long endHour = time + hour;
  2327. // List<Map<String, Object>> collect = mapList.stream().filter(w -> Long.parseLong(w.get("time").toString()) >= startHour && Long.parseLong(w.get("time").toString()) <= endHour && w.get("equipment_id").equals(equipmentId)).collect(Collectors.toList());
  2328. List<ProphaseWeatherData> weatherDataList = prophaseWeatherDataList.stream().filter(p -> p.getTs().getTime() >= startHour && p.getTs().getTime() <= endHour).collect(Collectors.toList());
  2329. for (ProphaseWeatherData map : weatherDataList) {
  2330. //过滤异常数据
  2331. airSun = airSun.add(CalculationUtil.getBigDecimal(map.getAirDensity()));
  2332. }
  2333. if (weatherDataList.size() > 0) {
  2334. BigDecimal airAve = airSun.divide(BigDecimal.valueOf(weatherDataList.size()), 2, RoundingMode.HALF_UP);
  2335. //判断map的key是否包含此小时 不包含直接加入value中 包含则相加
  2336. if (timeAndAirMap.get(new Date(startHour).getHours()) != null) {
  2337. BigDecimal Average = timeAndAirMap.get(new Date(startHour).getHours()).add(airAve);
  2338. BigDecimal total = totalAndAirMap.get(new Date(startHour).getHours()).add(BigDecimal.ONE);
  2339. timeAndAirMap.put(new Date(startHour).getHours(), Average);
  2340. totalAndAirMap.put(new Date(startHour).getHours(), total);
  2341. } else {
  2342. //如果map中不存在这个key则直接把平均值加入个数加一
  2343. timeAndAirMap.put(new Date(startHour).getHours(), airAve);
  2344. totalAndAirMap.put(new Date(startHour).getHours(), BigDecimal.ONE);
  2345. }
  2346. }
  2347. }
  2348. if (!timeAndAirMap.entrySet().isEmpty()) {
  2349. SimpleDateFormat sdf1 = new SimpleDateFormat("yyyyMMdd");
  2350. SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHH");
  2351. //设置数据时间为开始时间
  2352. String start = sdf1.format(new Date(startTime.getTime()));
  2353. for (Map.Entry<Integer, BigDecimal> a : timeAndAirMap.entrySet()) {
  2354. //拼接时间
  2355. Date time = sdf.parse(start + String.valueOf(a.getKey()));
  2356. BigDecimal airAve = a.getValue().divide(totalAndAirMap.get(a.getKey()), 2, RoundingMode.HALF_UP);
  2357. WindTowerCalculationData windTowerCalculationData = new WindTowerCalculationData();
  2358. windTowerCalculationData.setEbId(ebId);
  2359. windTowerCalculationData.setTime(time);
  2360. windTowerCalculationData.setEquipmentId(equipmentId);
  2361. windTowerCalculationData.setValue(airAve);
  2362. list.add(windTowerCalculationData);
  2363. }
  2364. }
  2365. } catch (Exception e) {
  2366. log.error("设备编号{},空气密度月逐时计算错误", equipmentId);
  2367. e.printStackTrace();
  2368. }
  2369. // saveBatchByEquipmentId(list, equipmentId);
  2370. log.info("设备编号{},空气密度月逐时,计算完成", equipmentId);
  2371. return list;
  2372. }
  2373. /**
  2374. * 根据时间范围 设备id 属性id删除
  2375. *
  2376. * @param equipmentId 设备id
  2377. * @param ebId 属性id
  2378. * @return List<WindTowerCalculationData>
  2379. */
  2380. public List<WindTowerCalculationData> findByEquipmentIdAndEbId(String equipmentId, String ebId) {
  2381. Map<String, Object> map = new HashMap<>();
  2382. map.put("equipment_id", equipmentId);
  2383. RequestDataHelper.setRequestData(map);
  2384. QueryWrapper<WindTowerCalculationData> wrapper = new QueryWrapper();
  2385. if (equipmentId != null && !equipmentId.equals("")) {
  2386. wrapper.eq("equipment_id", equipmentId);
  2387. }
  2388. if (ebId != null && !ebId.equals("")) {
  2389. wrapper.eq("eb_id", ebId);
  2390. }
  2391. return baseMapper.selectList(wrapper);
  2392. }
  2393. /**
  2394. * 根据时间范围和设备id查询数据
  2395. *
  2396. * @param equipmentId 设备属性id
  2397. * @return List<WindTowerCalculationData>
  2398. */
  2399. public List<WindTowerCalculationData> getByBetweenTimeAndEquipmentId(Date startTime, Date endTime, String equipmentId) {
  2400. Map<String, Object> map = new HashMap<>();
  2401. map.put("equipment_id", equipmentId);
  2402. RequestDataHelper.setRequestData(map);
  2403. QueryWrapper<WindTowerCalculationData> wrapper = new QueryWrapper();
  2404. if (startTime != null && endTime != null) {
  2405. wrapper.between("time", startTime, endTime);
  2406. }
  2407. if (equipmentId != null && !equipmentId.equals("")) {
  2408. wrapper.eq("equipment_id", equipmentId);
  2409. }
  2410. return baseMapper.selectList(wrapper);
  2411. }
  2412. public void saveByEquipmentId(WindTowerCalculationData windTowerCalculationData, String equipmentId) {
  2413. Map<String, Object> map = new HashMap<>();
  2414. map.put("equipment_id", equipmentId);
  2415. RequestDataHelper.setRequestData(map);
  2416. this.save(windTowerCalculationData);
  2417. }
  2418. public void saveBatchByEquipmentId(List<WindTowerCalculationData> windTowerCalculationDataList, String equipmentId) {
  2419. Map<String, Object> map = new HashMap<>();
  2420. map.put("equipment_id", equipmentId);
  2421. RequestDataHelper.setRequestData(map);
  2422. this.saveBatch(windTowerCalculationDataList);
  2423. }
  2424. /**
  2425. * 根据时间范围 设备id 属性id删除
  2426. *
  2427. * @param startTime 开始时间
  2428. * @param endTime 结束时间
  2429. * @param equipmentId 设备id
  2430. * @param ebId 属性id
  2431. */
  2432. public void removeByStartTimeBetweenAndEquipmentIdAndEbId(Date startTime, Date endTime, String equipmentId, String ebId) {
  2433. Map<String, Object> map = new HashMap<>();
  2434. map.put("equipment_id", equipmentId);
  2435. RequestDataHelper.setRequestData(map);
  2436. QueryWrapper<WindTowerCalculationData> wrapper = new QueryWrapper();
  2437. if (startTime != null && endTime != null) {
  2438. wrapper.between("time", startTime, endTime);
  2439. }
  2440. if (equipmentId != null && !equipmentId.equals("")) {
  2441. wrapper.eq("equipment_id", equipmentId);
  2442. }
  2443. if (ebId != null && !ebId.equals("")) {
  2444. wrapper.eq("eb_id", ebId);
  2445. }
  2446. remove(wrapper);
  2447. }
  2448. /**
  2449. * 根据时间范围 设备id 属性id查询
  2450. *
  2451. * @param startTime 开始时间
  2452. * @param endTime 结束时间
  2453. * @param equipmentId 设备id
  2454. * @param ebId 属性id
  2455. * @return List<WindTowerCalculationData>
  2456. */
  2457. public List<WindTowerCalculationData> getByStartTimeBetweenAndEquipmentIdAndEbId(Date startTime, Date endTime, String equipmentId, String ebId) {
  2458. Map<String, Object> map = new HashMap<>();
  2459. map.put("equipment_id", equipmentId);
  2460. RequestDataHelper.setRequestData(map);
  2461. QueryWrapper<WindTowerCalculationData> wrapper = new QueryWrapper();
  2462. if (startTime != null && endTime != null) {
  2463. wrapper.between("time", startTime, endTime);
  2464. }
  2465. if (equipmentId != null && !equipmentId.equals("")) {
  2466. wrapper.eq("equipment_id", equipmentId);
  2467. }
  2468. if (ebId != null && !ebId.equals("")) {
  2469. wrapper.eq("eb_id", ebId);
  2470. }
  2471. return baseMapper.selectList(wrapper);
  2472. }
  2473. /**
  2474. * 从 String 中提取数字
  2475. *
  2476. * @param string
  2477. * @return
  2478. */
  2479. public static String getNumberFromString(String string) {
  2480. String str = string;
  2481. str = str.trim();
  2482. StringBuffer str2 = new StringBuffer();
  2483. if (str != null && !"".equals(str)) {
  2484. for (int i = 0; i < str.length(); i++) {
  2485. if (str.charAt(i) >= 48 && str.charAt(i) <= 57) {
  2486. String s = String.valueOf(str.charAt(i));
  2487. str2.append(s);
  2488. }
  2489. }
  2490. }
  2491. return str2.toString();
  2492. }
  2493. /**
  2494. * 根据设备编号获取该设备的最后一条统计数据
  2495. *
  2496. * @param equipmentId 设备编号
  2497. * @return WindTowerCalculationData
  2498. */
  2499. public WindTowerCalculationData getLastDataCalculation(String equipmentId) {
  2500. return baseMapper.getLastData(equipmentId);
  2501. }
  2502. }