From 41b20ac009fa308d9f744952a434afac2193e3fb Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期二, 25 六月 2019 14:01:14 +0800
Subject: [PATCH] ---

---
 ruleserver/ruleToformula.go |   41 +++++++++++++++++++++++++++++------------
 1 files changed, 29 insertions(+), 12 deletions(-)

diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go
index e4be299..a9e7e39 100644
--- a/ruleserver/ruleToformula.go
+++ b/ruleserver/ruleToformula.go
@@ -3,6 +3,7 @@
 import (
 	"encoding/json"
 	"fmt"
+	"log"
 	"sort"
 	"strconv"
 	"strings"
@@ -60,6 +61,12 @@
 	score      float64 // 鍖哄煙鍐呯殑鐩爣鐨勭浉浼煎害
 	proportion float64 // 鍖哄煙鍐呯殑鐩爣鐨勫崰姣�
 	size       float64 // 鍖哄煙鍐呯殑鐩爣鐨勫昂瀵�
+	liker      []LikePerson
+}
+
+type LikePerson struct {
+	Id    string  // 涓庝箣鐩镐技鐨勫簳搴撲汉鍛樼殑id
+	Score float64 // 涓庡簳搴撲汉鍛樼殑鐩镐技鍊�
 }
 
 // 姣忎釜鍖哄煙鍐呯殑鍥剧墖鏁版嵁闆嗗悎
@@ -83,7 +90,8 @@
 // sdk杈撳嚭鐨勫浘鐗囦笂鍗曚釜鐩爣鐨勬暟鎹�
 type PhotoMap struct {
 	Rects Rect    // 鐭╁舰鍖哄煙鍙傛暟
-	Score float64 // 鐩镐技搴﹀緱鍒�
+	Score float64 // 鐩镐技搴﹀緱鍒嗭紙鏈夊澶х▼搴﹀儚涓�涓洰鏍囥�備汉鑴革紝浜轰綋鎴栬溅绛夌瓑锛�
+	Liker []LikePerson // 濡傛灉鏄汉鑴哥殑璇濆挨鍏舵槸姣斿锛屽簲瀛樹笅浠栬窡搴曞簱鐨勪汉鍛樼殑鐩镐技鎯呭喌 yolo鐨勮瘽缁檔il灏辫
 }
 
 // 浠庨�氶亾涓幏鍙栫殑sdk杈撳嚭鐨勫浘鍍忔暟鎹�(鐩墠涓昏鏄痽olo绠楁硶鐨勬暟鎹�)
@@ -110,7 +118,7 @@
 type Result struct {
 	TaskId      string // 浠诲姟id
 	RuleGroupId string // 瑙勫垯缁刬d
-	AlarmLevel  int32 // 鎶ヨ绛夌骇
+	AlarmLevel  int32  // 鎶ヨ绛夌骇
 	RuleText    string // 鏂囧瓧鐗堣鍒欑粍
 }
 
@@ -176,6 +184,7 @@
 			// 杩欐瑕佸榻愯〃杈惧紡閲屾墍闇�瑕佺殑鎵�鏈夊弬鏁�
 			a.targetNum++
 			arg := Arg{score: obj.Score, proportion: PgsInterPercent(areaPoints, obj.Rects, widthScale, heigthScale), size: float64(obj.Rects.Width * obj.Rects.Height)}
+			log.Println("鏀捐繘鍘荤殑arg锛�-------",arg)
 			a.args = append(a.args, arg)
 			a.filterData = append(a.filterData, arg)
 		}
@@ -189,10 +198,10 @@
 func Json2points(areaPoints string) []Point {
 	var pts []Point
 	if areaPoints == "" {
-		pts = append(pts,Point{0,0})
-		pts = append(pts,Point{0,540})
-		pts = append(pts,Point{960,540})
-		pts = append(pts,Point{960,0})
+		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 {
@@ -301,6 +310,7 @@
 func singleTask(aml *AreaMapList, arg *ArgsFromSdk, groupRule *protomsg.GroupRule, taskId string) bool {
 	var completeFormula string = ""
 	for _, areaMap := range aml.areaMapList {
+		//fmt.Println("褰撳墠瑙勫垯缁勪负---------锛�",groupRule)
 		for j := 0; j < len(groupRule.Rules); j++ {
 			// 鍏堣繃瀹屾潯浠舵暟鎹�
 			filterRule(groupRule.Rules[j], &areaMap)
@@ -339,7 +349,7 @@
 	if completeFormula != "" {
 		expression, _ := govaluate.NewEvaluableExpression(completeFormula)
 		result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋�
-		fmt.Println("杩欏抚鍥惧儚鍦ㄤ换鍔′笅鐨勯櫎浜嗘寔缁椂闂村鐨勪竴鏁存潯瑙勫垯涓嬬殑鍒ゆ柇缁撴灉", result)
+		//fmt.Println("杩欏抚鍥惧儚鍦ㄤ换鍔′笅鐨勯櫎浜嗘寔缁椂闂村鐨勪竴鏁存潯瑙勫垯涓嬬殑鍒ゆ柇缁撴灉", result)
 		// 鐢变簬澶╃劧鎴栫殑鍏崇郴锛屾弧瓒充竴涓氨璇ユ姤璀�,鍗宠甯ф暟鎹浜庢煇涓换鍔$殑鏌愪釜瑙勫垯缁勫簲璇ユ姤璀�
 		if !result.(bool) { // 濡傛灉涓嶇鍚堟潯浠讹紝搴旇閲嶇疆瀹氭椂鍣ㄥ厓绱狅紝绛夌鍚堟椂鍐嶅紑鍚�,鎶妅ey涓寘鍚换鍔d鐨則imeEle閮介噸缃�
 			for k, timeEle := range TimeEleList {
@@ -361,7 +371,7 @@
 			if flag {
 				fmt.Println("瀹氭椂鍣ㄦ姤璀︿簡")
 				// 杩囧畬瑙勫垯鍚庢墦涓爣绛撅紝鍛婅瘔璋冪敤鑰呮湰甯ф暟鎹拡瀵瑰摢涓换鍔″摢缁勮鍒欐姤璀︿簡
-				arg.RuleResult = append(arg.RuleResult, Result{taskId, groupRule.GroupId,groupRule.AlarmLevel,groupRule.GroupText})
+				arg.RuleResult = append(arg.RuleResult, Result{taskId, groupRule.GroupId, groupRule.AlarmLevel, groupRule.GroupText})
 				return true
 			} else {
 				return false
@@ -409,17 +419,19 @@
 			}
 			// 鍏堟竻绌鸿繃婊ゅ悗鐨勬暟鎹紝鍐嶅線閲屽鏈杩囨护鍚庣殑鏁版嵁
 			am.filterData = am.filterData[0:0]
+			log.Println("鐪嬩竴涓嬪綋鍓嶅皬瑙勫垯锛�",*rule)
 			for _, arg := range args {
 				var formula string
 				if rule.SdkArgAlias == "score" {
 					formula = strconv.FormatFloat(arg.score, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
 				} else if rule.SdkArgAlias == "proportion" {
 					formula = strconv.FormatFloat(arg.proportion, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
+					fmt.Println("鍗犳瘮鐨勫瓧绗︿覆鍏紡锛�--------",formula)
 				} else {
 					formula = strconv.FormatFloat(arg.size, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
 				}
 				expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡
-				result, _ := expression.Evaluate(nil)          // 寰楀埌鏁板鍏紡鐨勭粨鏋�
+				result, _ := expression.Evaluate(nil)                      // 寰楀埌鏁板鍏紡鐨勭粨鏋�
 				if result.(bool) {
 					am.filterData = append(am.filterData, arg) // 寰楀埌绗﹀悎鏉′欢鐨勮繃婊ゆ暟鎹�
 				}
@@ -452,14 +464,17 @@
 		}
 	}
 }
+
 // 鍐椾綑鎷兼帴
-func splice1 (am *AreaMap) string {
+func splice1(am *AreaMap) string {
 	args := am.targetNum
-	formula := strconv.Itoa(args) + " "  + ">" + "0"
+	log.Println("鐪嬬湅鍖哄煙鍐呯洰鏍囨暟閲忥細----------",args)
+	formula := strconv.Itoa(args) + " " + ">" + "0"
 	expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡
 	result, _ := expression.Evaluate(nil)                      // 寰楀埌鏁板鍏紡鐨勭粨鏋�
 	return strconv.FormatBool(result.(bool))
 }
+
 // 缁欐暟鎹簱鐨勮鍒欒〃杈惧紡浠e弬 args: 涓�鏉″瓙瑙勫垯锛屽尯鍩熸暟鎹�
 func transferParameters(rule *protomsg.Rule, am *AreaMap) string {
 	if rule.PolygonId == am.areaId { // 棣栧厛瑙勫垯鎵�瀵瑰簲鐨勫尯鍩焛d瑕佽窡鍖哄煙鏁版嵁鐨刬d瀵圭殑涓�
@@ -489,11 +504,13 @@
 		} else if rule.SdkId == "FaceDetect" { // 浜鸿劯妫�娴�
 			if rule.Operator == "==" || rule.Operator == ">=" || rule.Operator == "<=" || rule.Operator == "<" || rule.Operator == ">" || rule.Operator == "!=" {
 				// 濡傛灉鏄笉瑙勭煩鐨勮繛鎺ョ缁熺粺杩斿洖false 瑙勫垯涔熷彧鑳藉垽鏂汉鑴哥殑鐩镐技搴︼紝鎵�浠ヤ笉瀛樺湪鍒殑杩炴帴绗�
+
 				return "false"
 			} else {
 				return "false"
 			}
-		} else {
+		} else if rule.SdkId == "FaceCompare"{
+			// 鍙渶瑕佽繃婊ら槇鍊硷紝杩囨护瀹屽悗鏁扮粍闀垮害澶т簬0鍗充负鎶ヨ锛屼絾濡備綍瀵规瘡涓�寮犻兘鎶ヨ鍛�
 
 		}
 

--
Gitblit v1.8.0