From 1571cd0f137ced4345fa8785e166a29dc31b6ad1 Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期二, 13 五月 2025 17:42:39 +0800
Subject: [PATCH] 1. 新增动态污染溯源的数据异常判断逻辑 2. 新增动态污染溯源websocket连接功能

---
 src/main/kotlin/com/flightfeather/uav/biz/dataanalysis/exceptiontype/ExceptionValueMutation.kt |   26 ++++++++------------------
 1 files changed, 8 insertions(+), 18 deletions(-)

diff --git a/src/main/kotlin/com/flightfeather/uav/biz/dataanalysis/exceptiontype/ExceptionValueMutation.kt b/src/main/kotlin/com/flightfeather/uav/biz/dataanalysis/exceptiontype/ExceptionValueMutation.kt
index fdaa83c..582223b 100644
--- a/src/main/kotlin/com/flightfeather/uav/biz/dataanalysis/exceptiontype/ExceptionValueMutation.kt
+++ b/src/main/kotlin/com/flightfeather/uav/biz/dataanalysis/exceptiontype/ExceptionValueMutation.kt
@@ -1,6 +1,5 @@
 package com.flightfeather.uav.biz.dataanalysis.exceptiontype
 
-import com.flightfeather.uav.biz.dataanalysis.BaseExceptionContinuous
 import com.flightfeather.uav.biz.dataanalysis.model.DataAnalysisConfig
 import com.flightfeather.uav.biz.dataanalysis.model.ExceptionType
 import com.flightfeather.uav.domain.entity.BaseRealTimeData
@@ -10,7 +9,7 @@
 /**
  * 閲忕骇绐佸彉寮傚父鍒嗘瀽
  */
-class ExceptionValueMutation(config: DataAnalysisConfig) : BaseExceptionContinuous(config) {
+class ExceptionValueMutation(config: DataAnalysisConfig) : ExceptionContinuous(config) {
 
     /**
      * 鏈紓甯哥殑杩炵画鍙戠敓娆℃暟浼氭牴鎹紓甯哥殑绋嬪害鍙樺寲
@@ -34,30 +33,21 @@
             val b2 = r >= config.mutationRate
             if (b1) special = true
             res[f] = (b1 || b2)
-            if (res[f] == true) println("p: $pValue --- n: $nValue --- r: $r")
+//            if (res[f] == true) println("p: $pValue --- n: $nValue --- r: $r")
         }
-//        repeat(config.factorCount) { i->
-//            if (p?.getByFactorIndex(i) == null || n.getByFactorIndex(i) == null) {
-//                res.add(false)
-//                return@repeat
-//            }
-//            val pValue = p.getByFactorIndex(i)!!
-//            val nValue = n.getByFactorIndex(i)!!
-//            val r = abs((pValue - nValue) / pValue)
-//            val b1 = r >= (2 * config.mutationRate)
-//            val b2 = r >= config.mutationRate
-//            if (b1) special = true
-//            res.add(b1 || b2)
-//        }
 
         return res
     }
 
-    override fun judgeDuration(sIndex: Int, eIndex: Int): Boolean {
+    override fun judgeExceptionCount(tag: Tag): Boolean {
+        // 棣栦釜鏁版嵁娌℃湁鍓嶄竴涓暟鎹弬鐓э紝涓嶇畻寮傚父鍊硷紝鏈�鍚庝竴涓暟鎹槸鍒ゆ柇缁撴潫鐨勬甯稿�硷紝鍥犳寮傚父鏁版嵁涓暟鐨勮绠椾笅鏍囦负sIndex鍜宔Index
+        val sIndex = tag.sIndex
+        val eIndex = tag.eIndex - 1
+
         val b1 = special && (eIndex - sIndex) >= (config.mutationNum / 2)
         val b2 = (eIndex - sIndex) >= config.mutationNum
         special = false
-        println("sIndex: $sIndex --- eIndex: $eIndex --- special: $special")
+//        println("sIndex: $sIndex --- eIndex: $eIndex --- special: $special")
         return b1 || b2
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3