| | |
| | | import constant.CheckConstants; |
| | | import lombok.RequiredArgsConstructor; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.collections4.CollectionUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.data.mongodb.core.MongoTemplate; |
| | | import org.springframework.data.mongodb.core.query.Criteria; |
| | |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.Objects; |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | | * 视频计算考核指标任务 |
| | |
| | | query.addCriteria(Criteria |
| | | .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); |
| | | List<VideoOnlineResult> results = mongoTemplate.find(query, VideoOnlineResult.class); |
| | | //优云上有车辆和人脸的设备数据,需要过滤出视频设备 |
| | | List<String> videoIds = monitorMapper.getVideoIds(); |
| | | if(!CollectionUtils.isEmpty(results)){ |
| | | results = results.stream().filter(result -> videoIds.contains(result.getNo())).collect(Collectors.toList()); |
| | | } |
| | | CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_SiteOnline); |
| | | calculator.calculate(results); |
| | | log.info("结束计算点位在线率"); |
| | |
| | | .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); |
| | | |
| | | List<RecordMetaDSumResult> results = mongoTemplate.find(query, RecordMetaDSumResult.class); |
| | | //优云上有车辆和人脸的设备数据,需要过滤出视频设备 |
| | | List<String> videoIds = monitorMapper.getVideoIds(); |
| | | if(!CollectionUtils.isEmpty(results)){ |
| | | results = results.stream().filter(result -> videoIds.contains(result.getNo())).collect(Collectors.toList()); |
| | | } |
| | | CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_Usability); |
| | | calculator.calculate(results); |
| | | log.info("结束计算录像可用率和重点录像可用率"); |
| | |
| | | query.addCriteria(Criteria |
| | | .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); |
| | | List<OsdCheckResult> results = mongoTemplate.find(query, OsdCheckResult.class); |
| | | |
| | | CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Video_OsdTime); |
| | | calculator.calculate(results); |
| | | log.info("结束计算Osd标注、时间准确率"); |