---
panlei
2019-12-16 44d5e620bf62e4b1c70f16af980738d5c4c7d517
algorithm/middleware/middleware.go
@@ -73,8 +73,9 @@
               //logger.Info("当前走的规则是--:", groupRule.Rules[j],sdkName,groupRule.Rules[j].SdkArgAlias, "---","")
               for _, areaMap := range sdkData.AreaMapList {
                  ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message)
                  if groupRule.Rules[j].RuleWithPre == "contain" {
                     assembleDta(args,groupRule.Rules[j-1],groupRule.Rules[j])
                  logger.Info("前置连接符:",groupRule.Rules[j])
                  if groupRule.Rules[j].RuleWithPre == "⊇" && len(ruleResult.Target) > 0 {
                     assembleDta(resultSplice[len(resultSplice)-1].Target,ruleResult.Target)
                     // 把当前小规则结果置空
                     ruleResult = structure.LittleRuleResult{}
                  }
@@ -329,7 +330,7 @@
                  break
               }
            }
            return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort}
            return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + flag, Sort:rule.Sort}
         }
         if rule.Operator == "unsatisfy" || rule.Operator == "!=" { // 不满足所选的时间规则
@@ -349,7 +350,7 @@
                  break
               }
            }
            return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort}
            return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + flag, Sort:rule.Sort}
         }
      }
@@ -376,7 +377,7 @@
      soName = "static.so"
   case "812b674b-2375-4589-919a-5c1c3278a978":
      soName = "plate.so"
   case "人体跟踪":
   case "520af340-f257-4fe2-ac3c-695c390e53dc":
      soName = "personTrack.so"
   }
   //soInfo,err := cache.GetSoInfoById(sdkId)
@@ -461,44 +462,30 @@
//   }
//}
func assembleData(args *structure.SdkDatas,resultSplice []*structure.LittleRuleResult,groupRule protomsg.GroupRule) {
   for index,result := range resultSplice {
      if strings.Contains(result.Result,"contain") {
         assembleDta(args,groupRule.Rules[index-1],groupRule.Rules[index])
         // 删除带有contain的规则结果
         resultSplice = append(resultSplice[:index],resultSplice[index+1:]...)
//func assembleData(args *structure.SdkDatas,resultSplice []*structure.LittleRuleResult,groupRule protomsg.GroupRule) {
//   for index,result := range resultSplice {
//      if strings.Contains(result.Result,"contain") {
//         assembleDta(args,groupRule.Rules[index-1],groupRule.Rules[index])
//         // 删除带有contain的规则结果
//         resultSplice = append(resultSplice[:index],resultSplice[index+1:]...)
//      }
//   }
//}
// 如果规则组中有包含符号,把规则组之后的规则对应的算法和区域提取的数据装配到前面去
func assembleDta(targets1,targets2 []*structure.Arg) {
   if len(targets1) > 0 {
      logger.Info("有人体:",len(targets1))
      for _,target := range targets1 {
         mergeArg(target,targets2)
         targets2 = nil
         return // 装配一次就可以
      }
   }
}
// 如果规则组中有包含符号,把规则组之后的规则对应的算法和区域提取的数据装配到前面去
func assembleDta(args *structure.SdkDatas,rule1,rule2 *protomsg.Rule) {
      // 拿到后面的那个区域的数据
      area := structure.AreaMap{}
      for _, sdkData := range args.Sdkdata {
         for _, areaMap := range sdkData.AreaMapList {
            if areaMap.SdkId == rule2.SdkId && areaMap.AreaId == rule2.PolygonId {
               area = *areaMap
               goto second
            }
         }
      }
second:   for _, sdkData := range args.Sdkdata {
         for _, areaMap := range sdkData.AreaMapList {
            if areaMap.SdkId == rule1.SdkId && areaMap.AreaId == rule1.PolygonId {
               // 拿到包含符之前的数据,遍历装配
               for _,arg := range areaMap.FilterData {
                  mergeArg(arg,area)
               }
               // 清空人脸,人脸不再单独插入了
               area.FilterData = nil
               return // 装配一次就可以
            }
         }
      }
}
func mergeArg(arg *structure.Arg,areaMap structure.AreaMap) {
   for _,arg1 := range areaMap.FilterData {
func mergeArg(arg *structure.Arg,targets2 []*structure.Arg) {
   for _,arg1 := range targets2 {
      logger.Info("人脸:",arg1.Location,arg1.Score)
      precent := ruleserver.PgsInterPercent(Rect2Point(arg.Location),arg1.Location,1,1)
      if precent > 99 {
         arg.AttachArg = arg1.SourceArg