| | |
| | | this.callback = callback |
| | | } |
| | | |
| | | override var excludedFactor: List<FactorType> = listOf(FactorType.NO2) |
| | | |
| | | private var callback: NewPolluteClueCallback? = null |
| | | |
| | | abstract var windLevelCondition: RTExcWindLevelConfig.WindLevelCondition |
| | | |
| | | override var judgeMethod: JudgeMethod = JudgeMethod.M1 |
| | | |
| | | override fun getExceptionType(): ExceptionType { |
| | | return ExceptionType.TYPE4 |
| | |
| | | val con = windLevelCondition |
| | | |
| | | if (n.windSpeed!! in con.windSpeed.first..con.windSpeed.second) { |
| | | println("风速:${n.windSpeed},[${con.windSpeed.first} - ${con.windSpeed.second}]") |
| | | // println("风速:${n.windSpeed},[${con.windSpeed.first} - ${con.windSpeed.second}]") |
| | | val pValue = p.getByFactorType(f)!! |
| | | val nValue = n.getByFactorType(f)!! |
| | | // 计算后一个数据相比于前一个数据的变化率 |
| | | val r = (nValue - pValue) / pValue |
| | | val b1 = r >= con.mutationRate.first && r < con.mutationRate.second |
| | | println("因子:${f.des},幅度:${r},限定:${con.mutationRate.first},${b1}") |
| | | // println("因子:${f.des},幅度:${r},限定:${con.mutationRate.first},${b1}") |
| | | res[f] = b1 |
| | | } else { |
| | | res[f] = false |
| | |
| | | } |
| | | |
| | | override fun newResult(tag: ExceptionTag, factor: FactorFilter.SelectedFactor): PollutedClue { |
| | | return PollutedClue(tag, factor, getExceptionType(), config, windLevelCondition) |
| | | return PollutedClue() |
| | | } |
| | | |
| | | // override fun newResult( |
| | | override fun newResult(exceptions: List<Pair<FactorFilter.SelectedFactor, ExceptionTag>>): PollutedClue { |
| | | return if (exceptions.isEmpty()) |
| | | PollutedClue() |
| | | else |
| | | PollutedClue(exceptions, getExceptionType(), config, windLevelCondition) |
| | | } |
| | | |
| | | // override fun newResult( |
| | | // start: BaseRealTimeData, |
| | | // end: BaseRealTimeData?, |
| | | // factor: FactorFilter.SelectedFactor, |
| | |
| | | // return PollutedClue(start, end, factor, exceptionData, getExceptionType(), config, windLevelCondition) |
| | | // } |
| | | |
| | | override fun onNewException( |
| | | tag: ExceptionTag, |
| | | factor: FactorFilter.SelectedFactor, |
| | | exceptionStatus: ExceptionStatusType, |
| | | ) { |
| | | super.onNewException(tag, factor, exceptionStatus) |
| | | |
| | | // override fun mergeExceptionResult() { |
| | | // super.mergeExceptionResult() |
| | | // callback?.let { func -> |
| | | // result.forEach { |
| | | // func.invoke(it) |
| | | // } |
| | | // } |
| | | // } |
| | | |
| | | override fun onNewResult(result: List<PollutedClue>) { |
| | | callback?.let { func -> |
| | | val exc = tag.exceptionResult.last() |
| | | func.invoke(exc as PollutedClue) |
| | | result.forEach { |
| | | func.invoke(it) |
| | | } |
| | | } |
| | | } |
| | | } |