| | |
| | | return ExceptionType.TYPE4 |
| | | } |
| | | |
| | | override fun judgeDataScale(p: BaseRealTimeData?, n: BaseRealTimeData): MutableMap<FactorType, Boolean> { |
| | | val res = mutableMapOf<FactorType, Boolean>() |
| | | config.factorFilter.mainList().forEach { f -> |
| | | if (p?.getByFactorType(f) == null || n.getByFactorType(f) == null || n.windSpeed == null) { |
| | | res[f] = (false) |
| | | return@forEach |
| | | } |
| | | val nValue = n.getByFactorType(f)!! |
| | | val minValue = FactorType.getVMin(f) |
| | | res[f] = nValue >= minValue |
| | | } |
| | | return res |
| | | } |
| | | |
| | | override fun judgeException(p: BaseRealTimeData?, n: BaseRealTimeData): MutableMap<FactorType, Boolean> { |
| | | val res = mutableMapOf<FactorType, Boolean>() |
| | | println() |
| | | config.factorFilter.mainList().forEach { f -> |
| | | if (p?.getByFactorType(f) == null || n.getByFactorType(f) == null || n.windSpeed == null) { |
| | | res[f] = (false) |
| | |
| | | val nValue = n.getByFactorType(f)!! |
| | | // 计算后一个数据相比于前一个数据的变化率 |
| | | val r = (nValue - pValue) / pValue |
| | | val b1 = r >= con.mutationRate.first |
| | | val b1 = r >= con.mutationRate.first && r < con.mutationRate.second |
| | | println("因子:${f.des},幅度:${r},限定:${con.mutationRate.first},${b1}") |
| | | res[f] = b1 |
| | | } else { |
| | |
| | | return res |
| | | } |
| | | |
| | | override fun judgeExceptionCount(tag: ExceptionTag): Boolean { |
| | | override fun judgeExceptionCount(tag: ExceptionTag, factorType: FactorType?): Boolean { |
| | | return tag.exceptionData.size >= windLevelCondition.countLimit |
| | | } |
| | | |
| | | override fun needCut(tag: ExceptionTag, hasException: Boolean?): Boolean { |
| | | override fun needCut(tag: ExceptionTag, hasException: Boolean?, data: BaseRealTimeData): Boolean { |
| | | // 按照时长和距离限制将异常截取 |
| | | if (tag.exceptionData.isEmpty()) return false |
| | | |
| | | val se = tag.exceptionData.first() |
| | | val ee = tag.exceptionData.last() |
| | | val ee = data |
| | | |
| | | val sTime = LocalDateTime.ofInstant(se.dataTime?.toInstant(), ZoneId.systemDefault()) |
| | | val eTime = LocalDateTime.ofInstant(ee.dataTime?.toInstant(), ZoneId.systemDefault()) |
| | |
| | | return b1 || b2 |
| | | } |
| | | |
| | | override fun immeExcCheck(tag: ExceptionTag): Boolean { |
| | | override fun immeExcCheck(tag: ExceptionTag, factorType: FactorType): Boolean { |
| | | // 异常出现等于限定次数时,就需要形成污染线索 |
| | | return tag.exceptionData.size == windLevelCondition.countLimit |
| | | } |
| | | |
| | | override fun newResult( |
| | | start: BaseRealTimeData, |
| | | end: BaseRealTimeData?, |
| | | factor: FactorFilter.SelectedFactor, |
| | | exceptionData: List<BaseRealTimeData>, |
| | | ): PollutedClue { |
| | | return PollutedClue(start, end, factor, exceptionData, getExceptionType(), config, windLevelCondition) |
| | | override fun newResult(tag: ExceptionTag, factor: FactorFilter.SelectedFactor): PollutedClue { |
| | | return PollutedClue(tag, factor, getExceptionType(), config, windLevelCondition) |
| | | } |
| | | |
| | | // override fun newResult( |
| | | // start: BaseRealTimeData, |
| | | // end: BaseRealTimeData?, |
| | | // factor: FactorFilter.SelectedFactor, |
| | | // exceptionData: List<BaseRealTimeData>, |
| | | // ): PollutedClue { |
| | | // return PollutedClue(start, end, factor, exceptionData, getExceptionType(), config, windLevelCondition) |
| | | // } |
| | | |
| | | override fun onNewException( |
| | | tag: ExceptionTag, |
| | | factor: FactorFilter.SelectedFactor, |