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/MonitorRegistrationCalculation.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/calculate/VideoOnlineCalculation.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/factory/IndexCalculationFactory.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/task/MonitorTask.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
ycl-server/src/main/java/com/ycl/task/VideoTask.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
ycl-common/src/main/java/constant/CalculationStrategyConstants.java
@@ -53,6 +53,10 @@ /** * 一机一档注册率、档案考核比 */ public static final String Video_MonitorRegis_ArchiveRate = "videoMonitorRegisArchiveRate"; /** * 一机一档合格率 */ public static final String Video_MonitorQualify = "videoMonitorQualify"; ycl-server/src/main/java/com/ycl/calculate/IndexCalculationServe.java
@@ -2,18 +2,27 @@ import com.ycl.platform.base.CheckIndex; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.entity.YwPoint; import com.ycl.platform.domain.result.UY.MonitorQualifyResult; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.mapper.YwPointMapper; import com.ycl.utils.DateUtils; import constant.ApiConstants; import constant.CheckConstants; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.*; import java.util.function.Function; import java.util.stream.Collectors; /** @@ -25,13 +34,32 @@ @Autowired private YwPointMapper pointMapper; @Autowired private TMonitorMapper monitorMapper; @Autowired private MongoTemplate mongoTemplate; //一机一档合格率 public BigDecimal monitorQualify(Map<String, Object> param) { BigDecimal totalMonitors = new BigDecimal((Integer) param.get("totalMonitors")); BigDecimal qualifyMonitor = new BigDecimal((Integer) param.get("qualifyMonitor")); return qualifyMonitor.divide(totalMonitors, 4, RoundingMode.HALF_UP); } //一机一档注册率率 public BigDecimal monitorRegistration(Map<String, Object> param) { //新+正在用的档案数 BigDecimal totalSites = new BigDecimal((Integer) param.get("totalSites")); //正在用的档案数 BigDecimal useSites = new BigDecimal((Integer) param.get("totalSites") - (Integer) param.get("newSites")); return useSites.divide(totalSites, 4, RoundingMode.HALF_UP); } //档案考核比 public BigDecimal archivesRate(Map<String, Object> param) { BigDecimal allFiles = new BigDecimal((Integer) param.get("allFiles")); BigDecimal todayFiles = new BigDecimal((Integer) param.get("todayFiles")); return todayFiles.divide(allFiles, 4, RoundingMode.HALF_UP); } //点位在线率 public BigDecimal siteOnline(Map<String, Object> param) { BigDecimal totalSites = new BigDecimal((Integer) param.get("totalSites")); @@ -140,7 +168,24 @@ List<YwPoint> commandImages = pointMapper.selectByTag(null, null, Boolean.TRUE); return CollectionUtils.isEmpty(commandImages) ? new ArrayList<>() : commandImages.stream().map(YwPoint::getSerialNumber).collect(Collectors.toList()); } //返回重点指挥图像集合 public List<String> getMonitorFromMongo() { // 获取Calendar实例,默认使用当前时区和语言环境 Calendar calendar = Calendar.getInstance(); // 清除Calendar中的所有字段值,以避免它们对当前日期时间有影响 calendar.clear(); // 设置年份、月份(注意:月份是从0开始的,所以8月是7)、日期 calendar.set(Calendar.YEAR, 2024); calendar.set(Calendar.MONTH, Calendar.AUGUST); calendar.set(Calendar.DAY_OF_MONTH, 13); // Calendar.getTime()方法返回一个表示此Calendar时间值的Date对象 Date date = calendar.getTime(); Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(date)).lt(DateUtils.getDayEnd(date))); // Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); List<MonitorQualifyResult> oneMachineFileResults = mongoTemplate.find(query, MonitorQualifyResult.class); return CollectionUtils.isEmpty(oneMachineFileResults) ? new ArrayList<>() : oneMachineFileResults.stream().map(result -> result.getSerialNumber().getValue()).collect(Collectors.toList()); } //检查是否存在当日数据 public <T extends CheckIndex> T getCheckIndex(String key, List<T> checkIndexList, Class<T> clazz) { T checkIndex; ycl-server/src/main/java/com/ycl/calculate/MonitorRegistrationCalculation.java
New file @@ -0,0 +1,141 @@ package com.ycl.calculate; import com.alibaba.fastjson2.JSONArray; import com.ycl.platform.domain.entity.CheckIndexVideo; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.entity.YwPoint; import com.ycl.platform.domain.result.UY.VideoOnlineResult; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.mapper.CheckIndexVideoMapper; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.service.ICheckIndexVideoService; import constant.ApiConstants; import constant.RedisConstant; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils; import utils.DateUtils; import utils.StringUtils; import java.math.BigDecimal; import java.util.*; import java.util.function.Function; import java.util.stream.Collectors; /** * 计算一机一档注册率、档案考核比 * 获取分省厅、区域的map<k,v> k为deptId或者Province_deptId * 更新或新增 */ @Component public class MonitorRegistrationCalculation extends IndexCalculationServe implements CalculationStrategy<TMonitorVO> { @Autowired private CheckIndexVideoMapper checkIndexVideoMapper; @Autowired private TMonitorMapper monitorMapper; @Autowired private ICheckIndexVideoService checkIndexVideoService; @Autowired private RedisTemplate redisTemplate; //区域视频在线率的内部类 private static class AreaStats { //资产库登记在用数 int totalSites = 0; //未注册的数量 int newSites = 0; //全年留存数 int allFiles = 0; //当日档案数 int todayFiles = 0; } @Override public void calculate(List<TMonitorVO> list) { if (CollectionUtils.isEmpty(list)) { return; } //获得国标码为key的设备map Map<String, TMonitorVO> monitorMap = new HashMap<>(); if(!CollectionUtils.isEmpty(list)){ monitorMap = list.stream().collect(Collectors.toMap(TMonitorVO::getSerialNumber, Function.identity())); } //未注册设备 Map<String,TMonitor> newMonitorMap = new HashMap<>(); //Mongo一机一档同步Mysql时放入Redis String json = (String) redisTemplate.opsForValue().get(RedisConstant.New_Monitor_Set); if (!StringUtils.isEmpty(json)) { List<TMonitor> newMonitors = JSONArray.parseArray(json, TMonitor.class); if(!CollectionUtils.isEmpty(newMonitors)){ newMonitorMap = newMonitors.stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); } } //获取昨日mongo一机一档数量 List<String> todayMonitor = getMonitorFromMongo(); Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (TMonitorVO result : list) { TMonitorVO monitor = monitorMap.get(result.getSerialNumber()); if (monitor == null) continue; String deptId = monitor.getDeptId().toString(); updateAreaStats(areaStatsMap, deptId, result,newMonitorMap,todayMonitor); } // 查询是否index表已经存在今日数据 List<CheckIndexVideo> checkIndexVideoList = checkIndexVideoMapper.selectToday(DateUtils.getDate()); List<CheckIndexVideo> checkIndexVideos = new ArrayList<>(); areaStatsMap.forEach((deptId, stats) -> { if (stats.totalSites > 0) { CheckIndexVideo CheckIndexVideo = createOrUpdateCheckIndexVideo(deptId, stats, checkIndexVideoList); if (CheckIndexVideo != null) { checkIndexVideos.add(CheckIndexVideo); } } }); checkIndexVideoService.saveOrUpdateBatch(checkIndexVideos); } /** * 累计总点位数、在线点位数、重点点位数、重点点位在线数、指挥图像数、指挥图像在线数 */ private void updateAreaStats(Map<String, AreaStats> areaStatsMap, String key, TMonitorVO result,Map<String,TMonitor> newMonitors,List<String> todayMonitor) { //返回对象的引用,如果不存在会放入新的key,value AreaStats stats = areaStatsMap.computeIfAbsent(key, k -> new AreaStats()); stats.totalSites++; stats.allFiles++; if(newMonitors.containsKey(result.getSerialNumber())){ stats.newSites++; } if(todayMonitor.contains(result.getSerialNumber())){ stats.todayFiles++; } } /** * 视频点位在线率 */ private CheckIndexVideo createOrUpdateCheckIndexVideo(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("newSites", stats.newSites); BigDecimal monitorRegistration = monitorRegistration(param); checkIndexVideo.setMonitorRegistration(monitorRegistration); //调用档案考核比计算 Map<String, Object> importantParam = new HashMap<>(); param.put("allFiles", stats.allFiles); param.put("todayFiles", stats.todayFiles); BigDecimal archivesRate = archivesRate(importantParam); checkIndexVideo.setArchivesRate(archivesRate); return checkIndexVideo; } } ycl-server/src/main/java/com/ycl/calculate/VideoOnlineCalculation.java
@@ -88,7 +88,7 @@ List<CheckIndexVideo> checkIndexVideos = new ArrayList<>(); areaStatsMap.forEach((deptId, stats) -> { if (stats.totalSites > 0) { CheckIndexVideo CheckIndexVideo = createOrUpdateCheckIndexFace(deptId, stats, checkIndexVideoList); CheckIndexVideo CheckIndexVideo = createOrUpdateCheckIndexVideo(deptId, stats, checkIndexVideoList); if (CheckIndexVideo != null) { checkIndexVideos.add(CheckIndexVideo); } @@ -127,7 +127,7 @@ /** * 视频点位在线率 */ private CheckIndexVideo createOrUpdateCheckIndexFace(String key, AreaStats stats, List<CheckIndexVideo> checkIndexVideoList) { private CheckIndexVideo createOrUpdateCheckIndexVideo(String key, AreaStats stats, List<CheckIndexVideo> checkIndexVideoList) { CheckIndexVideo checkIndexVideo = getCheckIndex(key, checkIndexVideoList, CheckIndexVideo.class); if (checkIndexVideo == null) { return null; ycl-server/src/main/java/com/ycl/factory/IndexCalculationFactory.java
@@ -37,6 +37,8 @@ calculators.put(CalculationStrategyConstants.Face_ClockAccuracy, new FaceClockAccuracyCalculation()); //TODO:人脸目录一致 //一机一档注册率、档案考核比 calculators.put(CalculationStrategyConstants.Video_MonitorRegis_ArchiveRate,new MonitorRegistrationCalculation()) //一机一档合格率 calculators.put(CalculationStrategyConstants.Video_MonitorQualify, new MonitorQualifyCalculation()); //视频点位在线率 ycl-server/src/main/java/com/ycl/task/MonitorTask.java
@@ -55,7 +55,18 @@ //同步mongodb一机一档到数据库 @Transactional public void synchronize() { Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); // 获取Calendar实例,默认使用当前时区和语言环境 Calendar calendar = Calendar.getInstance(); // 清除Calendar中的所有字段值,以避免它们对当前日期时间有影响 calendar.clear(); // 设置年份、月份(注意:月份是从0开始的,所以8月是7)、日期 calendar.set(Calendar.YEAR, 2024); calendar.set(Calendar.MONTH, Calendar.AUGUST); calendar.set(Calendar.DAY_OF_MONTH, 13); // Calendar.getTime()方法返回一个表示此Calendar时间值的Date对象 Date date = calendar.getTime(); Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(date)).lt(DateUtils.getDayEnd(date))); // Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); List<MonitorQualifyResult> oneMachineFileResults = mongoTemplate.find(query, MonitorQualifyResult.class); //数据库monitor表数据 Map<String, TMonitorVO> monitorVOMap = monitorMapper.selectMonitorVOList().stream().collect(Collectors.toMap(TMonitorVO::getSerialNumber, Function.identity())); @@ -73,7 +84,7 @@ List<SysDictData> DictDataList = dictDataService.selectDictDataList(sysDictData); List<String> importantSite = DictDataList.stream().map(SysDictData::getDictValue).collect(Collectors.toList()); //TODO:全年留存还是单次留存 //全年留存 for (MonitorQualifyResult result : oneMachineFileResults) { TMonitor monitor = getMonitor(result, monitorVOMap); YwPoint point = getPoint(result, pointMap, importantSite); ycl-server/src/main/java/com/ycl/task/VideoTask.java
@@ -10,8 +10,10 @@ import com.ycl.platform.domain.result.UY.QueryVqdResult; import com.ycl.platform.domain.result.UY.VideoOnlineResult; import com.ycl.platform.domain.vo.PlatformOnlineVO; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.mapper.CheckIndexVideoMapper; import com.ycl.platform.mapper.PlatformOnlineMapper; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.service.PlatformOnlineService; import com.ycl.system.mapper.SysDeptMapper; import com.ycl.utils.DateUtils; @@ -43,7 +45,8 @@ private MongoTemplate mongoTemplate; @Autowired private PlatformOnlineMapper platformOnlineMapper; @Autowired private TMonitorMapper monitorMapper; public void siteOnlineTask() { Date yesterday = DateUtils.addDays(new Date(), -1); @@ -71,7 +74,9 @@ public void oneMonitorFileTask() { //计算一机一档注册率、档案考核比 List<TMonitorVO> tMonitorVOS = monitorMapper.selectMonitorVOList(); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); calculator.calculate(tMonitorVOS); } public void oneMonitorQualifyTask(){