From 6bc7833cd5e47bf60805125a2cbb71ee6097ec28 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期一, 16 十二月 2019 17:04:47 +0800
Subject: [PATCH] ---

---
 algorithm/static/static.go |   91 +++++++++++++++++++++++++++++----------------
 1 files changed, 58 insertions(+), 33 deletions(-)

diff --git a/algorithm/static/static.go b/algorithm/static/static.go
index f652775..ce26988 100644
--- a/algorithm/static/static.go
+++ b/algorithm/static/static.go
@@ -16,7 +16,10 @@
 		if rule.SdkArgAlias == "score" || rule.SdkArgAlias == "proportion" || rule.SdkArgAlias == "size" || rule.SdkArgAlias == "" { // 鍒ゆ柇鐨勬槸鐩镐技鍊硷紝鍗犳瘮锛屽昂瀵哥瓑杩囨护鏉′欢锛屽鏋滃啀鏈夛紝杩樺彲浠ュ啀鍔�
 			return filterRule(rule, am)
 		} else if rule.SdkArgAlias == "duration" {
-			return CompareAndSave(rule,am,lable,args,message)
+
+			lr := CompareAndSave(rule,am,lable,args,message)
+			logger.Info("涓綋闈欐瑙勫垯缁撴灉锛�",lr)
+			return lr
 		} else {
 			return structure.LittleRuleResult{}
 		}
@@ -42,13 +45,13 @@
 			var formula string
 			if rule.SdkArgAlias == "score" {
 				formula = strconv.FormatFloat(arg.Score, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
-				logger.Info("褰撳墠鐩镐技搴﹀皬鍏紡锛�", formula)
+				//logger.Info("褰撳墠鐩镐技搴﹀皬鍏紡锛�", formula)
 			} else if rule.SdkArgAlias == "proportion" {
 				formula = strconv.FormatFloat(arg.Proportion, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
-				logger.Info("褰撳墠鍗犳瘮灏忓叕寮忥細", formula)
+				//logger.Info("褰撳墠鍗犳瘮灏忓叕寮忥細", formula)
 			} else {
 				formula = strconv.FormatFloat(arg.Size, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
-				logger.Info("褰撳墠灏哄灏忓叕寮忥細", formula)
+				//logger.Info("褰撳墠灏哄灏忓叕寮忥細", formula)
 			}
 			expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡
 			result, _ := expression.Evaluate(nil)                      // 寰楀埌鏁板鍏紡鐨勭粨鏋�
@@ -58,16 +61,16 @@
 		}
 		am.TargetNum = len(am.FilterData) // 鎶婄鍚堟潯浠剁殑鐩爣鏁伴噺鏇存柊鍒皌argetNum瀛楁
 		if am.TargetNum > 0 {
-			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort}
+			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort,am.FilterData}
 		} else {
-			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort}
+			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData}
 		}
 
 	} else if rule.SdkArgAlias == "" {
 		if am.TargetNum > 0 {
-			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort}
+			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort,am.FilterData}
 		} else {
-			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort}
+			return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData}
 		}
 	}
 	return structure.LittleRuleResult{}
@@ -95,6 +98,12 @@
 }
 // 鍒ゆ柇涓�涓尯鍩熷唴鏈夋病鏈夐潤姝㈢殑鐩爣
 func CompareAndSave(rule *protomsg.Rule, am *structure.AreaMap,lable *structure.Others,args *structure.SdkDatas,message *protomsg.SdkMessage) structure.LittleRuleResult {
+	defer func() {
+		if err := recover(); err != nil {
+			logger.Error("涓綋闈欐瑙勫垯鏈夎", err)
+		}
+	}()
+	//logger.Info("璧颁簡涓綋闈欐鏍稿績绠楁硶")
 	initN := 5
 	if rule.SdkId == "812b674b-2375-4589-919a-5c1c3278a977" && rule.SdkArgAlias == "duration" {
 		if init,err := strconv.Atoi(rule.SdkArgValue); err != nil {
@@ -103,31 +112,47 @@
 			initN = init
 		}
 	}
-	if len(structure.StaticMap[am.AreaId].Targets) == 0 { // 鍗崇涓�甯ф暟鎹�(涔熶笉涓�瀹�)锛岃繕娌℃湁缂撳瓨
+	if len(am.FilterData) < 0 {
+		logger.Info("鏈抚鍖哄煙鍐呮棤鏁版嵁锛岃繑鍥�")
+		// 娓呯┖缂撳瓨鐨勭洰鏍�
+
+		return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData}
+	}
+	m := make(map[string]interface{})
+	m["target"] = []structure.Result{}
+	m["target"] = append(m["target"].([]structure.Result), structure.Result{args.TaskId, "", "", true, 0, "", am.FilterData, am.AreaJson, false,*lable})
+
+	if structure.StaticMap[am.AreaId] == nil || len(structure.StaticMap[am.AreaId].Targets) == 0 {
+		//logger.Info("涔嬪墠鏃犵紦瀛樺苟涓旀娆″尯鍩熷唴鏈変汉")
+
 		objs := []*structure.Obj{}
 		for _, tar := range am.FilterData {
-			obj := &structure.Obj{Id: tar.Id, Location: tar.Location, N: initN,InitN:initN}
+			obj := &structure.Obj{Id: tar.Id, Location: tar.Location, N: initN, InitN:initN, AlarmFlag: false, BufferFlag: 10, CacheSdkData:structure.ResultMsg{message, m}}
 			objs = append(objs, obj)
 		}
 		structure.StaticMap[am.AreaId] = &structure.CameraArea{objs}
-		return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort}
+		return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData}
 	} else {
+		//logger.Info("涔嬪墠鏈夌紦瀛�")
 		flag := "false"
 		// 浠ヤ箣鍓嶉潤姝㈢殑瀵硅薄涓轰富鍒ゆ柇鏄惁闈欐
 		tars := []*structure.Arg{}
+		//logger.Info("鐪嬩竴涓嬮潤姝㈠尯鍩熷唴鐨勭洰鏍囷細",am.AreaId)
+		//for _, tar := range structure.StaticMap[am.AreaId].Targets {
+		//	logger.Info("鍏蜂綋鐩爣锛�",tar.Location)
+		//}
 		for _, tar := range structure.StaticMap[am.AreaId].Targets {
-			singleResult,arg := SingleStatic(tar,am,lable,90)
+			singleResult,arg := SingleStatic(tar,am,lable,95)
 			if singleResult {
 				flag = "true"
 				tars = append(tars,arg)
-				logger.Info("闈欐鐨勭洰鏍囷細",arg.Id,arg.Location,arg.Score)
+				//logger.Info("闈欐鐨勭洰鏍囷細",arg.Id,arg.Location,arg.Score)
 			}
 		}
 
 		// 鎶婃弧瓒虫潯浠剁殑鐩爣鏀捐繘areaMap涓�
 		am.AlarmObj = tars
 		// 鏇存柊鏁版嵁,鎶婃柊鏉ョ殑鏁版嵁鍐欏叆缂撳瓨
-		objs := []*structure.Obj{}
 		for _, tar := range am.FilterData {
 			flag1 := false
 			for _, OBJ := range structure.StaticMap[am.AreaId].Targets {
@@ -136,12 +161,11 @@
 				}
 			}
 			if !flag1 { // 闆嗗悎涓病鏈夌殑鎵嶆彃鍏�
-				obj := &structure.Obj{Id: tar.Id, Location: tar.Location, N: initN,InitN:initN,AlarmFlag: false, BufferFlag: 10, CacheSdkData: structure.ResultMsg{message, nil}}
-				objs = append(objs, obj)
+				obj := &structure.Obj{Id: tar.Id, Location: tar.Location, N: initN, InitN:initN,AlarmFlag: false, BufferFlag: 10, CacheSdkData: structure.ResultMsg{message, m}}
+				structure.StaticMap[am.AreaId].Targets = append(structure.StaticMap[am.AreaId].Targets, obj)
 			}
 		}
-		structure.StaticMap[am.AreaId] = &structure.CameraArea{objs}
-		return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort}
+		return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort,am.FilterData}
 	}
 }
 
@@ -161,57 +185,59 @@
 
 // 鍒ゆ柇涓�涓洰鏍囨槸鍚﹂潤姝簡鎸囧畾鏃堕棿
 func SingleStatic(person *structure.Obj, am *structure.AreaMap,lable *structure.Others, argValue float64) (bool,*structure.Arg){
+	//logger.Info("鍗曚釜鐩爣鐨勫垽鏂細")
 	flag := false
 	var o *structure.Arg = nil
 	for _, obj := range am.FilterData {
 		if person.Id == obj.Id {
 			coincidenceDegree := PgsInterPercent(Rect2Point(person.Location), obj.Location, 1, 1)
+			logger.Info("鍒ゆ柇鐩爣鐨勯噸鍚堝害",coincidenceDegree)
 			o = obj
 			if coincidenceDegree >= argValue {
 				flag = true
 			}
 		}
 	}
-	if flag { // 鏈変竴涓璞′繚鎸侀潤姝紙id鐩哥瓑骞朵笖閲嶅悎搴﹂珮浜庨槇鍊硷級
-		flagTime := TimerAlarm(lable,person,flag,am.AreaId)
+	if flag { // 褰撳墠妫�娴嬪璞′繚鎸侀潤姝紙id鐩哥瓑骞朵笖閲嶅悎搴﹂珮浜庨槇鍊硷級
+		flagTime := TimerAlarm(o,person,flag,am.AreaId)
 		if flagTime == "10" || flagTime == "11" {
 			return flag,o
 		} else {
 			return false,o
 		}
 	} else {
-		TimerAlarm(lable,person,flag,am.AreaId)
+		TimerAlarm(o,person,flag,am.AreaId)
 		return flag,o
 	}
 }
 var rw sync.RWMutex
 // 鍒ゆ柇鏄惁绗﹀悎瀹氭椂鍣ㄦ潯浠�
-func TimerAlarm(oth *structure.Others,person *structure.Obj, result bool,areaId string) (string) {
+func TimerAlarm(o *structure.Arg,person *structure.Obj, result bool,areaId string) (string) {
 	var flagTime string //
-
+	logger.Info("鐩爣鐨勫畾鏃跺櫒锛�")
 	rw.Lock()
 
 		if result { // 缁撴灉涓虹湡
-			for k, tar := range structure.StaticMap[areaId].Targets {
+			for _, tar := range structure.StaticMap[areaId].Targets {
 				if tar.Id == person.Id {
 					if tar.N == 0 && tar.AlarmFlag {
-						logger.Debug("-------------------------绗﹀悎鎸佺画鏃堕棿瑙勫垯浣嗗苟涓嶆槸棣栨锛屼笉鎶ヨ")
+						//logger.Debug("-------------------------绗﹀悎鎸佺画鏃堕棿瑙勫垯浣嗗苟涓嶆槸棣栨锛屼笉鎶ヨ")
 						flagTime = "11"
-						oth.TimeLabel = flagTime
+						o.TimeLable = flagTime
+						o.CacheData = tar.CacheSdkData
 					}
 					if tar.N == 0 && !tar.AlarmFlag { // 杩欑粍瑙勫垯鐨勫畾鏃跺櫒瑕佸叏閮ㄧ瓑浜�0   鏆備笖璁や负涓�缁勮鍒欏彧鏈変竴涓畾鏃跺櫒
 						logger.Debug("鈥斺�斺�斺�斺�斺�斺�斺�斺�斺�斺��-------------棣栨绗﹀悎鎸佺画鏃堕棿瑙勫垯骞舵姤璀�")
 						flagTime = "10"
 						tar.AlarmFlag = true
-						oth.CacheData = []structure.ResultMsg{}
-						oth.CacheData = append(oth.CacheData,tar.CacheSdkData)
-						oth.TimeLabel = flagTime
+						o.TimeLable = flagTime
+						o.CacheData = tar.CacheSdkData
 					}
 					if tar.N != 0 {
 						flagTime = "00"
 						// 鏈夊畾鏃跺櫒浣嗕笉涓�0鎶婂凡鎵撶殑鏍囩鍒犻櫎
 						// args.RuleResult = nil
-						logger.Debug("------------------------缁撴灉涓虹湡浣嗚鏁板櫒涓嶅埌0锛屼笉鎶ヨ,姝ゆ椂鐨勮鏁板櫒", k, "鐨勫�间负锛�", tar.N)
+						//logger.Debug("------------------------缁撴灉涓虹湡浣嗚鏁板櫒涓嶅埌0锛屼笉鎶ヨ,姝ゆ椂鐨勮鏁板櫒", k, "鐨勫�间负锛�", tar.N)
 					}
 				}
 			}
@@ -220,9 +246,8 @@
 				if tar.Id == person.Id {
 					if tar.AlarmFlag {
 						if tar.BufferFlag == 0 {
-							logger.Debug("------------------------------鏉�姝昏鏁板櫒锛屾姤璀︽甯х姸鎬佹敼鍙樼殑鏁版嵁锛屾鏃剁殑璁℃暟鍣ㄧ殑鍊间负", tar.N)
+							//logger.Debug("------------------------------鏉�姝昏鏁板櫒锛屾姤璀︽甯х姸鎬佹敼鍙樼殑鏁版嵁锛屾鏃剁殑璁℃暟鍣ㄧ殑鍊间负", tar.N)
 							flagTime = "12"
-							oth.TimeLabel = flagTime
 							structure.StaticMap[areaId].Targets = append(structure.StaticMap[areaId].Targets[:index],structure.StaticMap[areaId].Targets[index+1:]...)
 						} else {
 							if tar.BufferFlag > 0 {
@@ -231,7 +256,7 @@
 							}
 						}
 					} else {
-						logger.Debug("-----------缁撴灉涓哄亣涓斾笉鍒�0锛屾潃姝诲畾鏃跺櫒")
+						//logger.Debug("-----------缁撴灉涓哄亣涓斾笉鍒�0锛屾潃姝诲畾鏃跺櫒")
 						structure.StaticMap[areaId].Targets = append(structure.StaticMap[areaId].Targets[:index],structure.StaticMap[areaId].Targets[index+1:]...)
 					}
 				}

--
Gitblit v1.8.0