From 6e2208069cec227edd6c8f274e36f87190e6b166 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期四, 18 七月 2019 17:19:07 +0800
Subject: [PATCH] 去掉一部分规则过滤数据中的对于代码,人脸比对直接给阈值了,不需要再用阈值过滤一遍了

---
 ruleserver/ruleToformula.go |  445 +++++++-----------------------------------------------
 1 files changed, 62 insertions(+), 383 deletions(-)

diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go
index 938f6a1..bf944ed 100644
--- a/ruleserver/ruleToformula.go
+++ b/ruleserver/ruleToformula.go
@@ -1,7 +1,7 @@
 package ruleserver
 
 import (
-	"encoding/json"
+	"fmt"
 	"ruleprocess/cache"
 	"ruleprocess/logger"
 	"sort"
@@ -9,56 +9,9 @@
 	"strings"
 	"time"
 
-	bigCache "basic.com/pubsub/cache.git"
-	"basic.com/pubsub/cache.git/esutil"
 	"basic.com/pubsub/protomsg.git"
 	"github.com/knetic/govaluate"
 )
-
-func init() {
-	bigCache.Init()
-}
-
-// 浠诲姟
-type Task struct {
-	camID     string //鎽勫儚鏈篒D
-	taskID    string //浠诲姟ID
-	sdkID     string //绠楁硶ID
-	areaId    string //鍖哄煙id
-	areaName  string //鍖哄煙鍚嶇О
-	topicType string //瑙勫垯涓婚绫诲瀷锛岀洰鏍�/鎸佺画鏃堕棿/鐏垫晱搴︾瓑
-}
-
-// 鏁版嵁搴撲腑鐨勮鍒欏厓绱�
-type SingleRule struct {
-	Task
-	operatorType     string // 鎿嶄綔绗︼紝>=,==...
-	compareType      string // 瀵规瘮绫诲瀷锛屽�硷紝琚�夐」
-	compareValue     string // 瀵规瘮鐨勫��
-	ruleWithPrevious string // 璺熶笂涓�鏉$殑閫昏緫鍏崇郴
-	groupId          string // 澶ц鍒檌d
-}
-
-// 鏁版嵁搴撲腑鍗曟潯瀛愯鍒�  璺熸暟鎹簱鏄犲皠鐨�
-type CameraTaskArg struct {
-	Id               string `json:"id"`
-	CameraTaskId     string `json:"camera_task_id"`
-	CameraId         string `json:"camera_id"`
-	PolygonId        string `json:"polygon_id"`
-	SdkId            string `json:"sdk_id"`
-	SdkArgAlias      string `json:"sdk_arg_alias"`
-	Operator         string `json:"operator"`      //鎿嶄綔绗︼紝>=,==...
-	OperatorType     string `json:"operator_type"` //瀵规瘮绫诲瀷锛屽�硷紝琚�夐」
-	SdkArgValue      string `json:"sdk_arg_value"` //瀵规瘮鐨勫��
-	Sort             int    `json:"sort"`
-	RuleWithPrevious string `json:"rule_with_previous"` //璺熶笂涓�鏉$殑閫昏緫鍏崇郴
-	GroupId          string `json:"group_id"`           //澶ц鍒檌d
-}
-
-// sdk杈撳嚭鐨勫浘鐗囨彁鍙栧弬鏁版暟鎹箣鍚庣殑鏁版嵁闆嗗悎锛屼篃鏄紶缁欎笅涓�姝ョ敤浜庤祴鍊肩殑鏁版嵁闆嗗悎
-type AreaMapList struct {
-	areaMapList []AreaMap
-}
 
 // 姣忎釜鐩爣鐨勫弬鏁帮細鐩镐技搴︼紝鍗犳瘮锛屽昂瀵�
 type Arg struct {
@@ -69,12 +22,7 @@
 	Location   Rect    // 璁颁笅姣忎釜鐩爣鐨勪綅缃弬鏁帮紝鏈�鍚庣粰缁撴灉瑁呴厤浜鸿劯鏁版嵁鐨勬椂鍊欑敤鐨勫埌
 	Feature    []byte
 	ThftRes    protomsg.ThftResult
-	Liker      []*protomsg.Baseinfo
-}
-
-type LikePerson struct {
-	Id    string  // 涓庝箣鐩镐技鐨勫簳搴撲汉鍛樼殑id
-	Score float64 // 涓庡簳搴撲汉鍛樼殑鐩镐技鍊�
+	Liker      []*BaseInfo
 }
 
 // 姣忎釜鍖哄煙鍐呯殑鍥剧墖鏁版嵁闆嗗悎
@@ -121,15 +69,13 @@
 // 浠庣畻娉曟ā鍧楀効鎷挎潵鐨勫涓�甯у浘鍍忓悇涓畻娉曟彁鍙栫殑鏁版嵁闆嗗悎
 type SdkDatas struct {
 	CameraId   string
+	TaskId     string
 	Sdkdata    []*SdkData
 	RuleResult map[string]interface{} // 杩囧畬瑙勫垯鍚庢墦鐨勬爣绛� face: []Arg, yolo: []Result, cacheData: SdkDatas, timeLabel: 0,1,2,3,4,5
 }
 
-// 灏嗕紶閫掕繃鏉ョ殑鍙傛暟杞寲涓�
-//protomsg.SdkMessage.TaskLabel.SdkmsgWithTask.sdkdata
-
 type ResultMsg struct {
-	protomsg.SdkMessage
+	*protomsg.SdkMessage
 	RuleResult map[string]interface{} // 杩囧畬瑙勫垯鍚庢墦鐨勬爣绛�
 }
 
@@ -149,74 +95,36 @@
 	Sort    int32
 }
 
-//
-type Face struct {
-	Location Rect // 浜鸿劯鍧愭爣妗�
-	SdkName  string
-	ThftRes  protomsg.ThftResult
-	Liker    []LikePerson // 鐩镐技浜哄憳锛堝鏋滄槸鍗曠函鐨勪汉鑴告娴嬪彲鏃犳椤癸級
-}
-
-// 鍖呭惈N鏉¤鍒欏厓绱犵殑涓�鏁存潯瑙勫垯
-type CompleteRule struct {
-	rule string
-}
-
-// 鏍规嵁鎽勫儚鏈篿d鎷垮埌鎽勫儚鏈烘墍鏈夊尯鍩�
-func GetPolygons(cameraId string) []protomsg.CameraPolygon {
-	var cameraPolygons []protomsg.CameraPolygon
-	cameraPolygons = cache.GetPolygonsByCameraId(cameraId)
-	logger.Debug("------=======鏌ョ湅涓嬪叏閮ㄥ尯鍩燂細",cameraPolygons)
-	return cameraPolygons
-}
-
-// 鎶妔dk浠庢暟鎹抚涓婃彁鍙栫殑鎸夌収鍖哄煙鍒嗙被褰掔疆
-func SdkDataFormat(cameraId string, arg *SdkData, cameraPolygons []protomsg.CameraPolygon) {
-	logger.Info("==================================鏈瑂dkData涓В鍑烘潵鐨勭洰鏍囨暟鎹�=======================================")
-	for _, photo := range arg.Photo {
-		logger.Info("--------瑙f瀽鍑烘潵鐨勬暟鎹�---", cameraId, arg.IpcId, photo.Rects, photo.Score)
-	}
-	for _, polygon := range cameraPolygons {
-		//logger.Println("++++++鍦ㄨ繖鍎跨湅涓�涓嬪尯鍩熷晩:", polygon.Polygon)
-		areaMap := AreaMap{cameraId: cameraId, areaId: polygon.Id, areaJson: polygon.Polygon, triggerLine: polygon.TriggerLine, directionLine: polygon.DirectionLine}
-		// 涓烘瘡涓憚鍍忔満鍖哄煙濉厖鏁版嵁
-		areaMap.CountAreaObjs(arg)
-		arg.AreaMapList = append(arg.AreaMapList, &areaMap)
-	}
-}
-
 // 瀵瑰崟甯у浘鍍忕殑鍒ゆ柇 thisSdkDatas  褰撳墠浼犲叆鐨勮繖甯ф暟鎹紝cacheSdkData 瀹氭椂鍣ㄩ噷缂撳瓨鐨勪竴甯ф暟鎹� 娌℃湁灏辫繑鍥瀗il  (thisSdkDatas SdkDatas, cacheSdkDatas SdkDatas)
-func Judge(args *SdkDatas) {
+func Judge(args *SdkDatas, message *protomsg.SdkMessage) {
 	if len(args.Sdkdata) > 0 {
 		// 鎷垮埌鏈憚鍍忔満鐨勫尯鍩�
 		cameraPolygons := GetPolygons(args.CameraId)
 		// 鎶婃墍鏈夌殑sdk鎻愬彇鐨勬暟鎹兘鎸夋墍灞炴憚鍍忔満鐨勫尯鍩熷綊缃�
+		logger.Debug("褰撳墠鎽勫儚鏈篿d涓猴細",message.Cid,"褰撳墠鎽勫儚鏈烘墽琛岀殑浠诲姟鏄細",message.Tasklab.Taskname)
 		for _, arg := range args.Sdkdata {
 			SdkDataFormat(args.CameraId, arg, cameraPolygons)
 		}
 		// 璺戞湰鎽勫儚鏈虹殑鎵�鏈夎鍒欑粍 涓�缁勪竴缁勮窇
-		taskRuleList := GetRuleGroup(args.CameraId) // 鏈憚鍍忔満涓嬫墍鏈変换鍔$粍
+		taskGroup := GetRuleGroup(args.CameraId, args.TaskId) // 鏈憚鍍忔満涓嬫墍鏈変换鍔$粍
 		//logger.Println("鐪嬩笅鎽勫儚鏈轰笅鐨勪换鍔$粍锛�",taskRuleList)
 		// 寰楀埌灞炰簬璇ユ憚鍍忔満鐨勮嫢骞茬粍浠诲姟鐨勫畬鏁磋鍒欙紙璺熸瘡涓�鏉″畬鏁磋鍒欐瘮杈冧箣鍚庡緱鍑烘湰寮犲浘鍍忓浜庢煇涓鍒欐槸鍚︽姤璀︾殑缁撴灉銆傛斁杩沵ap锛屾瘮濡傛湰甯у浘鍍忕殑id锛屾墍纰版挒鎴愬姛鐨勮鍒檌d锛�
 		args.RuleResult = make(map[string]interface{})
 		args.RuleResult["yolo"] = []Result{}
 		args.RuleResult["face"] = []Arg{}
-		if len(taskRuleList) > 0 {
-			for _, taskRule := range taskRuleList {
+		if taskGroup != nil && len(taskGroup.GroupRules) > 0 {
+			for _, group := range taskGroup.GroupRules {
 				//logger.Println("------------------------------浠诲姟瑙勫垯锛�",taskRule)
-				ruleList := taskRule.GroupRules // 鑾峰彇鐨勬槸task涓嬮潰鐨勪换鍔$粍
-				taskId := taskRule.TaskId
+				taskId := taskGroup.TaskId
 				//logger.Println("------------鏈粍浠诲姟涓嬬殑瑙勫垯缁勭殑鏁伴噺锛�",len(ruleList))
-				for i := 0; i < len(ruleList); i++ {
-					temp := ruleList[i].Rules // temp涓轰竴缁勫畬鏁磋鍒� 鍦ㄦ闇�瑕佸垽鏂鍒欐槸鍚︽槸鑱斿姩瑙勫垯
-					if len(temp) > 0 {
-						if ruleList[i].SetType == "linkTask" {
-							// groupId涓惈鏈塴ink鍒欎负鑱斿姩浠诲姟
-							LinkTask(args, ruleList[i], taskId)
-						} else {
-							// 鐙珛浠诲姟鐨勫鐞�
-							RunRule(args, ruleList[i], taskId)
-						}
+				temp := group.Rules // temp涓轰竴缁勫畬鏁磋鍒� 鍦ㄦ闇�瑕佸垽鏂鍒欐槸鍚︽槸鑱斿姩瑙勫垯
+				if len(temp) > 0 {
+					if group.SetType == "linkTask" {
+						// groupId涓惈鏈塴ink鍒欎负鑱斿姩浠诲姟
+						LinkTask(args, group, taskId, message)
+					} else {
+						// 鐙珛浠诲姟鐨勫鐞�
+						RunRule(args, group, taskId, message)
 					}
 				}
 			}
@@ -224,89 +132,7 @@
 	}
 }
 
-// 缁欑洰鏍囧~鍏卨iker
-func (arg *Arg) fillLiker() {
-	bytes := bigCache.Getdbpersonmsg("", arg.Feature, true)
-	var m map[string]float32
-	err1 := json.Unmarshal(bytes, &m)
-	if err1 != nil {
-		logger.Error("getBaseInfo瑙e帇閿欒", err1)
-	}
-	//logger.Info("----------------------------------------map鏄�", m)
-	for key, val := range m {
-		baseinfo, err1 := esutil.Dbpersoninfosbyid(key)
-		if err1 != nil {
-			logger.Error("鏌ヨ搴曞簱浜哄憳淇℃伅鍑洪敊", err1)
-		}
-		baseinfo.CompareScore = Retain(val)
-		arg.Liker = append(arg.Liker, &baseinfo)
-	}
-	//logger.Info("------------------绗竴娆$湅args:",*arg)
-}
-// 淇濈暀鍥涗綅灏忔暟
-func Retain(f float32)(float32) {
-	s:= strconv.FormatFloat(float64(f), 'f', 4, 64)
-	v, err := strconv.ParseFloat(s, 32)
-	if err != nil {
-		logger.Error("淇濈暀鍥涗綅灏忔暟杞崲閿欒")
-	}
-	return float32(v)
-}
-func Compare(args *SdkDatas, groupRule *protomsg.GroupRule) {
-	compareFlag := 0
-	tableIds := ""
-	// 鐪嬬湅鏄惁鏈夊彧閰嶄汉鑴告瘮瀵圭畻娉曚絾娌℃湁閰嶅姣斿簱鐨勮鍒欙紝濡傛灉鏈夛紝鍒欐瘮瀵瑰璞′负鍏ㄩ儴搴曞簱
-	for j := 0; j < len(groupRule.Rules); j++ {
-		if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" { // 閰嶄簡浜鸿劯姣斿
-			if groupRule.Rules[j].SdkArgAlias == "compareBase" && groupRule.Rules[j].SdkArgValue != "" { // 閰嶄簡姣斿搴曞簱鐨勫弬鏁颁絾娌℃湁閰嶅叏閮ㄥ簳搴�
-				compareFlag = 2
-				tableIds = groupRule.Rules[j].SdkArgValue + "," // 鏈�鍚庝細澶氫竴涓猼ableId锛屽垏鍑烘潵鐨勬暟缁勫彇len-1灏卞彲浠�
-			}
-			if groupRule.Rules[j].SdkArgAlias == "compareBase" && groupRule.Rules[j].SdkArgValue == "" { // 閰嶇殑鍙傛暟鏄瘮瀵瑰叏閮ㄥ簳搴�
-				compareFlag = 1
-			}
-		}
-	}
-	// 涓轰簡娴嬭瘯浣滀笅寮婏紝鐩存帴璁╁叾姣斿鍏ㄩ儴搴曞簱
-	//compareFlag = 1
-	if compareFlag == 0 {
-		logger.Info("娌℃湁閰嶇疆瀵规瘮搴曞簱鍙傛暟")
-		return
-	}
-	for j := 0; j < len(groupRule.Rules); j++ {
-		if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" {
-			for _, sdkData := range args.Sdkdata {
-				if sdkData.IpcId == "A8B73405-373D-4F23-CED2-A617EBD7EC55" { // 鎼滅储鍒颁汉鑴告娴嬬殑sdkdata 鐜板湪鍏充簬浜鸿劯鐨勫彧鏈変粬涓�涓猻dk锛屽叏鎵句粬
-					logger.Info("============================================杩涜浜鸿劯瀵规瘮")
-					for _, areaMap := range sdkData.AreaMapList {
-						logger.Info("-------------浜鸿劯姣斿涔嬪墠鐩爣鏁伴噺",len(areaMap.args))
-						// 鎷垮尯鍩熶腑姣忎釜浜鸿劯鐗瑰緛鍊煎幓瀵规瘮锛屽~鍏呭叾liker
-						if groupRule.Rules[j].PolygonId == areaMap.areaId {
-							logger.Info("--------------鐪嬬湅compareFlag鐨勫�硷細",compareFlag)
-							for _, arg := range areaMap.args {
-								if compareFlag == 1 {
-									arg.fillLiker()
-								}
-								if compareFlag == 2 {
-									array := strings.Split(tableIds, ",")
-									logger.Info("--------------------------鐪嬬湅瀵规瘮搴曞簱鐨勫��;",array)
-									for i := 0; i < len(array)-1; i++ {
-										arg.fillLiker()
-									}
-								}
-								logger.Info("-------------------鎴愬姛缁檒iker璧嬪��,闀垮害涓猴細", len(arg.Liker))
-							}
-							areaMap.filterData = areaMap.args
-							//logger.Info("=======绗竴娆$湅args锛�",(areaMap.filterData))
-						}
-						logger.Info("-------------------------------浜鸿劯瀵规瘮涔嬪悗鐨勭洰鏍囨暟閲�",len(areaMap.args))
-					}
-				}
-			}
-		}
-	}
-}
-func RunRule(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string) bool {
+func RunRule(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string, message *protomsg.SdkMessage) bool {
 	defer func() {
 		if err := recover(); err != nil {
 			logger.Error("姣斿瑙勫垯鏈夎", err.(string))
@@ -330,9 +156,9 @@
 			logger.Info("瑙勫垯鐨刬pcId涓巗dkData鐨処pcId:", ipcId, "===", sdkData.IpcId)
 			if ipcId == sdkData.IpcId {
 				logger.Info("褰撳墠璧扮殑瑙勫垯鐨勭畻娉曟槸--锛�", sdkName, "---")
-				logger.Info("========================鏈夊嚑涓尯鍩燂細",len(sdkData.AreaMapList))
-				for _,areaMap := range sdkData.AreaMapList{
-					logger.Info("妫�鏌ヤ竴涓嬪尯鍩熺殑鍏蜂綋鏁版嵁锛�",areaMap.areaJson)
+				logger.Info("========================鏈夊嚑涓尯鍩燂細", len(sdkData.AreaMapList))
+				for _, areaMap := range sdkData.AreaMapList {
+					logger.Info("妫�鏌ヤ竴涓嬪尯鍩熺殑鍏蜂綋鏁版嵁锛�", areaMap.areaJson)
 				}
 				for _, areaMap := range sdkData.AreaMapList {
 					ruleResult := filterRule(groupRule.Rules[j], areaMap)
@@ -406,22 +232,7 @@
 			}
 		}
 	}
-	// 鏈�鍚庤繃鎸佺画鏃堕棿绛夋椂闂寸淮搴︾殑鏉′欢
-	for j := 0; j < len(groupRule.Rules); j++ {
-		for _, sdkData := range args.Sdkdata {
-			sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId)
-			if err != nil {
-				logger.Error("娌℃煡鍒皊dk鐨勪俊鎭�---", err)
-			}
-			ipcId := sdk.IpcId
-			if ipcId == sdkData.IpcId {
-				for _, areaMap := range sdkData.AreaMapList {
-					// 鍘诲紑鍚竴涓畾鏃跺櫒
-					duration(groupRule.Rules[j], groupRule.GroupId, areaMap, args)
-				}
-			}
-		}
-	}
+
 	// 灏嗘暟缁勬寜sort鎺掑簭
 	sort.Sort(resultList(resultSplice))
 	// 鎺掑簭鍚庡彇鍚勮嚜鐨勭粨鏋滃拰杩炴帴绗︽嫾鍑鸿鍒欒〃杈惧紡寰楀嚭缁撴灉
@@ -444,14 +255,13 @@
 	}
 	if completeFormula != "" {
 		logger.Info("缁撴灉鍏紡-----------锛�", completeFormula)
-		expression, _ := govaluate.NewEvaluableExpression(completeFormula)
-		if strings.HasPrefix(completeFormula, "&&") || strings.HasPrefix(completeFormula, "||") {
+		expression, err := govaluate.NewEvaluableExpression(completeFormula)
+		if strings.HasPrefix(completeFormula, "&&") || strings.HasPrefix(completeFormula, "||") || err != nil{
 			panic("瑙勫垯鏈夎锛屽緱鍒扮殑鏁板鍏紡涓嶅彲瑙f瀽")
 		}
 		result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋�
-		// 杩涜瀹氭椂鍣ㄧ殑澶勭悊鍜屽垽鏂�
-		timeFlag := TimerAlarm(args,groupRule.GroupId,result.(bool))
-		if timeFlag == "01" || timeFlag == "10" || timeFlag == "11" {
+
+		if result.(bool) {
 			// 鏈�鍚庢垚鍔熸姤璀︽墠鎶婄鍚堟潯浠剁殑浜鸿劯鏁版嵁濉炶繘缁撴灉鏍囩閲�
 			// 閰嶄簡浜鸿劯鐨勭畻娉曟墠鎶婁汉鑴哥殑鏁版嵁鐢╁嚭鏉ユ墦鏍囩
 			faces := []Arg{}
@@ -481,74 +291,46 @@
 					}
 				}
 			}
-			logger.Debug("------locations鐨勫唴瀹癸細",locations)
+			logger.Debug("------locations鐨勫唴瀹癸細", locations)
 			if sdkNames != "" {
-				args.RuleResult["yolo"] = append(args.RuleResult["yolo"].([]Result), Result{taskId, sdkNames, groupRule.GroupId, groupRule.AlarmLevel, groupRule.GroupText, locations,polygonId})
+				args.RuleResult["yolo"] = append(args.RuleResult["yolo"].([]Result), Result{taskId, sdkNames, groupRule.GroupId, groupRule.AlarmLevel, groupRule.GroupText, locations, polygonId})
 				logger.Info("-------------------yolo缁撴灉鏍囩闀垮害", len(args.RuleResult["yolo"].([]Result)))
 			}
 			if args.RuleResult["face"] != nil {
 				logger.Info("-------------------face缁撴灉鏍囩", len(args.RuleResult["face"].([]Arg)))
 			}
-			return true
+			// 鏈�鍚庤繃鎸佺画鏃堕棿绛夋椂闂寸淮搴︾殑鏉′欢   鎶婃椂闂磋鍒欎綅缃皟鏁村埌杩欎釜浣嶇疆鏄负浜嗙紦瀛樻暟鎹�
+			for j := 0; j < len(groupRule.Rules); j++ {
+				for _, sdkData := range args.Sdkdata {
+					sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId)
+					if err != nil {
+						logger.Error("娌℃煡鍒皊dk鐨勪俊鎭�---", err)
+					}
+					ipcId := sdk.IpcId
+					if ipcId == sdkData.IpcId {
+						for _, areaMap := range sdkData.AreaMapList {
+							// 鍘诲紑鍚竴涓畾鏃跺櫒
+							duration(groupRule.Rules[j], groupRule.GroupId, areaMap, args, message)
+						}
+					}
+				}
+			}
+			// 杩涜瀹氭椂鍣ㄧ殑澶勭悊鍜屽垽鏂�
+			timeFlag := TimerAlarm(args, groupRule.GroupId, result.(bool))
+			if timeFlag == "01" || timeFlag == "10" || timeFlag == "11" { // 婊¤冻瀹氭椂鍣ㄦ潯浠�
+				return true
+			} else {
+				return false
+			}
 		} else {
+			// 缁撴灉涓哄亣鏃朵篃瑕佽蛋锛屾湁鏃跺�欎负鍋囩殑鐘舵�佸弽杞暟鎹篃闇�瑕佽褰曚笅鏉�
+			timeFlag := TimerAlarm(args, groupRule.GroupId, result.(bool))
+			fmt.Println(timeFlag)
 			return false
 		}
 	} else {
 		return false
 	}
-}
-// 鍒ゆ柇鏄惁绗﹀悎瀹氭椂鍣ㄦ潯浠�
-func TimerAlarm(args *SdkDatas,groupId string,result bool) (string) {
-	var flagTime string  //
-	// 鍒ゆ柇鏈夋棤姝よ鍒欑粍鐨勫畾鏃跺櫒
-	flag := false
-	for k,_ := range TimeEleList {
-		logger.Debug("-----------------鐪嬬湅杩欎釜key鍜実roupId",k,groupId)
-		if strings.Contains(k, groupId) {
-			flag = true
-		}
-	}
-	if flag {     // 鏈夊畾鏃跺櫒
-		if result { // 缁撴灉涓虹湡
-			for k, timeEle := range TimeEleList {
-				if strings.Contains(k, groupId) {
-					if timeEle.N == 0 && timeEle.AlarmFlag {
-						logger.Debug("-------------------------绗﹀悎鎸佺画鏃堕棿瑙勫垯浣嗗苟涓嶆槸棣栨锛屼笉鎶ヨ")
-						flagTime = "11"
-						args.RuleResult["timeLabel"] = flagTime
-					}
-					if timeEle.N == 0 && !timeEle.AlarmFlag { // 杩欑粍瑙勫垯鐨勫畾鏃跺櫒瑕佸叏閮ㄧ瓑浜�0   鏆備笖璁や负涓�缁勮鍒欏彧鏈変竴涓畾鏃跺櫒
-						logger.Debug("鈥斺�斺�斺�斺�斺�斺�斺�斺�斺�斺��-------------棣栨绗﹀悎鎸佺画鏃堕棿瑙勫垯骞舵姤璀�")
-						flagTime = "10"
-						timeEle.AlarmFlag = true
-						args.RuleResult["cacheData"] = timeEle.CacheSdkData
-						args.RuleResult["timeLabel"] = flagTime
-					}
-					if timeEle.N != 0 {
-						flagTime = "00"
-						logger.Debug("------------------------缁撴灉涓虹湡浣嗚鏁板櫒涓嶅埌0锛屼笉鎶ヨ,姝ゆ椂鐨勮鏁板櫒鐨勫�间负锛�",timeEle.N)
-					}
-				}
-			}
-		} else { // 缁撴灉涓哄亣
-			for k, timeEle := range TimeEleList {
-				if strings.Contains(k, groupId) {
-					logger.Debug("------------------------------閲嶇疆瀹氭椂鍣紝姝ゆ椂鐨勮鏁板櫒鐨勫�间负",timeEle.N)
-					timeEle.N = timeEle.InitN // 閲嶇疆瀹氭椂鍣�
-					timeEle.CacheSdkData = SdkDatas{} // 鎶婄紦瀛樻暟鎹墧浜�
-					flagTime = "12"
-				}
-			}
-
-		}
-	} else { // 鏃犲畾鏃跺櫒
-		if result {
-			flagTime = "01"
-		} else {
-			flagTime = "00"
-		}
-	}
-	return flagTime
 }
 
 func putFaceToResult(am *AreaMap) []Arg {
@@ -574,61 +356,8 @@
 	return locations
 }
 
-// 璁$畻鍖哄煙鍐呯殑鐩爣鏁伴噺浠ュ強灏嗙浉浼煎害銆佸崰姣斻�佸昂瀵哥瓑鎵撳寘
-func (a *AreaMap) CountAreaObjs(arg *SdkData) {
-
-	a.targetNum = 0
-	threshold := 0.0       // 鐩镐技搴�
-	intersectionper := 0.2 // 鍗犳瘮
-	size := 0.0            // 灏哄
-
-	areaPoints := Json2points(a.areaJson)
-	widthScale := float64(arg.ImageWidth / 960)
-	heigthScale := float64(arg.ImageHeight / 540)
-	for _, obj := range arg.Photo {
-		//logger.Info("------------------鐪嬬湅sdkData:", arg.SdkName, "鐨凱hoto鏁版嵁----------------", obj, "----椤轰究鐪嬬湅鍗犳瘮-----锛�", PgsInterPercent(areaPoints, obj.Rects, widthScale, heigthScale))
-		if threshold <= obj.Score && size <= float64(obj.Rects.Width*obj.Rects.Height) && intersectionper <= PgsInterPercent(areaPoints, obj.Rects, widthScale, heigthScale) {
-			// 杩欐瑕佸榻愯〃杈惧紡閲屾墍闇�瑕佺殑鎵�鏈夊弬鏁�
-			a.targetNum++
-			arg1 := Arg{obj.Score, PgsInterPercent(areaPoints, obj.Rects, widthScale, heigthScale), float64(obj.Rects.Width * obj.Rects.Height), obj.IsYolo, obj.Rects, obj.Feature, obj.ThftRes, []*protomsg.Baseinfo{}}
-			//logger.Println("鏀捐繘鍘荤殑arg锛�-------", arg1)
-			a.args = append(a.args, &arg1)
-			a.filterData = append(a.filterData, &arg1)
-		}
-	}
-	a.time = time.Unix(time.Now().Unix(), 0).String()[11:16]
-	a.keepRight = arg.KeepRight
-	a.isStatic = arg.IsStatic
-	//logger.Println("--------------------鐪嬬湅鍖哄煙鏁版嵁锛�",*a)
-}
-
-// 灏嗗瓧绗︿覆鏍煎紡鐨勫潗鏍囧簭鍒楀寲涓篜oint鏍煎紡
-func Json2points(areaPoints string) []Point {
-	var pts []Point
-	if areaPoints == "[]" {
-		logger.Error("=====================姝ゅ尯鍩熶负鍏ㄩ儴鍖哄煙")
-		pts = append(pts, Point{0, 0})
-		pts = append(pts, Point{0, 540})
-		pts = append(pts, Point{960, 540})
-		pts = append(pts, Point{960, 0})
-	} else {
-		err := json.Unmarshal([]byte(areaPoints), &pts)
-		if err != nil {
-			logger.Error("json.Unmarshal閿欒", err)
-			panic("搴忓垪鍖栧潗鏍囧紓甯革紝绋嬪簭閫�鍑�")
-		}
-	}
-	return pts
-}
-
-// 浠ユ憚鍍忔満id鏌ュ嚭璺熷叾鐩稿叧鐨勬墍鏈変换鍔′笅鐨勬墍鏈夎鍒欑粍
-func GetRuleGroup(cameraId string) []*protomsg.TaskGroupArgs {
-	all := cache.GetCameraTaskRulesByCameraId(cameraId)
-	return all
-}
-
 // 鑱斿姩浠诲姟鐨勫鐞�
-func LinkTask(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string) {
+func LinkTask(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string, message *protomsg.SdkMessage) {
 	// new涓�涓畾鏃跺櫒锛屽鏋滀互姝roupId涓烘爣蹇楃殑瀹氭椂鍣ㄤ笉瀛樺湪鐨勮瘽
 	logger.Info("------------------------------------------褰撳墠鏄仈鍔ㄤ换鍔★紝瑙勫垯鏄細", groupRule.GroupText)
 	var flag bool = true
@@ -658,7 +387,7 @@
 		}
 	}
 	// 寰�鏁扮粍閲岃祴鍊�
-	isOk := RunRule(args, groupRule, taskId)
+	isOk := RunRule(args, groupRule, taskId, message)
 	if isOk {
 		logger.Info("杩欏抚鍥惧儚鍦ㄤ换鍔′笅鐨勪竴鏁存潯瑙勫垯涓嬶紙鑱斿姩浠诲姟涓嬪氨鏄窡鏈憚鍍忔満鍍忕浉鍏崇殑灏忚鍒欙級鐨勫垽鏂粨鏋滀负true")
 		// 鏍规嵁cameraId鍘绘洿鏂版垨鑰呮彃鍏ョ粨鏋�,鐒跺悗鍒ゆ柇鏄惁鏁扮粍鏄惁鍙互寰楀嚭鎶ヨ鐨勭粨璁�
@@ -691,7 +420,7 @@
 				result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋�
 				if result.(bool) {
 					logger.Info("___________________________________________________________________鑱斿姩浠诲姟鎶ヨ")
-					args.RuleResult["yolo"] = append(args.RuleResult["yolo"].([]Result), Result{taskId, "", groupRule.GroupId, groupRule.AlarmLevel, groupRule.GroupText, []Rect{},""})
+					args.RuleResult["yolo"] = append(args.RuleResult["yolo"].([]Result), Result{taskId, "", groupRule.GroupId, groupRule.AlarmLevel, groupRule.GroupText, []Rect{}, ""})
 					logger.Info("-------------------yolo缁撴灉鏍囩鏈夊嚑涓�", len(args.RuleResult["yolo"].([]Result)))
 					if args.RuleResult["face"] != nil {
 						logger.Info("-------------------face缁撴灉鏍囩鏈夊嚑涓�", len(args.RuleResult["face"].([]Arg)))
@@ -721,25 +450,12 @@
 		//logger.Info("瑙勫垯鐨勭畻娉昳d鍜屽尯鍩熺殑绠楁硶id锛�", rule.SdkId, "===", am.sdkId)
 		if rule.PolygonId == am.areaId { // 绠楁硶鍜屽尯鍩熼兘寰楀鐨勪笂
 
-			if rule.SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && rule.SdkArgAlias != "time_rule" && rule.SdkArgAlias != "compareBase"{
-				argValue, err := strconv.ParseFloat(rule.SdkArgValue, 64)
+			if rule.SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && rule.SdkArgAlias != "time_rule" && rule.SdkArgAlias != "compareBase" {
 				if err != nil {
 					logger.Error("瑙勫垯閰嶇疆鐨勯槇鍊奸潪娉�")
 					return LittleRuleResult{am.sdkName, rule.RuleWithPre + "" + "false", rule.Sort}
 				}
 				flag := "false"
-				for _, obj := range am.filterData {
-					for index := 0; index < len(obj.Liker); {
-						// 灏嗚揪涓嶅埌闃堝�肩殑鐩镐技鑰呬粠鐩镐技鑰呮暟缁勪腑鍒犻櫎
-						logger.Debug("=======================鐩镐技鍊硷細", float64(obj.Liker[index].CompareScore*100))
-						if float64(obj.Liker[index].CompareScore*100) < argValue {
-							// Go 璇█涓垏鐗囧垹闄ゅ厓绱犵殑鏈川鏄細浠ヨ鍒犻櫎鍏冪礌涓哄垎鐣岀偣锛屽皢鍓嶅悗涓や釜閮ㄥ垎鐨勫唴瀛橀噸鏂拌繛鎺ヨ捣鏉ャ�備笉鐢ㄦ��鐤戯紝鏁扮粍鍒犻櫎鍏冪礌灏辫繖涔堝潙鐖�
-							obj.Liker = append(obj.Liker[:index], obj.Liker[index+1:]...)
-						} else {
-							index++
-						}
-					}
-				}
 				// 鎶婃病鏈夌浉浼艰�呯殑浜鸿劯浠巉ilterData涓垹闄�
 				for index := 0; index < len(am.filterData); {
 					// 灏嗚揪涓嶅埌闃堝�肩殑鐩镐技鑰呬粠鐩镐技鑰呮暟缁勪腑鍒犻櫎
@@ -817,7 +533,7 @@
 				}
 				// 鍏堟竻绌鸿繃婊ゅ悗鐨勬暟鎹紝鍐嶅線閲屽鏈杩囨护鍚庣殑鏁版嵁
 				am.filterData = am.filterData[0:0]
-				logger.Debug("鐪嬬湅args锛氾細锛氾細锛�",args)
+				logger.Debug("鐪嬬湅args锛氾細锛氾細锛�", args)
 				for _, arg := range args {
 					var formula string
 					if rule.SdkArgAlias == "score" {
@@ -854,7 +570,7 @@
 }
 
 // 濡傛灉鏈夋寔缁椂闂存潯浠剁淮鎶ゅ紑鍚竴涓畾鏃跺櫒
-func duration(rule *protomsg.Rule, groupId string, am *AreaMap, args *SdkDatas) {
+func duration(rule *protomsg.Rule, groupId string, am *AreaMap, args *SdkDatas, message *protomsg.SdkMessage) {
 	if rule.PolygonId == am.areaId { // 棣栧厛瑙勫垯鎵�瀵瑰簲鐨勫尯鍩焛d瑕佽窡鍖哄煙鏁版嵁鐨刬d瀵圭殑涓�  閰嶇疆鐨勭畻娉曡瀵圭殑涓�
 		if rule.SdkArgAlias == "duration" { //
 			// 鍏堢湅鐪嬪畾鏃跺櫒鍏冪礌闃熷垪涓槸鍚︽湁杩欎釜鎽勫儚鏈鸿繖涓尯鍩熺殑瀹氭椂鍣�,濡傛灉鏈夊氨涓嶈兘鍐嶆鍒涘缓浜�
@@ -868,7 +584,7 @@
 
 			if flag {
 				timeLength, _ := strconv.Atoi(rule.SdkArgValue)
-				timeEle := TimeElement{N: timeLength, InitN: timeLength, AlarmFlag: false, CacheSdkData: *args} // 鎵旇繘鍘讳竴涓畾鏃跺櫒鍏冪礌锛堝苟缂撳瓨褰撳墠鐢婚潰甯ф暟鎹級
+				timeEle := TimeElement{N: timeLength, InitN: timeLength, AlarmFlag: false, BufferFlag: 10, CacheSdkData: ResultMsg{message, args.RuleResult}} // 鎵旇繘鍘讳竴涓畾鏃跺櫒鍏冪礌锛堝苟缂撳瓨褰撳墠鐢婚潰甯ф暟鎹級
 				//TimeEleList = make(map[string]timeElement)
 				TimeEleList[groupId+" "+rule.Id] = &timeEle // 瀹氭椂鍣ㄥ厓绱犱互鎽勫儚鏈篿d鎷兼帴鍖哄煙id涓洪敭
 				logger.Info("鍒涘缓浜嗚鏁板櫒骞朵笖璁℃暟鍣ㄩ泦鍚堜负锛�", TimeEleList)
@@ -968,41 +684,4 @@
 		}
 	}
 	return LittleRuleResult{}
-}
-
-// 鏍规嵁浼犲叆鐨勫瓧绗︿覆寰楀埌鍏跺湪涓�鍛ㄥ唴鐨勭储寮� 鍛ㄤ竴鍒板懆鏃ュ垎鍒搴�1鍒�7
-func getIndexOfWeek(weekday string) int {
-	var weekdays = [7]string{"Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"}
-	for k, value := range weekdays {
-		if value == weekday {
-			return k + 1 // 鍥犱负鏁版嵁搴撲腑瀛樼殑鏄�1-7浠h〃鐨勫懆涓�鍒板懆鏃�
-		}
-	}
-	return 0
-}
-
-type TimeRange struct {
-	Start string `json:"start"`
-	End   string `json:"end"`
-}
-type day struct {
-	Day       int         `json:"day"`        // 鏍囩ず褰撳墠鏄熸湡鍑�
-	TimeRange []TimeRange `json:"time_range"` // 褰撳ぉ鐨勫嚑涓椂闂存
-}
-
-// 鍙栧嚭鏌愪釜鏃堕棿瑙勫垯鐨勭鍑犲ぉ鐨勮鍒欐闆嗗悎
-func GetTimeById(id string, index int) []TimeRange {
-	_, cameraTimeRule := cache.GetTimeRuleById(id)
-	var timeRangeList []day
-	err := json.Unmarshal([]byte(cameraTimeRule.TimeRule), &timeRangeList)
-	if err != nil {
-		logger.Error("鍙栨椂闂磋鍒欐椂鍙嶅簭鍒楀寲閿欒锛�")
-	}
-	for _, timerange := range timeRangeList {
-		if timerange.Day == index {
-			//logger.Println("鍙栧埌鐨勬椂闂磋鍒欙細", timerange.TimeRange)
-			return timerange.TimeRange
-		}
-	}
-	return nil
 }

--
Gitblit v1.8.0