---
panlei
2019-12-16 6bc7833cd5e47bf60805125a2cbb71ee6097ec28
algorithm/face/face.go
@@ -2,9 +2,9 @@
import (
   "basic.com/pubsub/protomsg.git"
   logger "github.com/jeanphorn/log4go"
   "github.com/knetic/govaluate"
   "ruleprocess/structure"
   "basic.com/valib/logger.git"
   "strconv"
)
// 人脸算法
@@ -29,7 +29,7 @@
               // 把没有相似者的人脸从filterData中删除
               for index := 0; index < len(am.FilterData); {
                  // 将达不到阈值的相似者从相似者数组中删除
                  logger.Info("看看相似者人数:",len(am.FilterData[index].Liker))
                  //logger.Info("看看相似者人数:",len(am.FilterData[index].Liker))
                  if len(am.FilterData[index].Liker) == 0 {
                     // Go 语言中切片删除元素的本质是:以被删除元素为分界点,将前后两个部分的内存重新连接起来。不用怀疑,数组删除元素就这么坑爹
                     am.FilterData = append(am.FilterData[:index], am.FilterData[index+1:]...)
@@ -40,8 +40,8 @@
               if len(am.FilterData) > 0 {
                  flag = "true"
               }
               logger.Info("---------人脸比对符合条件的数量为:",len(am.FilterData))
               return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort}
               //logger.Info("---------人脸比对符合条件的数量为:",len(am.FilterData))
               return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + flag, Sort:rule.Sort}
            }
         }
         if rule.SdkId == "812b674b-2375-4589-919a-5c1c3278a97e" { // 人脸检测
@@ -49,7 +49,7 @@
            if rule.Operator == "==" || rule.Operator == ">=" || rule.Operator == "<=" || rule.Operator == "<" || rule.Operator == ">" || rule.Operator == "!=" {
               // 如果是不规矩的连接符统统返回false 规则也只能判断人脸的相似度,所以不存在别的连接符
               if rule.SdkArgAlias == "score" || rule.SdkArgAlias == "proportion" || rule.SdkArgAlias == "size" { // 判断的是相似值,占比,尺寸等过滤条件,如果再有,还可以再加
                  logger.Info("-----------------------过规则之前区域内的人脸数量为:",am.TargetNum)
                  //logger.Info("-----------------------过规则之前区域内的人脸数量为:",am.TargetNum)
                  var args []*structure.Arg
                  if rule.RuleWithPre == "&&" {
                     args = am.FilterData
@@ -67,13 +67,13 @@
                     switch rule.SdkArgAlias {
                     case "score":
                        formula = strconv.FormatFloat(arg.Score, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue
                        logger.Info("相似度小公式:", formula)
                        //logger.Info("相似度小公式:", formula)
                     case "proportion":
                        formula = strconv.FormatFloat(arg.Proportion, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue
                        logger.Info("占比公式:", formula)
                        //logger.Info("占比公式:", formula)
                     case "size":
                        formula = strconv.FormatFloat(arg.Size, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue
                        logger.Info("尺寸小公式:", formula)
                        //logger.Info("尺寸小公式:", formula)
                     }
                     expression, _ := govaluate.NewEvaluableExpression(formula) // 得到数学公式
                     result, _ := expression.Evaluate(nil)                      // 得到数学公式的结果
@@ -82,23 +82,23 @@
                     }
                  }
                  am.TargetNum = len(am.FilterData) // 把符合条件的目标数量更新到targetNum字段
                  logger.Info("过完条件后的目标数量为:",am.TargetNum)
                  if am.TargetNum > 0 {
                     logger.Info("!!!!!!!!!人脸检测成功")
                     return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort}
                     return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + "true", Sort:rule.Sort,Target:am.FilterData}
                  } else {
                     return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort}
                     return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + "false", Sort:rule.Sort}
                  }
               }
            } else if rule.SdkArgAlias == "" { // 什么参数都不配的情况
               if am.TargetNum > 0 {
                  return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort}
                  return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + "true", Sort:rule.Sort,Target:am.FilterData}
               } else {
                  return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort}
                  return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + "false", Sort:rule.Sort}
               }
            }
         }
      }
   }
   return structure.LittleRuleResult{}
}
}