From 75e1f0dc801e87821d7a72eddd041951837b8197 Mon Sep 17 00:00:00 2001
From: dongyukun <1208714201@qq.com>
Date: 星期三, 07 五月 2025 18:01:47 +0800
Subject: [PATCH] 归档过滤-2

---
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java |   60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 58 insertions(+), 2 deletions(-)

diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java
index efc2c6e..6e0f10d 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/api/controller/admin/McsApiController.java
@@ -21,6 +21,8 @@
 import java.io.IOException;
 import java.math.BigDecimal;
 import java.text.SimpleDateFormat;
+import java.time.LocalDateTime;
+import java.time.temporal.ChronoUnit;
 import java.util.*;
 
 import static com.iailab.framework.common.pojo.CommonResult.success;
@@ -63,6 +65,53 @@
             e.printStackTrace();
         }
         return CommonResult.success(respVO);
+    }
+
+    @PostMapping("/predict-data/missDataList")
+    @Operation(summary = "缺失历史数据表单")
+    public CommonResult<List<Map<String,Object>>> getPreDataMissDataList(HttpServletResponse response, HttpServletRequest
+            request, @RequestBody PreDataBarLineReqVO reqVO) throws Exception {
+        apiSecurityUtils.validate(request);
+
+        PreDataBarLineRespVO respVO = new PreDataBarLineRespVO();
+        List<Map<String,Object>> result = new ArrayList<>();
+        try {
+            respVO = mcsApi.getPreDataCharts(reqVO);
+            for (int i = 0; i < respVO.getDataViewList().size()-1; i++) {
+
+                Map<String,Object> real = getMissDataMap(respVO.getDataViewList().get(i).getRealData(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(真实)");
+                Map<String,Object> preN = getMissDataMap(respVO.getDataViewList().get(i).getPreDataN(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(T+N)");
+                Map<String,Object> preL = getMissDataMap(respVO.getDataViewList().get(i).getPreDataL(),respVO.getDataViewList().get(i).getOutId(),respVO.getDataViewList().get(i).getResultName()+"(T+L)");
+                result.add(real);
+                result.add(preN);
+                result.add(preL);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+        return CommonResult.success(result);
+    }
+
+    private Map<String,Object> getMissDataMap( List<Object[]> list,String outId,String resultName){
+        Map<String,Object> missDataMap = new HashMap<>();
+
+        if (list == null || list.size() < 2) {
+            return missDataMap;
+        }
+        for (int i = 1; i < list.size(); i++) {
+            LocalDateTime startTime = (LocalDateTime) list.get(i-1)[0];
+            LocalDateTime endTime = (LocalDateTime) list.get(i)[0];
+            long gap = ChronoUnit.MINUTES.between(startTime, endTime);
+            if (gap > 10) {
+                missDataMap.put("outId",outId);
+                missDataMap.put("resultName",resultName);
+                missDataMap.put("startTime",startTime);
+                missDataMap.put("endTime",endTime);
+                missDataMap.put("random",10);
+                missDataMap.put("gap",gap);
+            }
+        }
+        return missDataMap;
     }
 
     @PostMapping("/predict-data/item-chart")
@@ -113,13 +162,13 @@
         reqVO.setItemId(itemId);
         try {
             if (startTime == "") {
-                reqVO.setStartTime(new Date((new Date()).getTime() - 60 * 60 * 1000));
+                reqVO.setStartTime(null);
             } else {
                 reqVO.setStartTime(formatter.parse(startTime));
 
             }
             if (endTime == "") {
-                reqVO.setEndTime(new Date((new Date()).getTime() + 60 * 60 * 1000));
+                reqVO.setEndTime(null);
             } else {
                 reqVO.setEndTime(formatter.parse(endTime));
             }
@@ -275,4 +324,11 @@
         List<ScheduleSuggestRespDTO> data = mcsApi.getLastSuggest(params);
         return CommonResult.success(data);
     }
+
+    @GetMapping("/predict/model/setting/update")
+    @Operation(summary = "修改调度模型配置")
+    public CommonResult<Boolean> updatePredictModelSetting(@RequestParam("modelCode") String modelCode, @RequestParam("key") String key, @RequestParam("value") String value){
+        mcsApi.updatePredictModelSetting(modelCode, key, value);
+        return success( true);
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3