|
|
@@ -90,6 +90,8 @@ public class RankStrategy4RegionMergeModelV562 extends RankStrategy4RegionMergeM
|
|
|
Map<String, String> headVideoInfo = param.getHeadInfo();
|
|
|
List<String> vids = CommonCollectionUtils.toListDistinct(rovRecallRank, v -> String.valueOf(v.getVideoId()));
|
|
|
Map<String, Map<String, Map<String, String>>> videoBaseInfoMap = featureService.getVideoBaseInfo("", vids);
|
|
|
+ Map<String, Map<String, Map<String, String>>> videoBCData = featureService.getVideoStatistics(vids);
|
|
|
+
|
|
|
FeatureService.Feature feature = featureService.getFeatureV4(param, headVideoInfo, videoBaseInfoMap, vids);
|
|
|
Map<String, Map<String, String>> featureOriginUser = feature.getUserFeature();
|
|
|
Map<String, Map<String, Map<String, String>>> featureOriginVideo = feature.getVideoFeature();
|
|
|
@@ -115,21 +117,31 @@ public class RankStrategy4RegionMergeModelV562 extends RankStrategy4RegionMergeM
|
|
|
double xgbRovNegRate = mergeWeight.getOrDefault("xgbRovNegRate", 0.059);
|
|
|
double xgbNorPowerWeight = mergeWeight.getOrDefault("xgbNorPowerWeight", 1.22);
|
|
|
double xgbNorPowerExp = mergeWeight.getOrDefault("xgbNorPowerExp", 1.15);
|
|
|
- double norBase = mergeWeight.getOrDefault("norBase", 0.1);
|
|
|
- double vorBase = mergeWeight.getOrDefault("vorBase", 0.1);
|
|
|
+
|
|
|
+ double rosAdd = mergeWeight.getOrDefault("ros_add", 0.1);
|
|
|
+ double rosW = mergeWeight.getOrDefault("ros_w", 1.0d);
|
|
|
+
|
|
|
+ double vorAdd = mergeWeight.getOrDefault("vor_add", 0.1d);
|
|
|
+ double vorW = mergeWeight.getOrDefault("vor_w", 1.0d);
|
|
|
+
|
|
|
+ double c1Rovn1hW = mergeWeight.getOrDefault("c1_rovn_1h_w", 0d);
|
|
|
+ double c1Rovn24hW = mergeWeight.getOrDefault("c1_rovn_24h_w", 0d);
|
|
|
+
|
|
|
+ double b0Str1hW = mergeWeight.getOrDefault("b0_str_1h_w", 0d);
|
|
|
+ double b0Str24hW = mergeWeight.getOrDefault("b0_str_24h_w", 0d);
|
|
|
+
|
|
|
+ double b0Ror1hW = mergeWeight.getOrDefault("b0_ror_1h_w", 0d);
|
|
|
+ double b0Ror24hW = mergeWeight.getOrDefault("b0_ror_24h_w", 0d);
|
|
|
+
|
|
|
+ double cnRovn1hW = mergeWeight.getOrDefault("cn_rovn_1h_w", 0d);
|
|
|
+ double cnRovn24hW = mergeWeight.getOrDefault("cn_rovn_24h_w", 0d);
|
|
|
+
|
|
|
+ double dnRovn1hW = mergeWeight.getOrDefault("dn_rovn_1h_w", 0d);
|
|
|
+ double dnRovn24hW = mergeWeight.getOrDefault("dn_rovn_24h_w", 0d);
|
|
|
+
|
|
|
Map<String, Map<String, String>> vid2MapFeature = this.getVideoRedisFeature(vids, "redis:vid_hasreturn_vor:");
|
|
|
|
|
|
- // 获取权重
|
|
|
- Map<String, Double> cate2Coefficient = new HashMap<>();
|
|
|
- double cate2CoefficientFunc = mergeWeight.getOrDefault("cate2CoefficientFunc", 0d);
|
|
|
- if (cate2CoefficientFunc == 1d) {
|
|
|
- String headVidStr = String.valueOf(param.getHeadVid());
|
|
|
- String mergeCate2 = this.findVideoMergeCate2(videoBaseInfoMap, headVidStr);
|
|
|
- Double length = mergeWeight.getOrDefault("cate2CoefficientLength", 10000d);
|
|
|
- Map<String, Double> simCateScore = this.findSimCateScore(mergeCate2, length.intValue());
|
|
|
- cate2Coefficient.putAll(simCateScore);
|
|
|
- }
|
|
|
- Double cate2CoefficientDenominator = mergeWeight.getOrDefault("cate2CoefficientDenominator", 1d);
|
|
|
+
|
|
|
Map<String, String> contextInfo = getContextInfo(param);
|
|
|
|
|
|
List<Video> result = new ArrayList<>();
|
|
|
@@ -139,27 +151,75 @@ public class RankStrategy4RegionMergeModelV562 extends RankStrategy4RegionMergeM
|
|
|
item.getScoresMap().put("fmRovOrigin", fmRovOrigin);
|
|
|
double fmRov = restoreScore(fmRovOrigin, xgbRovNegRate);
|
|
|
item.getScoresMap().put("fmRov", fmRov);
|
|
|
+
|
|
|
double hasReturnRovScore = Double.parseDouble(vid2MapFeature.getOrDefault(item.getVideoId() + "", new HashMap<>()).getOrDefault("rov", "0"));
|
|
|
item.getScoresMap().put("hasReturnRovScore", hasReturnRovScore);
|
|
|
+
|
|
|
double norXGBScore = item.getScoresMap().getOrDefault("NorXGBScore", 0d);
|
|
|
double newNorXGBScore = norPowerCalibration(xgbNorPowerWeight, xgbNorPowerExp, norXGBScore);
|
|
|
+ item.getScoresMap().put("rosAdd", rosAdd);
|
|
|
+ item.getScoresMap().put("rosW", rosW);
|
|
|
+
|
|
|
double vor = Double.parseDouble(vid2MapFeature.getOrDefault(item.getVideoId() + "", new HashMap<>()).getOrDefault("vor", "0"));
|
|
|
item.getScoresMap().put("vor", vor);
|
|
|
-
|
|
|
- String vidMergeCate2 = this.findVideoMergeCate2(videoBaseInfoMap, String.valueOf(item.getVideoId()));
|
|
|
- Double scoreCoefficient = cate2Coefficient.getOrDefault(vidMergeCate2, 0d);
|
|
|
- item.getScoresMap().put("scoreCoefficient", scoreCoefficient);
|
|
|
- item.getScoresMap().put("cate2CoefficientDenominator", cate2CoefficientDenominator);
|
|
|
- item.getScoresMap().put("norBase", norBase);
|
|
|
- item.getScoresMap().put("vorBase", vorBase);
|
|
|
-
|
|
|
- score = fmRov * (norBase + newNorXGBScore) * (vorBase + vor) * (1 + scoreCoefficient / cate2CoefficientDenominator);
|
|
|
+ item.getScoresMap().put("vorAdd", vorAdd);
|
|
|
+ item.getScoresMap().put("vorW", vorW);
|
|
|
+
|
|
|
+ Map<String, String> bcData = videoBCData.getOrDefault(String.valueOf(item.getVideoId()), new HashMap<>()).getOrDefault("alg_vid_feature_b_c_data", new HashMap<>());
|
|
|
+ Map<String, String> cdNData = videoBCData.getOrDefault(String.valueOf(item.getVideoId()), new HashMap<>()).getOrDefault("alg_vid_feature_cn_dn_data", new HashMap<>());
|
|
|
+
|
|
|
+ double c1Rovn1h = Double.parseDouble(bcData.getOrDefault("c1_rovn_1h", "0"));
|
|
|
+ double c1Rovn24h = Double.parseDouble(bcData.getOrDefault("c1_rovn_24h", "0"));
|
|
|
+ double c1RovnScore = c1Rovn1hW * c1Rovn1h + c1Rovn24hW * c1Rovn24h;
|
|
|
+ item.getScoresMap().put("c1RovnScore", c1RovnScore);
|
|
|
+ item.getScoresMap().put("c1Rovn1hW", c1Rovn1hW);
|
|
|
+ item.getScoresMap().put("c1Rovn1h", c1Rovn1h);
|
|
|
+ item.getScoresMap().put("c1Rovn24hW", c1Rovn24hW);
|
|
|
+ item.getScoresMap().put("c1Rovn24h", c1Rovn24h);
|
|
|
+
|
|
|
+ double b0Str1h = Double.parseDouble(bcData.getOrDefault("b_str1_1h", "0"));
|
|
|
+ double b0Str24h = Double.parseDouble(bcData.getOrDefault("b_str1_24h", "0"));
|
|
|
+ double b0StrScore = b0Str1hW * b0Str1h + b0Str24hW * b0Str24h;
|
|
|
+ item.getScoresMap().put("b0StrScore", b0StrScore);
|
|
|
+ item.getScoresMap().put("b0Str1hW", b0Str1hW);
|
|
|
+ item.getScoresMap().put("b0Str1h", b0Str1h);
|
|
|
+ item.getScoresMap().put("b0Str24hW", b0Str24hW);
|
|
|
+ item.getScoresMap().put("b0Str24h", b0Str24h);
|
|
|
+
|
|
|
+
|
|
|
+ double b0Ror1h = Double.parseDouble(bcData.getOrDefault("b_ror1_1h", "0"));
|
|
|
+ double b0Ror24h = Double.parseDouble(bcData.getOrDefault("b_ror1_24h", "0"));
|
|
|
+ double b0RorScore = b0Ror1hW * b0Ror1h + b0Ror24hW * b0Ror24h;
|
|
|
+ item.getScoresMap().put("b0RorScore", b0RorScore);
|
|
|
+ item.getScoresMap().put("b0Ror1hW", b0Ror1hW);
|
|
|
+ item.getScoresMap().put("b0Ror1h", b0Ror1h);
|
|
|
+ item.getScoresMap().put("b0Ror24hW", b0Ror24hW);
|
|
|
+ item.getScoresMap().put("b0Ror24h", b0Ror24h);
|
|
|
+
|
|
|
+ double cnRovn1h = Double.parseDouble(cdNData.getOrDefault("cn_rovn_1h", "0"));
|
|
|
+ double cnRovn24h = Double.parseDouble(cdNData.getOrDefault("cn_rovn_24h", "0"));
|
|
|
+ double cnRovnScore = cnRovn1hW * cnRovn1h + cnRovn24hW * cnRovn24h;
|
|
|
+ item.getScoresMap().put("cnRovnScore", cnRovnScore);
|
|
|
+ item.getScoresMap().put("cnRovn1hW", cnRovn1hW);
|
|
|
+ item.getScoresMap().put("cnRovn1h", cnRovn1h);
|
|
|
+ item.getScoresMap().put("cnRovn24hW", cnRovn24hW);
|
|
|
+ item.getScoresMap().put("cnRovn24h", cnRovn24h);
|
|
|
+
|
|
|
+ double dnRovn1h = Double.parseDouble(cdNData.getOrDefault("dn_rovn_1h", "0"));
|
|
|
+ double dnRovn24h = Double.parseDouble(cdNData.getOrDefault("dn_rovn_24h", "0"));
|
|
|
+ double dnRovnScore = dnRovn1hW * dnRovn1h + dnRovn24hW * dnRovn24h;
|
|
|
+ item.getScoresMap().put("dnRovnScore", dnRovnScore);
|
|
|
+ item.getScoresMap().put("dnRovn1hW", dnRovn1hW);
|
|
|
+ item.getScoresMap().put("dnRovn1h", dnRovn1h);
|
|
|
+ item.getScoresMap().put("dnRovn24hW", dnRovn24hW);
|
|
|
+ item.getScoresMap().put("dnRovn24h", dnRovn24h);
|
|
|
+
|
|
|
+ score = fmRov * (rosAdd + rosW * newNorXGBScore) * (vorAdd + vorW * vor) + c1RovnScore + b0StrScore + b0RorScore + cnRovnScore * dnRovnScore;
|
|
|
|
|
|
Video video = item.getVideo();
|
|
|
video.setScore(score);
|
|
|
video.setSortScore(score);
|
|
|
video.setScoresMap(item.getScoresMap());
|
|
|
- // video.setAllFeatureMap(item.getAllFeatureMap());
|
|
|
|
|
|
String mergeCate2 = ExtractVideoMergeCate.parseMergeCate2(String.valueOf(item.getVideoId()), videoBaseInfoMap);
|
|
|
if (StringUtils.isNotBlank(mergeCate2)) {
|