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