ycl-common/src/main/java/constant/ApiConstants.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-common/src/main/java/constant/CalculationStrategyConstants.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/calculate/IndexCalculationServe.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/calculate/VideoOnlineCalculation.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/calculate/VideoUsabilityCalculation.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/factory/IndexCalculationFactory.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/task/VideoTask.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
ycl-common/src/main/java/constant/ApiConstants.java
@@ -46,4 +46,8 @@ public final static Integer UY_OnlineSite_Online = 1; public final static Integer UY_OnlineSite_Unknown = 0; public final static Integer UY_OnlineSite_Offline = -1; //优云录像完整状态 public final static Integer UY_RecordStatus_Integrity = 1; public final static Integer UY_RecordStatus_Interval = 0; public final static Integer UY_RecordStatus_Abnormal = -1; } ycl-common/src/main/java/constant/CalculationStrategyConstants.java
@@ -56,4 +56,8 @@ * 视频点位在线率 */ public static final String Video_SiteOnline = "videoSiteOnline"; /** * 视频录像可用率 */ public static final String Video_Usability = "videoUsability"; } ycl-server/src/main/java/com/ycl/calculate/IndexCalculationServe.java
@@ -110,6 +110,13 @@ return picQualifySites.divide(totalSitesCount, 4, RoundingMode.HALF_UP); } //录像可用率 public BigDecimal videoUsability(Map<String, Object> param) { BigDecimal totalSites = new BigDecimal((Integer) param.get("totalSites")); BigDecimal usabilitySites = new BigDecimal((Integer) param.get("usabilitySites")); return usabilitySites.divide(totalSites, 4, RoundingMode.HALF_UP); } //返回省厅国标码集合 public List<String> getProvince() { // TODO: 分省厅市局 需要补充集合数据 ycl-server/src/main/java/com/ycl/calculate/VideoOnlineCalculation.java
@@ -115,8 +115,8 @@ * 视频点位在线率 */ private CheckIndexVideo createOrUpdateCheckIndexFace(String key, AreaStats stats, List<CheckIndexVideo> checkIndexVideoList) { CheckIndexVideo CheckIndexVideo = getCheckIndex(key, checkIndexVideoList, CheckIndexVideo.class); if (CheckIndexVideo == null) { CheckIndexVideo checkIndexVideo = getCheckIndex(key, checkIndexVideoList, CheckIndexVideo.class); if (checkIndexVideo == null) { return null; } //调用点位在线率计算方法 @@ -124,13 +124,13 @@ param.put("totalSites", stats.totalSites); param.put("onlineSites", stats.onlineSites); BigDecimal siteOnline = siteOnline(param); CheckIndexVideo.setSiteOnline(siteOnline); checkIndexVideo.setSiteOnline(siteOnline); //调用点位在线率计算方法 计算重点点位在线率 Map<String, Object> importantParam = new HashMap<>(); param.put("totalSites", stats.importantSites); param.put("onlineSites", stats.importantOnlineSites); BigDecimal importantSiteOnline = siteOnline(importantParam); CheckIndexVideo.setKeySiteOnline(importantSiteOnline); return CheckIndexVideo; checkIndexVideo.setKeySiteOnline(importantSiteOnline); return checkIndexVideo; } } ycl-server/src/main/java/com/ycl/calculate/VideoUsabilityCalculation.java
New file @@ -0,0 +1,135 @@ package com.ycl.calculate; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.CheckIndexVideo; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.param.UY.RecordMetaDSumParam; import com.ycl.platform.domain.result.UY.QueryVqdResult; import com.ycl.platform.mapper.CheckIndexVideoMapper; import com.ycl.platform.service.ICheckIndexVideoService; import com.ycl.platform.service.ITMonitorService; import constant.ApiConstants; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils; import utils.DateUtils; import java.math.BigDecimal; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.function.Function; import java.util.stream.Collectors; /** * 计算视频设备录像可用率 * 录像可用率接口 * 获取分省厅、区域的map<k,v> k为deptId或者Province_deptId * 循环map计算数据上传及时性 * 更新或新增 */ @Component public class VideoUsabilityCalculation extends IndexCalculationServe implements CalculationStrategy<RecordMetaDSumParam> { @Autowired private CheckIndexVideoMapper checkIndexVideoMapper; @Autowired private ITMonitorService monitorService; @Autowired private ICheckIndexVideoService checkIndexVideoService; //区域视频在线率的内部类 private static class AreaStats { int totalSites = 0; int usabilitySites = 0; int importantSites = 0; int importantUsabilitySites = 0; } @Override public void calculate(List<RecordMetaDSumParam> list) { if (CollectionUtils.isEmpty(list)) { return; } //获得国标码为key的设备map Map<String, TMonitor> monitorMap = monitorService.list(new QueryWrapper<TMonitor>() .in("serial_number", list.stream().map(RecordMetaDSumParam::getDeviceId).collect(Collectors.toList()))) .stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); //获取省厅国标码集合 List<String> provinceIds = getProvince(); //重点点位集合 List<String> important = getImportant(); Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (RecordMetaDSumParam result : list) { TMonitor monitor = monitorMap.get(result.getDeviceId()); if (monitor == null) continue; String deptId = monitor.getDeptId().toString(); updateAreaStats(areaStatsMap, deptId, result, important); // 处理省厅数据 if (!CollectionUtils.isEmpty(provinceIds) && provinceIds.contains(monitor.getSerialNumber())) { String provinceKey = "Province_" + deptId; updateAreaStats(areaStatsMap, provinceKey, result, important); } } // 查询是否index表已经存在今日数据 List<CheckIndexVideo> checkIndexVideoList = checkIndexVideoMapper.selectToday(DateUtils.getDate()); List<CheckIndexVideo> checkIndexVideos = new ArrayList<>(); areaStatsMap.forEach((deptId, stats) -> { if (stats.totalSites > 0) { CheckIndexVideo CheckIndexVideo = createOrUpdateCheckIndexFace(deptId, stats, checkIndexVideoList); if (CheckIndexVideo != null) { checkIndexVideos.add(CheckIndexVideo); } } }); checkIndexVideoService.saveOrUpdateBatch(checkIndexVideos); } /** * 累计总点位数、在线点位数、重点点位数、重点点位在线数 */ private void updateAreaStats(Map<String, AreaStats> areaStatsMap, String key, RecordMetaDSumParam result, List<String> important) { //返回对象的引用,如果不存在会放入新的key,value AreaStats stats = areaStatsMap.computeIfAbsent(key, k -> new AreaStats()); stats.totalSites++; boolean flag = important.contains(result.getDeviceId()); if(flag){ stats.importantSites++; } if (ApiConstants.UY_RecordStatus_Integrity.equals(result.getRecordStatus())){ stats.usabilitySites++; if(flag){ stats.importantUsabilitySites++; } } } /** * 视频点位在线率 */ private CheckIndexVideo createOrUpdateCheckIndexFace(String key, AreaStats stats, List<CheckIndexVideo> checkIndexVideoList) { CheckIndexVideo checkIndexVideo = getCheckIndex(key, checkIndexVideoList, CheckIndexVideo.class); if (checkIndexVideo == null) { return null; } //调用录像可用计算方法 Map<String, Object> param = new HashMap<>(); param.put("totalSites", stats.totalSites); param.put("usabilitySites", stats.usabilitySites); BigDecimal videoUsability = videoUsability(param); checkIndexVideo.setVideoAvailable(videoUsability); //调用录像可用率计算方法 计算重点点位录像可用率 Map<String, Object> importantParam = new HashMap<>(); param.put("totalSites", stats.importantSites); param.put("usabilitySites", stats.importantUsabilitySites); BigDecimal importantVideoUsability = videoUsability(importantParam); checkIndexVideo.setKeyVideoAvailable(importantVideoUsability); return checkIndexVideo; } } ycl-server/src/main/java/com/ycl/factory/IndexCalculationFactory.java
@@ -38,6 +38,8 @@ //视频点位在线率 calculators.put(CalculationStrategyConstants.Video_SiteOnline, new VideoOnlineCalculation()); //视频录像可用率 calculators.put(CalculationStrategyConstants.Video_Usability, new VideoUsabilityCalculation()); } ycl-server/src/main/java/com/ycl/task/VideoTask.java
@@ -3,6 +3,7 @@ import com.ycl.calculate.CalculationStrategy; import com.ycl.factory.IndexCalculationFactory; import com.ycl.platform.domain.param.UY.RecordMetaDSumParam; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.platform.domain.result.UY.QueryVqdResult; import com.ycl.utils.DateUtils; @@ -39,4 +40,21 @@ CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_SiteOnline); calculator.calculate(results); } public void videoUsabilityTask(){ Date yesterday = DateUtils.addDays(new Date(), -1); //计算录像可用率和重点录像可用率 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); List<RecordMetaDSumParam> results = mongoTemplate.find(query, RecordMetaDSumParam.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); calculator.calculate(results); } public void oneMonitorFileTask(){ //计算一机一档注册率、一机一档合格率、档案考核比 } public void platformOnlineTask(){ //计算平台在线率 } }