|
@@ -0,0 +1,91 @@
|
|
|
+package com.tzld.piaoquan.recommend.server.service.recall.strategy;
|
|
|
+
|
|
|
+import com.google.common.collect.Lists;
|
|
|
+import com.tzld.piaoquan.recommend.server.model.Video;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.filter.FilterParam;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.filter.FilterResult;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.filter.FilterService;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.recall.FilterParamFactory;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.recall.RecallParam;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.recall.RecallStrategy;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.score.ScorerUtils;
|
|
|
+import com.tzld.piaoquan.recommend.server.service.score4recall.ScorerPipeline4Recall;
|
|
|
+import org.apache.commons.collections4.CollectionUtils;
|
|
|
+import org.apache.commons.lang3.tuple.Pair;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Component;
|
|
|
+
|
|
|
+import java.util.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * @author zhangbo
|
|
|
+ */
|
|
|
+@Component
|
|
|
+public class RegionRealtimeRecallStrategyROS implements RecallStrategy {
|
|
|
+ @Autowired
|
|
|
+ private FilterService filterService;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public List<Video> recall(RecallParam param) {
|
|
|
+ long t0 = System.currentTimeMillis();
|
|
|
+ // 1 获取省份key 放入参数map中
|
|
|
+ String provinceCn = param.getProvince();
|
|
|
+ if (provinceCn == null) {
|
|
|
+ provinceCn = "中国";
|
|
|
+ } else {
|
|
|
+ provinceCn = provinceCn.replaceAll("省$", "");
|
|
|
+ }
|
|
|
+ Map<String, String> param4Model = new HashMap<>(1);
|
|
|
+ param4Model.put("region_province", provinceCn);
|
|
|
+ // 2 通过model拿到召回list
|
|
|
+ ScorerPipeline4Recall pipeline = ScorerUtils.getScorerPipeline4Recall("feeds_recall_config_region_ros.conf");
|
|
|
+ List<List<Pair<Long, Double>>> results = pipeline.recall(param4Model);
|
|
|
+ List<Pair<Long, Double>> result = results.get(0);
|
|
|
+ for (int i = 1; i < results.size(); ++i) {
|
|
|
+ result.addAll(results.get(i));
|
|
|
+ }
|
|
|
+ Map<Long, Double> videoMap = new LinkedHashMap<>();
|
|
|
+ for (Pair<Long, Double> v : result) {
|
|
|
+ videoMap.put(v.getLeft(), v.getRight());
|
|
|
+ }
|
|
|
+ long t1 = System.currentTimeMillis();
|
|
|
+ // 3 召回内部过滤
|
|
|
+ FilterParam filterParam = FilterParamFactory.create(param, Lists.newArrayList(videoMap.keySet()));
|
|
|
+ FilterResult filterResult = filterService.filter(filterParam);
|
|
|
+ List<Video> videosResult = new ArrayList<>();
|
|
|
+ if (filterResult != null && CollectionUtils.isNotEmpty(filterResult.getVideoIds())) {
|
|
|
+ filterResult.getVideoIds().forEach(vid -> {
|
|
|
+ Video video = new Video();
|
|
|
+ video.setVideoId(vid);
|
|
|
+ video.setRovScore(videoMap.get(vid));
|
|
|
+ video.setPushFrom(pushFrom());
|
|
|
+ videosResult.add(video);
|
|
|
+ });
|
|
|
+ }
|
|
|
+ videosResult.sort(Comparator.comparingDouble(o -> -o.getRovScore()));
|
|
|
+ return videosResult;
|
|
|
+ }
|
|
|
+
|
|
|
+ public static final String PUSH_FORM = "recall_strategy_region_ros";
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public String pushFrom() {
|
|
|
+ return PUSH_FORM;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public static List<List<Long>> groupKeys(Map<Long, Double> videoMap, int groupSize) {
|
|
|
+ List<List<Long>> result = new ArrayList<>();
|
|
|
+ List<Long> keys = new ArrayList<>(videoMap.keySet());
|
|
|
+
|
|
|
+ int size = keys.size();
|
|
|
+ for (int i = 0; i < size; i += groupSize) {
|
|
|
+ int endIndex = Math.min(i + groupSize, size);
|
|
|
+ List<Long> group = keys.subList(i, endIndex);
|
|
|
+ result.add(group);
|
|
|
+ }
|
|
|
+
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+
|
|
|
+}
|