| | |
| | | //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 == "⊇" { |
| | | 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{} |
| | | } |
| | |
| | | } |
| | | } |
| | | // 人脸 |
| | | //for j := 0; j < len(groupRule.Rules); j++ { |
| | | // if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && groupRule.Rules[j].SdkArgAlias != "time_rule"{ |
| | | // for _, sdkData := range args.Sdkdata { |
| | | // // 根据规则的sdkId查出其对应的ipcId,用ipcId去找该比对的数据 |
| | | // sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId) |
| | | // if err != nil { |
| | | // logger.Error("没查到sdk的信息---", err) |
| | | // } |
| | | // ipcId := sdk.IpcId |
| | | // sdkName := sdk.SdkName |
| | | // //logger.Info("规则的ipcId与sdkData的IpcId:", ipcId, "===", sdkData.IpcId) |
| | | // if ipcId == sdkData.IpcId { |
| | | // //logger.Info("当前走的规则是--:", sdkName, "---","") |
| | | // for _, areaMap := range sdkData.AreaMapList { |
| | | // ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message) |
| | | // if ruleResult.Result != "" { |
| | | // //logger.Info("人脸比对规则结果:", ruleResult.Result) |
| | | // // 如果结果为真,把这条规则中的区域置为有效 |
| | | // if strings.Contains(ruleResult.Result, "true") { |
| | | // areaMap.IsEffective = true |
| | | // } |
| | | // // 如果此结果为真且当前过的是yolo算法,应记下此规则所对应的sdkName,另外,还要去重 (后加:把此条触碰的区域id也记录下来) |
| | | // if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(sdkNames, sdkName) { |
| | | // sdkNames = sdkName + " " |
| | | // } |
| | | // if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(polygonId, groupRule.Rules[j].PolygonId) { |
| | | // polygonId += groupRule.Rules[j].PolygonId + "," |
| | | // } |
| | | // resultSplice = append(resultSplice, &ruleResult) |
| | | // } |
| | | // } |
| | | // } |
| | | // } |
| | | // } |
| | | //} |
| | | for j := 0; j < len(groupRule.Rules); j++ { |
| | | if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && groupRule.Rules[j].SdkArgAlias != "time_rule"{ |
| | | for _, sdkData := range args.Sdkdata { |
| | | // 根据规则的sdkId查出其对应的ipcId,用ipcId去找该比对的数据 |
| | | sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId) |
| | | if err != nil { |
| | | logger.Error("没查到sdk的信息---", err) |
| | | } |
| | | ipcId := sdk.IpcId |
| | | sdkName := sdk.SdkName |
| | | //logger.Info("规则的ipcId与sdkData的IpcId:", ipcId, "===", sdkData.IpcId) |
| | | if ipcId == sdkData.IpcId { |
| | | //logger.Info("当前走的规则是--:", sdkName, "---","") |
| | | for _, areaMap := range sdkData.AreaMapList { |
| | | ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message) |
| | | if ruleResult.Result != "" { |
| | | //logger.Info("人脸比对规则结果:", ruleResult.Result) |
| | | // 如果结果为真,把这条规则中的区域置为有效 |
| | | if strings.Contains(ruleResult.Result, "true") { |
| | | areaMap.IsEffective = true |
| | | } |
| | | // 如果此结果为真且当前过的是yolo算法,应记下此规则所对应的sdkName,另外,还要去重 (后加:把此条触碰的区域id也记录下来) |
| | | if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(sdkNames, sdkName) { |
| | | sdkNames = sdkName + " " |
| | | } |
| | | if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(polygonId, groupRule.Rules[j].PolygonId) { |
| | | polygonId += groupRule.Rules[j].PolygonId + "," |
| | | } |
| | | resultSplice = append(resultSplice, &ruleResult) |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | // 个体静止 |
| | | for j := 0; j < len(groupRule.Rules); j++ { |
| | | if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a977" && groupRule.Rules[j].SdkArgAlias == "duration"{ |
| | |
| | | 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 == "!=" { // 不满足所选的时间规则 |
| | |
| | | break |
| | | } |
| | | } |
| | | return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + flag, rule.Sort} |
| | | return structure.LittleRuleResult{SdkName:am.SdkName, Result:rule.RuleWithPre + "" + flag, Sort:rule.Sort} |
| | | } |
| | | |
| | | } |
| | |
| | | // } |
| | | //} |
| | | // 如果规则组中有包含符号,把规则组之后的规则对应的算法和区域提取的数据装配到前面去 |
| | | func assembleDta(args *structure.SdkDatas,rule1,rule2 *protomsg.Rule) { |
| | | // 拿到后面的那个区域的数据 |
| | | logger.Info("触发了包含事件,把后者的数据给到前者") |
| | | 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 |
| | | } |
| | | } |
| | | func assembleDta(targets1,targets2 []*structure.Arg) { |
| | | if len(targets1) > 0 { |
| | | logger.Info("有人体:",len(targets1)) |
| | | for _,target := range targets1 { |
| | | mergeArg(target,targets2) |
| | | targets2 = nil |
| | | return // 装配一次就可以 |
| | | } |
| | | 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) |
| | | logger.Info("合并后的arg是:",*arg) |
| | | } |
| | | // 清空人脸,人脸不再单独插入了 |
| | | 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 |