From eb6f08d1eea2430383ad486eca9d3a509db344bf Mon Sep 17 00:00:00 2001 From: panlei <2799247126@qq.com> Date: 星期二, 17 十二月 2019 10:04:21 +0800 Subject: [PATCH] 装配目标 --- algorithm/car/plate.go | 108 ++++++++++++++++++++++++------------------------------ 1 files changed, 48 insertions(+), 60 deletions(-) diff --git a/algorithm/car/plate.go b/algorithm/car/plate.go index e299a9a..d2b5f9b 100644 --- a/algorithm/car/plate.go +++ b/algorithm/car/plate.go @@ -1,22 +1,21 @@ package main import ( -"basic.com/pubsub/protomsg.git" -"basic.com/valib/logger.git" -"github.com/knetic/govaluate" -"ruleprocess/structure" -"strconv" + "basic.com/pubsub/protomsg.git" + "github.com/knetic/govaluate" + "ruleprocess/structure" + "strconv" ) // 杞︾墝绠楁硶 func Entrance(rule *protomsg.Rule, am *structure.AreaMap,lable *structure.Others,args *structure.SdkDatas,message *protomsg.SdkMessage) structure.LittleRuleResult { if rule.PolygonId == am.AreaId { // 棣栧厛杩欐潯瑙勫垯寰楁槸杩欎釜绠楁硶鐨勮鍒欙紝鍏舵瑙勫垯鎵�瀵瑰簲鐨勫尯鍩焛d瑕佽窡鍖哄煙鏁版嵁鐨刬d瀵圭殑涓� - if rule.SdkArgAlias != "nCarCount" && rule.SdkArgAlias != "nCarLogoCount" { - logger.Info("杩囨护杞︾墝淇℃伅") + if rule.SdkArgAlias != "nCarCount" { + //logger.Info("杩囨护杞︾墝淇℃伅") return filterRule(rule, am) } else { - logger.Info("璁$畻杞︾墝杞﹁締鏁伴噺") // 鐩墠鍙兘妫�娴嬪嚭杞︾墝鏁伴噺 + //logger.Info("璁$畻杞︾墝杞﹁締鏁伴噺") // 鐩墠鍙兘妫�娴嬪嚭杞︾墝鏁伴噺 return transferParameters(rule, am) } } else { @@ -29,12 +28,12 @@ // 杩囨护瑙勫垯鍏堢瓫閫夊嚭绗﹀悎鏉′欢鐨勭洰鏍囨暟閲� func filterRule(rule *protomsg.Rule, am *structure.AreaMap) structure.LittleRuleResult { // 澶勭悊鐨勯兘鏄痽olo鏁版嵁 - carFlag := rule.SdkArgAlias == "license" || rule.SdkArgAlias == "nColor" || rule.SdkArgAlias == "nConfidence" || - rule.SdkArgAlias == "nBright" || rule.SdkArgAlias == "nTime" || rule.SdkArgAlias == "nCarBright" || rule.SdkArgAlias == "nCarColor" || - rule.SdkArgAlias == "nCarLogo" || rule.SdkArgAlias == "nCarType" || rule.SdkArgAlias == "nCarModel" || rule.SdkArgAlias == "nCarModelConfidence" + carFlag := rule.SdkArgAlias == "license" || rule.SdkArgAlias == "nConfidence" || rule.SdkArgAlias == "fConfidence" || + rule.SdkArgAlias == "nType" || rule.SdkArgAlias == "nVehicleColor1" || rule.SdkArgAlias == "nVehicleBright" || rule.SdkArgAlias == "nCarColor" || + rule.SdkArgAlias == "fVDConf" || rule.SdkArgAlias == "nVehicleColor2" || rule.SdkArgAlias == "nColor" || rule.SdkArgAlias == "nPlateFlag" if rule.SdkArgAlias == "score" || rule.SdkArgAlias == "proportion" || rule.SdkArgAlias == "size" || carFlag{ // 鍒ゆ柇鐨勬槸鐩镐技鍊硷紝鍗犳瘮锛屽昂瀵哥瓑杩囨护鏉′欢锛屽鏋滃啀鏈夛紝杩樺彲浠ュ啀鍔� - logger.Debug("---------璧颁簡杞︾墝璇嗗埆杩囨护绠楁硶",rule.Id,rule.SdkArgAlias,rule.Operator,rule.SdkArgValue,am.AreaId) + //logger.Debug("---------璧颁簡杞︾墝璇嗗埆杩囨护绠楁硶",rule.Id,rule.SdkArgAlias,rule.Operator,rule.SdkArgValue,am.AreaId) var args []*structure.Arg if rule.RuleWithPre == "&&" { args = am.FilterData @@ -47,48 +46,36 @@ for _, arg := range args { var formula string switch rule.SdkArgAlias { - case "score": - formula = strconv.FormatFloat(arg.Score, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("鐩镐技搴﹀皬鍏紡锛�", formula) - case "proportion": - formula = strconv.FormatFloat(arg.Proportion, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("鍗犳瘮鍏紡锛�", formula) - case "size": - formula = strconv.FormatFloat(arg.Size, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("灏哄灏忓叕寮忥細", formula) - case "license": - formula = arg.Car.License + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("褰撳墠杞︾墝鍙风爜灏忓叕寮忥細", formula) - case "nColor": - formula = strconv.Itoa(int(arg.Car.NColor)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︾墝棰滆壊灏忓叕寮忥細", formula) - case "nConfidence": - formula = strconv.Itoa(int(arg.Car.NConfidence)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("鏁寸墝鍙俊搴﹀皬鍏紡锛�", formula) - case "nBright": - formula = strconv.Itoa(int(arg.Car.NBright)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︾墝浜害璇勪环灏忓叕寮忥細", formula) - case "nDirection": - formula = strconv.Itoa(int(arg.Car.NDirection)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︾墝杩愬姩鏂瑰悜灏忓叕寮忥細", formula) - case "nCarBright": - formula = strconv.Itoa(int(arg.Car.NCarBright)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︾殑浜害灏忓叕寮忥細", formula) - case "nCarColor": - formula = strconv.Itoa(int(arg.Car.NCarColor)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︾殑棰滆壊灏忓叕寮忥細", formula) - case "nCarLogo": - formula = strconv.Itoa(int(arg.Car.NCarLogo)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞︽爣绫诲瀷灏忓叕寮忥細", formula) - case "nCarType": - formula = strconv.Itoa(int(arg.Car.NCarType)) + " " + rule.Operator + " " + rule.SdkArgValue - logger.Info("杞﹁締绫诲瀷灏忓叕寮忥細", formula) - //case "nCarModel": - // formula = strconv.Itoa(int(arg.Car.ncm)) + " " + rule.Operator + " " + rule.SdkArgValue - // logger.Info("璇嗗埆鎴愬姛涓庡惁灏忓叕寮忥細", formula) - //case "nCarModelConfidence": - // formula = strconv.Itoa(int(arg.Car.NCarModelConfidence)) + " " + rule.Operator + " " + rule.SdkArgValue - // logger.Info("杞﹀瀷鍙俊搴﹀皬鍏紡锛�", formula) + case "fVDConf": + formula = strconv.FormatFloat(arg.Score, 'f', -1, 32) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁締缃俊搴﹀皬鍏紡锛�", formula) + case "nVehicleColor1": + formula = strconv.Itoa(int(arg.Car.NVehicleColor1)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁韩涓婚鑹插皬鍏紡锛�", formula) + case "nVehicleColor2": + formula = strconv.Itoa(int(arg.Car.NVehicleColor2)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁韩杈呴鑹插皬鍏紡锛�", formula) + case "fConfidence": + formula = arg.Car.VehicleType1 + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁締绫诲瀷灏忓叕寮忥細", formula) + case "nVehicleBright": + formula = strconv.Itoa(int(arg.Car.NVehicleBright)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁締浜害灏忓叕寮忥細", formula) + case "nPlateFlag": + formula = strconv.Itoa(int(arg.Car.NPlateFlag)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("璇嗗埆鍒拌溅鐗屽皬鍏紡锛�", formula) + case "license": + formula = arg.Car.License + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞︾墝鍙风爜灏忓叕寮忥細", formula) + case "nConfidence": + formula = strconv.Itoa(int(arg.Car.NConfidence)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞︾墝鍙俊搴﹀皬鍏紡锛�", formula) + case "nColor": + formula = strconv.Itoa(int(arg.Car.NColor)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞︾墝棰滆壊灏忓叕寮忥細", formula) + case "nType": + formula = strconv.Itoa(int(arg.Car.NType)) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞︾墝绫诲瀷灏忓叕寮忥細", formula) } expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡 result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋� @@ -98,16 +85,16 @@ } am.TargetNum = len(am.FilterData) // 鎶婄鍚堟潯浠剁殑鐩爣鏁伴噺鏇存柊鍒皌argetNum瀛楁 if am.TargetNum > 0 { - return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort} + return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort,am.FilterData} } else { - return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort} + return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData} } } else if rule.SdkArgAlias == "" { if am.TargetNum > 0 { - return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort} + return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "true", rule.Sort,am.FilterData} } else { - return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort} + return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + "" + "false", rule.Sort,am.FilterData} } } return structure.LittleRuleResult{} @@ -119,13 +106,14 @@ //logger.Info("褰撳墠灏忚鍒欐槸锛�---------", rule) //logger.Info("寰楀嚭缁撴灉闃舵", "姣旇緝鐨勮鍒欐槸锛�", rule) if rule.Operator == "" { - return structure.LittleRuleResult{am.SdkName, strconv.Itoa(am.TargetNum) + "" + rule.RuleWithPre, rule.Sort} // 濡傛灉鍚庨潰涓嶈窡鎿嶄綔绗﹀氨鐩存帴杩斿洖鏁伴噺 姣斿瑕佽窡涓嬩竴涓尯鍩熸瘮杈冩暟閲忕殑灏辩洿鎺ヨ繑鍥炴湰鍖哄煙鐨勬暟閲� + return structure.LittleRuleResult{am.SdkName, strconv.Itoa(am.TargetNum) + "" + rule.RuleWithPre, rule.Sort,am.FilterData} // 濡傛灉鍚庨潰涓嶈窡鎿嶄綔绗﹀氨鐩存帴杩斿洖鏁伴噺 姣斿瑕佽窡涓嬩竴涓尯鍩熸瘮杈冩暟閲忕殑灏辩洿鎺ヨ繑鍥炴湰鍖哄煙鐨勬暟閲� } //args := am.targetNum targetNum 宸叉垚鎵�鏈夌洰鏍囩殑鎬绘暟閲忥紝杩欓噷鍙畻yolo鐨� var num int = len(am.FilterData) formula := strconv.Itoa(num) + " " + rule.Operator + " " + rule.SdkArgValue + //logger.Info("杞﹁締鏁伴噺鍏紡",formula) expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡 result, _ := expression.Evaluate(nil) // 寰楀埌鏁板鍏紡鐨勭粨鏋� - return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + " " + strconv.FormatBool(result.(bool)), rule.Sort} + return structure.LittleRuleResult{am.SdkName, rule.RuleWithPre + " " + strconv.FormatBool(result.(bool)), rule.Sort,am.FilterData} // 鍔犱笂鍏充簬绠楁硶鐨勫垽鏂潯浠讹紝涓嶈兘鍙湁鍏充簬瑙勫垯鐨勶紝鏈夌殑绠楁硶鏈韩灏辨槸涓�涓鍒欙紝濡備釜浣撻潤姝紝闈犲彸琛�,鎵�浠ワ紝鎷垮埌褰撳墠瀛愯鍒欑殑sdkid鏉ュ垽鏂槸鍚︽槸閭d簺鐗规畩鐨勮鍒� } \ No newline at end of file -- Gitblit v1.8.0