ycl-common/src/main/java/constant/ApiConstants.java
@@ -16,13 +16,31 @@ //抓拍数据量监测结果 正常 public final static Integer HK_SnapCount_ResultType_Normal = 1; //抓拍数据量监测结果 无数据 public final static Integer HK_SnapCount_ResultType_Null = 2; //抓拍数据量监测结果 数据突降 public final static Integer HK_SnapCount_ResultType_Descent = 3; //请求参数dataType 数据量少 public final static Integer HK_DATATYPE_ResultType_Low = 4; //经纬度检测结果 正常 public final static Integer HK_Info_LayType_Normal = 1; //经纬度检测结果 经纬度缺失 public final static Integer HK_Info_LayType_Absent = 2; //经纬度检测结果 不在辖区 public final static Integer HK_Info_LayType_NotIn = 3; //经纬度检测结果 精度低 public final static Integer HK_Info_LayType_Low = 4; //国际编码监测结果 正常 public final static Integer HK_Info_GbCodeType_Normal = 1; //国际编码监测结果 编码长度不等于20位 public final static Integer HK_Info_GbCodeType_NotEq = 2; //国际编码监测结果 前6位不合标准 public final static Integer HK_Info_GbCodeType_6NotStandard = 3; //国际编码监测结果 11-13位不合标准 public final static Integer HK_Info_GbCodeType_11NotStandard = 4; } ycl-common/src/main/java/constant/CalculationStrategyConstants.java
@@ -13,4 +13,12 @@ * 人脸点位在线率和视图库对接稳定性 */ public static final String Face_SiteOnline_ViewStability = "faceSiteOnlineViewStability"; /** * 车辆卡口属性监测结果 */ public static final String CAR_InfoAccuracy = "carInfoAccuracy"; /** * 人脸属性监测结果 */ public static final String Face_InfoAccuracy = "faceInfoAccuracy"; } ycl-server/src/main/java/com/ycl/calculate/CarInFoAccuracyCalculation.java
New file @@ -0,0 +1,136 @@ package com.ycl.calculate; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.CheckIndexCar; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.result.HK.CrossDetailResult; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.platform.mapper.CheckIndexCarMapper; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.service.ICheckIndexCarService; import com.ycl.platform.service.ITMonitorService; import com.ycl.system.mapper.SysConfigMapper; import constant.ApiConstants; import constant.CheckConstants; import constant.CheckSnapCountConstants; 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.math.RoundingMode; import java.time.LocalDate; import java.util.*; import java.util.function.Function; import java.util.stream.Collectors; /** * 计算车辆卡口信息采集准确率 设备编码、行政区划代码、安装位置、坐标经纬度信息完整准确 * 获取分省厅、区域的map<k,v> k为deptId或者Province_deptId * 更新或新增 */ @Component public class CarInFoAccuracyCalculation extends IndexCalculationServe implements CalculationStrategy<CrossDetailResult> { @Autowired private CheckIndexCarMapper checkIndexCarMapper; @Autowired private SysConfigMapper sysConfigMapper; @Autowired private ITMonitorService monitorService; @Autowired private TMonitorMapper monitorMapper; @Autowired private ICheckIndexCarService checkIndexCarService; //区域车辆信息采集准确率的内部类 private static class AreaStats { int totalSites = 0; int qualifySite = 0; } @Override public void calculate(List<CrossDetailResult> list) { if (CollectionUtils.isEmpty(list)) { return; } //返回以国标码为key的设备map //TODO:monitor去掉了deptId Map<String, TMonitor> monitorMap = monitorService.list(new QueryWrapper<TMonitor>() .in("serial_number", list.stream().map(CrossDetailResult::getExternalIndexCode).collect(Collectors.toList()))) .stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); //获取省厅国标码集合 List<String> provinceIds = getProvince(); Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (CrossDetailResult result : list) { TMonitor monitor = monitorMap.get(result.getExternalIndexCode()); if (monitor == null) continue; String deptId = monitor.getDeptId().toString(); updateAreaStats(areaStatsMap, deptId, result); // 处理省厅数据 if (!CollectionUtils.isEmpty(provinceIds) && provinceIds.contains(monitor.getSerialNumber())) { String provinceKey = "Province_" + deptId; updateAreaStats(areaStatsMap, provinceKey, result); } } // 查询是否index表已经存在今日数据 List<CheckIndexCar> checkIndexCarList = checkIndexCarMapper.selectToday(DateUtils.getDate()); List<CheckIndexCar> checkIndexCars = new ArrayList<>(); areaStatsMap.forEach((deptId, stats) -> { if (stats.totalSites > 0) { CheckIndexCar checkIndexCar = createOrUpdateCheckIndexCar(deptId, stats, checkIndexCarList); checkIndexCars.add(checkIndexCar); } }); checkIndexCarService.saveOrUpdateBatch(checkIndexCars); } /** * 累计总点位数、标注异常点位数 */ private void updateAreaStats(Map<String, AreaStats> areaStatsMap, String key, CrossDetailResult result) { //返回对象的引用,如果不存在会放入新的key,value AreaStats stats = areaStatsMap.computeIfAbsent(key, k -> new AreaStats()); stats.totalSites++; if (ApiConstants.HK_Info_LayType_Normal.equals(result.getLalType()) && ApiConstants.HK_Info_GbCodeType_Normal.equals(result.getGbCodeType())) { stats.qualifySite++; } } /** * 车辆信息采集正确率 */ private CheckIndexCar createOrUpdateCheckIndexCar(String key, AreaStats stats, List<CheckIndexCar> checkIndexCarList) { CheckIndexCar checkIndexCar; // 检查是否已存在今日数据 Optional<CheckIndexCar> existingCar = checkIndexCarList.stream() .filter(car -> key.equals(car.getDeptId().toString()) && (key.startsWith("Province_") ? CheckConstants.Examine_Tag_City.equals(car.getExamineTag()) : CheckConstants.Examine_Tag_County.equals(car.getExamineTag()))) .findFirst(); if (existingCar.isPresent()) { checkIndexCar = existingCar.get(); } else { checkIndexCar = new CheckIndexCar(); checkIndexCar.setDeptId(key.startsWith("Province_") ? Long.parseLong(key.split("_")[1]) : Long.parseLong(key)); checkIndexCar.setExamineTag(key.startsWith("Province_") ? CheckConstants.Examine_Tag_City : CheckConstants.Examine_Tag_County); checkIndexCar.setCreateTime(new Date()); } //调用计算方法 Map<String, Object> siteOnlineParam = new HashMap<>(); siteOnlineParam.put("totalSites", stats.totalSites); siteOnlineParam.put("qualifySite", stats.qualifySite); BigDecimal infoAccuracy = InfoAccuracy(siteOnlineParam); checkIndexCar.setVehicleInformationCollectionAccuracy(infoAccuracy); return checkIndexCar; } } ycl-server/src/main/java/com/ycl/calculate/CarSiteOnlineCalculation.java
@@ -30,7 +30,7 @@ * 更新或新增 */ @Component public class CarSiteOnlineCalculation implements CalculationStrategy<SnapshotDataMonitorResult> { public class CarSiteOnlineCalculation extends IndexCalculationServe implements CalculationStrategy<SnapshotDataMonitorResult> { @Autowired private CheckIndexCarMapper checkIndexCarMapper; @Autowired @@ -52,14 +52,15 @@ if (CollectionUtils.isEmpty(list)) { return; } Map<String, AreaStats> areaStatsMap = new HashMap<>(); //获得国标码为key的设备map Map<String, TMonitor> monitorMap = monitorService.list(new QueryWrapper<TMonitor>() .in("serial_number", list.stream().map(SnapshotDataMonitorResult::getExternalIndexCode).collect(Collectors.toList()))) .stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); //获取省厅国标码集合 List<String> provinceIds = getProvince(); // TODO: 分省厅市局 需要补充集合数据 List<String> provinceIds = new ArrayList<>(); // 这里需要根据点位补充 Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (SnapshotDataMonitorResult result : list) { TMonitor monitor = monitorMap.get(result.getExternalIndexCode()); if (monitor == null) continue; @@ -135,14 +136,14 @@ Map<String, Object> siteOnlineParam = new HashMap<>(); siteOnlineParam.put("totalSites", stats.totalSites); siteOnlineParam.put("offlineSites", stats.offlineSites); BigDecimal siteOnline = IndexCalculationUtils.siteOnline(siteOnlineParam); BigDecimal siteOnline = siteOnline(siteOnlineParam); checkIndexCar.setSiteOnline(siteOnline); //视图库对接稳定性 BigDecimal avgCount = key.startsWith("Province_") ? cityCountAvg : countyCountAvg; Map<String, Object> viewConnectParam = new HashMap<>(); viewConnectParam.put("totalDataSum", stats.totalDataSum); viewConnectParam.put("avgCount", avgCount); BigDecimal viewConnectStability = IndexCalculationUtils.viewConnectStability(viewConnectParam); BigDecimal viewConnectStability = viewConnectStability(viewConnectParam); checkIndexCar.setViewConnectStability(viewConnectStability); return checkIndexCar; } ycl-server/src/main/java/com/ycl/calculate/FaceInFoAccuracyCalculation.java
New file @@ -0,0 +1,132 @@ package com.ycl.calculate; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.CheckIndexFace; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.result.HK.MonitoringDetailResult; import com.ycl.platform.mapper.CheckIndexFaceMapper; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.service.ICheckIndexFaceService; import com.ycl.platform.service.ITMonitorService; import com.ycl.system.mapper.SysConfigMapper; import constant.ApiConstants; import constant.CheckConstants; 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.*; import java.util.function.Function; import java.util.stream.Collectors; /** * 人脸卡口信息采集准确率 设备编码、行政区划代码、安装位置、坐标经纬度信息完整准确 * 获取分省厅、区域的map<k,v> k为deptId或者Province_deptId * 更新或新增 */ @Component public class FaceInFoAccuracyCalculation extends IndexCalculationServe implements CalculationStrategy<MonitoringDetailResult> { @Autowired private CheckIndexFaceMapper checkIndexFaceMapper; @Autowired private ICheckIndexFaceService checkIndexFaceService; @Autowired private SysConfigMapper sysConfigMapper; @Autowired private ITMonitorService monitorService; @Autowired private TMonitorMapper monitorMapper; //区域车辆信息采集准确率的内部类 private static class AreaStats { int totalSites = 0; int qualifySite = 0; } @Override public void calculate(List<MonitoringDetailResult> list) { if (CollectionUtils.isEmpty(list)) { return; } //返回以国标码为key的设备map //TODO:monitor去掉了deptId Map<String, TMonitor> monitorMap = monitorService.list(new QueryWrapper<TMonitor>() .in("serial_number", list.stream().map(MonitoringDetailResult::getExternalIndexCode).collect(Collectors.toList()))) .stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); //获取省厅国标码集合 List<String> provinceIds = getProvince(); Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (MonitoringDetailResult result : list) { TMonitor monitor = monitorMap.get(result.getExternalIndexCode()); if (monitor == null) continue; String deptId = monitor.getDeptId().toString(); updateAreaStats(areaStatsMap, deptId, result); // 处理省厅数据 if (!CollectionUtils.isEmpty(provinceIds) && provinceIds.contains(monitor.getSerialNumber())) { String provinceKey = "Province_" + deptId; updateAreaStats(areaStatsMap, provinceKey, result); } } // 查询是否index表已经存在今日数据 List<CheckIndexFace> checkIndexFaceList = checkIndexFaceMapper.selectToday(DateUtils.getDate()); List<CheckIndexFace> checkIndexFaces = new ArrayList<>(); areaStatsMap.forEach((deptId, stats) -> { if (stats.totalSites > 0) { CheckIndexFace checkIndexFace = createOrUpdateCheckIndexFace(deptId, stats, checkIndexFaceList); checkIndexFaces.add(checkIndexFace); } }); checkIndexFaceService.saveOrUpdateBatch(checkIndexFaces); } /** * 累计总点位数、标注异常点位数 */ private void updateAreaStats(Map<String, AreaStats> areaStatsMap, String key, MonitoringDetailResult result) { //返回对象的引用,如果不存在会放入新的key,value AreaStats stats = areaStatsMap.computeIfAbsent(key, k -> new AreaStats()); stats.totalSites++; if (ApiConstants.HK_Info_LayType_Normal.equals(result.getLalType()) && ApiConstants.HK_Info_GbCodeType_Normal.equals(result.getGbCodeType())) { stats.qualifySite++; } } /** * 车辆信息采集正确率 */ private CheckIndexFace createOrUpdateCheckIndexFace(String key, AreaStats stats, List<CheckIndexFace> checkIndexFaceList) { CheckIndexFace checkIndexFace; // 检查是否已存在今日数据 Optional<CheckIndexFace> existingFace = checkIndexFaceList.stream() .filter(car -> key.equals(car.getDeptId().toString()) && (key.startsWith("Province_") ? CheckConstants.Examine_Tag_City.equals(car.getExamineTag()) : CheckConstants.Examine_Tag_County.equals(car.getExamineTag()))) .findFirst(); if (existingFace.isPresent()) { checkIndexFace = existingFace.get(); } else { checkIndexFace = new CheckIndexFace(); checkIndexFace.setDeptId(key.startsWith("Province_") ? Long.parseLong(key.split("_")[1]) : Long.parseLong(key)); checkIndexFace.setExamineTag(key.startsWith("Province_") ? CheckConstants.Examine_Tag_City : CheckConstants.Examine_Tag_County); checkIndexFace.setCreateTime(new Date()); } //调用计算方法 Map<String, Object> siteOnlineParam = new HashMap<>(); siteOnlineParam.put("totalSites", stats.totalSites); siteOnlineParam.put("qualifySite", stats.qualifySite); BigDecimal infoAccuracy = InfoAccuracy(siteOnlineParam); checkIndexFace.setFaceInformationCollectionAccuracy(infoAccuracy); return checkIndexFace; } } ycl-server/src/main/java/com/ycl/calculate/FaceSiteOnlineCalculation.java
@@ -1,18 +1,13 @@ package com.ycl.calculate; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.CheckIndexCar; import com.ycl.platform.domain.entity.CheckIndexFace; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.platform.mapper.CheckIndexCarMapper; import com.ycl.platform.mapper.CheckIndexFaceMapper; import com.ycl.platform.service.ICheckIndexCarService; import com.ycl.platform.service.ICheckIndexFaceService; import com.ycl.platform.service.ITMonitorService; import com.ycl.platform.service.impl.CheckIndexFaceServiceImpl; import com.ycl.system.mapper.SysConfigMapper; import com.ycl.system.mapper.SysDeptMapper; import constant.ApiConstants; import constant.CheckConstants; import constant.CheckSnapCountConstants; @@ -35,7 +30,7 @@ * 更新或新增 */ @Component public class FaceSiteOnlineCalculation implements CalculationStrategy<SnapshotDataMonitorResult> { public class FaceSiteOnlineCalculation extends IndexCalculationServe implements CalculationStrategy<SnapshotDataMonitorResult> { @Autowired private CheckIndexFaceMapper checkIndexFaceMapper; @Autowired @@ -57,14 +52,14 @@ if (CollectionUtils.isEmpty(list)) { return; } Map<String, AreaStats> areaStatsMap = new HashMap<>(); //返回以国标码为key的设备map Map<String, TMonitor> monitorMap = monitorService.list(new QueryWrapper<TMonitor>() .in("serial_number", list.stream().map(SnapshotDataMonitorResult::getExternalIndexCode).collect(Collectors.toList()))) .stream().collect(Collectors.toMap(TMonitor::getSerialNumber, Function.identity())); //获取省厅国标码集合 List<String> provinceIds = getProvince(); // TODO: 分省厅市局 需要补充集合数据 List<String> provinceIds = new ArrayList<>(); // 这里需要根据点位补充 Map<String, AreaStats> areaStatsMap = new HashMap<>(); for (SnapshotDataMonitorResult result : list) { TMonitor monitor = monitorMap.get(result.getExternalIndexCode()); @@ -138,15 +133,19 @@ checkIndexFace.setCreateTime(new Date()); } // 点位在线率 BigDecimal totalSitesBd = new BigDecimal(stats.totalSites); BigDecimal offlineSitesBd = new BigDecimal(stats.offlineSites); BigDecimal onlineSitesBd = totalSitesBd.subtract(offlineSitesBd); checkIndexFace.setSiteOnline(onlineSitesBd.divide(totalSitesBd, 4, RoundingMode.HALF_UP)); //调用点位在线计算方法 Map<String, Object> siteOnlineParam = new HashMap<>(); siteOnlineParam.put("totalSites", stats.totalSites); siteOnlineParam.put("offlineSites", stats.offlineSites); BigDecimal siteOnline = siteOnline(siteOnlineParam); checkIndexFace.setSiteOnline(siteOnline); //视图库对接稳定性 BigDecimal avgCount = key.startsWith("Province_") ? cityCountAvg : countyCountAvg; checkIndexFace.setViewConnectStability(new BigDecimal(stats.totalDataSum).divide(avgCount, 4, RoundingMode.HALF_UP)); Map<String, Object> viewConnectParam = new HashMap<>(); viewConnectParam.put("totalDataSum", stats.totalDataSum); viewConnectParam.put("avgCount", avgCount); BigDecimal viewConnectStability = viewConnectStability(viewConnectParam); checkIndexFace.setViewConnectStability(viewConnectStability); return checkIndexFace; } } ycl-server/src/main/java/com/ycl/calculate/IndexCalculationServe.java
New file @@ -0,0 +1,57 @@ package com.ycl.calculate; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.platform.service.ITMonitorService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.stereotype.Service; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.function.Function; import java.util.stream.Collectors; /** * 计算公式 */ @Component public class IndexCalculationServe { @Autowired private ITMonitorService monitorService; //点位在线率 public BigDecimal siteOnline(Map<String, Object> param) { BigDecimal totalSites = new BigDecimal((Integer) param.get("totalSites")); BigDecimal offlineSites = new BigDecimal((Integer) param.get("offlineSites")); BigDecimal onlineSites = totalSites.subtract(offlineSites); return onlineSites.divide(totalSites, 4, RoundingMode.HALF_UP); } //视图库对接稳定性 public BigDecimal viewConnectStability(Map<String, Object> param) { BigDecimal totalDataSum = new BigDecimal((Integer) param.get("totalDataSum")); BigDecimal avgCount = new BigDecimal((Integer) param.get("avgCount")); return avgCount.divide(totalDataSum, 4, RoundingMode.HALF_UP); } //标注正确率 public BigDecimal InfoAccuracy(Map<String, Object> param) { BigDecimal totalSitesCount = new BigDecimal((Integer) param.get("totalSites")); BigDecimal qualifySiteCount = new BigDecimal((Integer) param.get("qualifySite")); return qualifySiteCount.divide(totalSitesCount, 4, RoundingMode.HALF_UP); } //返回省厅国标码集合 public List<String> getProvince() { // TODO: 分省厅市局 需要补充集合数据 List<String> list = new ArrayList<>(); return list; } } ycl-server/src/main/java/com/ycl/calculate/IndexCalculationUtils.java
File was deleted ycl-server/src/main/java/com/ycl/factory/IndexCalculationFactory.java
@@ -1,8 +1,6 @@ package com.ycl.factory; import com.ycl.calculate.CalculationStrategy; import com.ycl.calculate.CarSiteOnlineCalculation; import com.ycl.calculate.FaceSiteOnlineCalculation; import com.ycl.calculate.*; import constant.CalculationStrategyConstants; import java.util.HashMap; @@ -14,6 +12,8 @@ static { calculators.put(CalculationStrategyConstants.CAR_SiteOnline_ViewStability, new CarSiteOnlineCalculation()); calculators.put(CalculationStrategyConstants.Face_SiteOnline_ViewStability, new FaceSiteOnlineCalculation()); calculators.put(CalculationStrategyConstants.CAR_InfoAccuracy, new CarInFoAccuracyCalculation()); calculators.put(CalculationStrategyConstants.Face_InfoAccuracy, new FaceInFoAccuracyCalculation()); } public static CalculationStrategy getCalculator(String indexName) { ycl-server/src/main/java/com/ycl/platform/service/impl/CheckIndexCarServiceImpl.java
@@ -1,7 +1,6 @@ package com.ycl.platform.service.impl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ycl.calculate.IndexCalculationUtils; import com.ycl.platform.domain.entity.CheckIndexCar; import com.ycl.platform.mapper.CheckIndexCarMapper; import com.ycl.platform.service.ICheckIndexCarService; ycl-server/src/main/java/com/ycl/task/CarTask.java
@@ -3,6 +3,7 @@ import com.ycl.calculate.CalculationStrategy; import com.ycl.factory.IndexCalculationFactory; import com.ycl.platform.domain.result.HK.CrossDetailResult; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.utils.DateUtils; import constant.ApiConstants; @@ -34,10 +35,18 @@ query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)) .and("dataType").is(ApiConstants.HK_DATATYPE_CAR)); List<SnapshotDataMonitorResult> snapshotDataMonitorResults = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy<SnapshotDataMonitorResult> siteOnlineCalculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.CAR_SiteOnline_ViewStability); siteOnlineCalculator.calculate(snapshotDataMonitorResults); List<SnapshotDataMonitorResult> results = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy<SnapshotDataMonitorResult> calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.CAR_SiteOnline_ViewStability); calculator.calculate(results); } public void InfoAccuracyTask(){ 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<CrossDetailResult> results = mongoTemplate.find(query, CrossDetailResult.class); CalculationStrategy calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.CAR_InfoAccuracy); calculator.calculate(results); } } ycl-server/src/main/java/com/ycl/task/FaceTask.java
@@ -3,6 +3,8 @@ import com.ycl.calculate.CalculationStrategy; import com.ycl.factory.IndexCalculationFactory; import com.ycl.platform.domain.result.HK.CrossDetailResult; import com.ycl.platform.domain.result.HK.MonitoringDetailResult; import com.ycl.platform.domain.result.HK.SnapshotDataMonitorResult; import com.ycl.utils.DateUtils; import constant.ApiConstants; @@ -34,9 +36,18 @@ query.addCriteria(Criteria .where("mongoCreateTime").gte(DateUtils.getDayStart(yesterday)).lt(DateUtils.getDayEnd(yesterday)) .and("dataType").is(ApiConstants.HK_DATATYPE_FACE)); List<SnapshotDataMonitorResult> snapshotDataMonitorResults = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy<SnapshotDataMonitorResult> siteOnlineCalculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Face_SiteOnline_ViewStability); siteOnlineCalculator.calculate(snapshotDataMonitorResults); List<SnapshotDataMonitorResult> results = mongoTemplate.find(query, SnapshotDataMonitorResult.class); CalculationStrategy<SnapshotDataMonitorResult> calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Face_SiteOnline_ViewStability); calculator.calculate(results); } public void InfoAccuracyTask(){ 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<MonitoringDetailResult> results = mongoTemplate.find(query, MonitoringDetailResult.class); CalculationStrategy<MonitoringDetailResult> calculator = IndexCalculationFactory.getCalculator(CalculationStrategyConstants.Face_InfoAccuracy); calculator.calculate(results); } }