package com.ycl.task; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.calculate.CalculationStrategy; import com.ycl.factory.IndexCalculationFactory; import com.ycl.platform.domain.entity.YwPoint; import com.ycl.platform.domain.form.VideoExportForm; import com.ycl.platform.domain.result.HK.*; import com.ycl.platform.domain.result.SYS.TMonitorResult; 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 com.ycl.utils.StringUtils; import constant.ApiConstants; import constant.CalculationStrategyConstants; 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 java.util.Date; import java.util.List; import java.util.regex.Pattern; import java.util.stream.Collectors; /** * 车辆计算考核指标任务 * 凌晨执行计算昨天数据 */ @Slf4j @Component("carTask") public class CarTask { @Autowired private MongoTemplate mongoTemplate; @Autowired private TMonitorMapper monitorMapper; @Autowired private YwPointMapper pointMapper; public void siteOnlineTask() { log.info("开始计算点位在线率"); Date yesterday = DateUtils.addDays(new Date(), -1); //计算点位在线率 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)) .and("dataType").is(ApiConstants.HK_DataType_CAR)); List results = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_SiteOnline); calculator.calculate(results); log.info("结束计算点位在线率"); } public void viewConnectTask() { log.info("开始计算视图库对接稳定性"); Date yesterday = DateUtils.addDays(new Date(), -1); //计算视图库对接稳定性 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)) .and("dataType").is(ApiConstants.HK_DataType_CAR)); List results = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_ViewStability); calculator.calculate(results); log.info("结束计算视图库对接稳定性"); } public void deviceSampleTask() { log.info("开始计算车辆卡口设备数据识别准确性、url可用性、大图可用性"); Date yesterday = DateUtils.addDays(new Date(), -1); //计算车辆卡口设备数据识别准确性、url可用性、大图可用性 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); List results = mongoTemplate.find(query, VehicleDeviceSamplingResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_DataAccuracy_PicUsability); calculator.calculate(results); log.info("结束计算车辆卡口设备数据识别准确性、url可用性、大图可用性"); } public void carUrlTask() { log.info("开始计算车辆url可用性"); Date yesterday = DateUtils.addDays(new Date(), -1); //计算车辆卡口设备数据识别准确性、url可用性、大图可用性 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); List results = mongoTemplate.find(query, PicAccessResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_Url); calculator.calculate(results); log.info("结束计算url可用性"); } public void infoAccuracyTask() { log.info("开始计算车辆卡口信息采集准确率"); 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 results = mongoTemplate.find(query, CrossDetailResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_InfoAccuracy); calculator.calculate(results); log.info("结束计算车辆卡口信息采集准确率"); } public void snapShopDelayTask() { log.info("开始计算车辆抓拍数据上传及时性"); Date yesterday = DateUtils.addDays(new Date(), -1); //计算车辆抓拍数据上传及时性 Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)) .and("dataType").is(ApiConstants.HK_DataType_CAR)); List results = mongoTemplate.find(query, SnapshotDelayMonitorResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_SnapshotDelay); calculator.calculate(results); log.info("结束计算车辆抓拍数据上传及时性"); } public void snapShopDataIntegrity() { log.info("开始计算车辆数据抓拍完整性"); 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 results = mongoTemplate.find(query, DataIntegrityMonitoringResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_DataIntegrity); calculator.calculate(results); log.info("结束计算车辆数据抓拍完整性"); } public void clockAccuracyTask() { log.info("开始计算车辆卡口设备时钟准确性"); 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 results = mongoTemplate.find(query, VehicleDeviceInspectionResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_ClockAccuracy); calculator.calculate(results); log.info("结束计算车辆卡口设备时钟准确性"); } public void directConsistentTask() { log.info("开始计算车辆目录一致率"); //车辆目录一致率 Date yesterday = DateUtils.addDays(new Date(), -1); Query query = new Query(); query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday))); // 1/2/3 视频/车辆/人脸 Pattern pattern = Pattern.compile(".*2.*"); query.addCriteria(Criteria.where("sxjgnlx.value").regex(pattern)); List results = mongoTemplate.find(query, MonitorQualifyResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Car_DirectConsistent); calculator.calculate(results); log.info("结束计算车辆目录一致率"); } }