From bcebdcfdc1a41422bf1b6a35c5bfacfb22e5b420 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期三, 17 七月 2019 17:11:26 +0800
Subject: [PATCH] 加入人脸追踪[C

---
 go.sum                         |    2 
 go.mod                         |    2 
 main.go                        |    8 +-
 ruleserver/personTrack.go      |   94 +++++++++++++++++++++++++++++++
 ruleserver/readyDataForRule.go |   16 +++--
 5 files changed, 111 insertions(+), 11 deletions(-)

diff --git a/go.mod b/go.mod
index 5f24da0..e66c9e0 100644
--- a/go.mod
+++ b/go.mod
@@ -5,7 +5,7 @@
 require (
 	basic.com/dbapi.git v0.0.0-20190701055817-73bca225181f
 	basic.com/pubsub/cache.git v0.0.0-20190712095028-e73efb4afc3b
-	basic.com/pubsub/protomsg.git v0.0.0-20190712081201-5a482419c227
+	basic.com/pubsub/protomsg.git v0.0.0-20190717072554-576620e5ba07
 	basic.com/pubsub/sdkcompare.git v0.0.0-20190715013640-f536a4647d00
 	basic.com/valib/deliver.git v0.0.0-20190531095353-25d8c3b20051
 	basic.com/valib/gopherdiscovery.git v0.0.0-20190605034340-15d89d8b4e28
diff --git a/go.sum b/go.sum
index 277e93e..be748aa 100644
--- a/go.sum
+++ b/go.sum
@@ -6,6 +6,8 @@
 basic.com/pubsub/protomsg.git v0.0.0-20190709070734-b34c868adcc2/go.mod h1:un5NV5VWQoblVLZfx1Rt5vyLgwR0jI92d3VJhfrJhWU=
 basic.com/pubsub/protomsg.git v0.0.0-20190712081201-5a482419c227 h1:1jprxyxmeQ8X4/S7cFnhRf4ByVqD0xLZNvx8/0xTk2k=
 basic.com/pubsub/protomsg.git v0.0.0-20190712081201-5a482419c227/go.mod h1:un5NV5VWQoblVLZfx1Rt5vyLgwR0jI92d3VJhfrJhWU=
+basic.com/pubsub/protomsg.git v0.0.0-20190717072554-576620e5ba07 h1:ZeiaQTNSB6K5ASpcwYtk0bWabMQX0r2JX/5agzTznRs=
+basic.com/pubsub/protomsg.git v0.0.0-20190717072554-576620e5ba07/go.mod h1:un5NV5VWQoblVLZfx1Rt5vyLgwR0jI92d3VJhfrJhWU=
 basic.com/pubsub/sdkcompare.git v0.0.0-20190715013640-f536a4647d00 h1:sK+Tx7rvM9J2WnNIwrzMDjZSylWiKNfQO0prUBfKsDk=
 basic.com/pubsub/sdkcompare.git v0.0.0-20190715013640-f536a4647d00/go.mod h1:8by33F9E1w17Pw/rDgJGJXAo122w0wDENG14hiMS+RE=
 basic.com/valib/deliver.git v0.0.0-20190531095353-25d8c3b20051 h1:9flC2o3kasaM2Y6I+mY+mxmve/pyAY/UzGQZLT3lFHM=
diff --git a/main.go b/main.go
index e433cbc..c536279 100644
--- a/main.go
+++ b/main.go
@@ -105,6 +105,8 @@
 	if err != nil {
 		panic("瑙f瀽msg鏃跺嚭鐜伴敊璇�")
 	}
+	// 鍏堣繘琛屼竴涓嬭拷韪�
+	ruleserver.IsSame(&m)
 	args.CameraId = m.Cid
 	args.TaskId = m.Tasklab.Taskid
 	// 鎶婂浘鐗囩殑浜岃繘鍒惰В鍘嬬缉杩涜鐢绘鍦ㄥ帇缂╁洖鍘�
@@ -140,7 +142,7 @@
 					logger.Info("瑙f瀽YOLO sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
 					continue
 				}
-				//logger.Info("--------------鐪嬬湅yolo涓湁鍑犱釜鐩爣锛�",len(yoloParam.Infos))
+				logger.Info("--------------杩借釜涔嬪悗yolo鐨勪釜鏁帮細",len(yoloParam.Infos))
 				for _, info := range yoloParam.Infos {
 					if info.Typ == 0 {
 						//logger.Debug("-------------yolo鐨勫潗鏍囨湁鍑犱釜",info.RcObj)
@@ -177,9 +179,9 @@
 					logger.Info("瑙f瀽FACE sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
 					continue
 				}
-				logger.Info("--------------鐪嬬湅浜鸿劯妫�娴嬩腑鏈夊嚑涓洰鏍囷細",len(faceParam.Faces))
+				logger.Info("--------------杩借釜涔嬪悗yolo鐨勪釜鏁帮細",len(faceParam.Faces))
 				for _, info := range faceParam.Faces {
-					logger.Info("_______________________________________________绗竴娆$湅鐩镐技鍊硷細",info.Pos.FAngle.Confidence*100)
+					//logger.Info("_______________________________________________绗竴娆$湅鐩镐技鍊硷細",info.Pos.FAngle.Confidence*100)
 					photoMap := ruleserver.PhotoMap{Rects: rectFormat(info.Pos.RcFace), Score: float64(info.Pos.FAngle.Confidence*100), IsYolo:false,ThftRes:*(info.Result),Feature:info.Feats}
 					arg.Photo = append(arg.Photo, photoMap)
 				}
diff --git a/ruleserver/personTrack.go b/ruleserver/personTrack.go
new file mode 100644
index 0000000..a819dda
--- /dev/null
+++ b/ruleserver/personTrack.go
@@ -0,0 +1,94 @@
+package ruleserver
+
+import (
+	"basic.com/pubsub/protomsg.git"
+	"github.com/golang/protobuf/proto"
+	"ruleprocess/logger"
+)
+
+var TrackPond = make(map[string]*PersonTrack)
+
+type PersonTrack struct {
+	Face int // 浜鸿劯鐨刬d鏁扮粍  鏀逛负鏁伴噺
+	Yolo int // yolo瀵硅薄鐨刬d鏁扮粍 鏀逛负鏁伴噺
+}
+
+func (pt *PersonTrack) Set(msg protomsg.SdkMessage) {
+
+}
+
+// 妫�鏌ユ槸鍚﹀墠鍚庝袱娆$殑鏁版嵁id鏄惁瀹屽叏鐩稿悓锛堜汉鑴稿拰yolo锛�
+func IsSame(msg *protomsg.SdkMessage) {
+	logger.Debug("++++++++++++++++++++++++++++杩借釜寮�濮�++++++++++++++++++++++++")
+	for _, sdkinfo := range msg.Tasklab.Sdkinfos { // 閬嶅巻鍚勭畻娉曠殑sdkData
+		if sdkinfo.Sdktype == "FaceDetect" { // 浜鸿劯妫�娴�
+			if len(sdkinfo.Sdkdata) > 1 {
+				faceParam := protomsg.ParamFacePos{}
+				err := proto.Unmarshal(sdkinfo.Sdkdata, &faceParam)
+				if err != nil {
+					logger.Info("瑙f瀽face sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
+					continue
+				}
+				logger.Info("================杩借釜涔嬪墠浜鸿劯鐨勪釜鏁帮細",len(faceParam.Faces))
+				if len(faceParam.Faces) == TrackPond[msg.Cid].Yolo { // yolo鐨勫鏋滄暟閲忕浉鍚屽垯瑙嗕负涓嶅彉銆佹妸yolo鐨剆dkData娓呯┖
+					faceParam.Faces = (faceParam.Faces)[0:0]
+				} else {
+					TrackPond[msg.Cid].Face = len(faceParam.Faces)
+				}
+				//for i := 0;  i < len(faceParam.Faces); {
+				//	if flag := IsInPond(msg.Cid,faceParam.Faces[i]);flag { // 宸茬粡瀛樺湪锛屼粠msg鐨勪汉鑴告暟缁勪腑鍒犻櫎杩欎釜鍏冪礌锛屼笉蹇呬紶鍒颁笅涓�涓幆鑺�
+				//		faceParam.Faces = append(faceParam.Faces[:i], faceParam.Faces[i+1:]...)
+				//	} else {
+				//		i++
+				//	}
+				//}
+			} else {
+				continue
+			}
+		}
+		if sdkinfo.Sdktype == "Yolo" {
+			if len(sdkinfo.Sdkdata) > 1 {
+				yoloParam := protomsg.ParamYoloObj{}
+				err := proto.Unmarshal(sdkinfo.Sdkdata, &yoloParam)
+				if err != nil {
+					logger.Info("瑙f瀽yolo鏁版嵁鏃跺嚭鐜伴敊璇�", err)
+					continue
+				}
+				logger.Info("================杩借釜涔嬪墠yolo鐨勪釜鏁帮細",len(yoloParam.Infos))
+				if len(yoloParam.Infos) == TrackPond[msg.Cid].Yolo { // yolo鐨勫鏋滄暟閲忕浉鍚屽垯瑙嗕负涓嶅彉銆佹妸yolo鐨剆dkData娓呯┖
+					yoloParam.Infos = (yoloParam.Infos)[0:0]
+				} else {
+					TrackPond[msg.Cid].Yolo = len(yoloParam.Infos)
+				}
+			} else {
+				continue
+			}
+		}
+	}
+	logger.Debug("---------------------------------------杩借釜缁撴潫--------------------------------------")
+}
+//// 鍒ゆ柇涓�涓汉鑴竔d鍦ㄤ笉鍦ㄨ拷韪睜涓�
+//func FaceIsInPond(cameraId string,face *protomsg.ResultFaceDetect) bool{
+//	if TrackPond[cameraId].Face > 0 {
+//		for key,val := range TrackPond  {
+//			if key == cameraId {
+//				faceFlag := false
+//				for faceId := range val.Face  {
+//					if face.Pos.FaceID == uint64(faceId) { // 姝や汉鑴稿凡鍦ㄦ睜瀛愪腑锛屼笉闇�瑕佸畠鍒颁笅涓�涓幆鑺備簡
+//						faceFlag = true
+//						return true
+//					}
+//				}
+//				if !faceFlag { // 姝や汉鑴镐笉鍦ㄦ睜瀛愪腑
+//					val.Face = append(val.Face,face.Pos.FaceID)
+//					return false
+//				}
+//			}else {
+//				return false
+//			}
+//		}
+//	} else {
+//		return false
+//	}
+//	return false
+//}
\ No newline at end of file
diff --git a/ruleserver/readyDataForRule.go b/ruleserver/readyDataForRule.go
index 7bdbaa5..100ba1e 100644
--- a/ruleserver/readyDataForRule.go
+++ b/ruleserver/readyDataForRule.go
@@ -132,13 +132,15 @@
 	}
 	logger.Info("------------------------------------------------------------------------------------------------------------------------")
 	logger.Info("=====================浜哄憳id鐨勯泦鍚堜负锛�",ids)
-	baseinfos, err1 := esutil.Dbpersoninfosbyid(ids)
-	if err1 != nil {
-		logger.Error("鏌ヨ搴曞簱浜哄憳淇℃伅鍑洪敊", err1)
-	}
-	logger.Debug("----------------++++++++++++++++++++搴曞簱浜哄憳淇℃伅锛�",baseinfos)
-	for _,baseinfo := range baseinfos  {
-		logger.Info("---------鐪嬬湅姣忎釜搴曞簱浜哄憳鐨勪俊鎭細",baseinfo)
+	if len(ids) > 0 {
+		baseinfos, err1 := esutil.Dbpersoninfosbyid(ids)
+		if err1 != nil {
+			logger.Error("鏌ヨ搴曞簱浜哄憳淇℃伅鍑洪敊", err1)
+		}
+		logger.Debug("----------------++++++++++++++++++++搴曞簱浜哄憳淇℃伅锛�",baseinfos)
+		for _,baseinfo := range baseinfos  {
+			logger.Info("---------鐪嬬湅姣忎釜搴曞簱浜哄憳鐨勪俊鎭細",baseinfo)
+		}
 	}
 	//baseinfo.CompareScore = Retain(val)
 	//arg.Liker = append(arg.Liker, &baseinfo)

--
Gitblit v1.8.0