|  | @@ -51,6 +51,13 @@ public class RankStrategyBy688 extends RankStrategyBasic {
 | 
											
												
													
														|  |      @ApolloJsonValue("${rank.score.weight.680:{}}")
 |  |      @ApolloJsonValue("${rank.score.weight.680:{}}")
 | 
											
												
													
														|  |      private Map<String, Double> weightMap;
 |  |      private Map<String, Double> weightMap;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 人群分层&创意的权重
 | 
											
												
													
														|  | 
 |  | +     * 格式:{layer_creativeId: weight}
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    @ApolloJsonValue("${rank.score.weight.layer.and.creative.680:{}}")
 | 
											
												
													
														|  | 
 |  | +    private Map<String, Double> layerAndCreativeWeightMap;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      @ApolloJsonValue("${rank.score.neg_sample_rate:0.01}")
 |  |      @ApolloJsonValue("${rank.score.neg_sample_rate:0.01}")
 | 
											
												
													
														|  |      Double negSampleRate;
 |  |      Double negSampleRate;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -298,6 +305,9 @@ public class RankStrategyBy688 extends RankStrategyBasic {
 | 
											
												
													
														|  |          // loop
 |  |          // loop
 | 
											
												
													
														|  |          double cpmCoefficient = weightParam.getOrDefault("cpmCoefficient", 0.9);
 |  |          double cpmCoefficient = weightParam.getOrDefault("cpmCoefficient", 0.9);
 | 
											
												
													
														|  |          boolean isGuaranteeType = false;
 |  |          boolean isGuaranteeType = false;
 | 
											
												
													
														|  | 
 |  | +        // 查询人群分层信息
 | 
											
												
													
														|  | 
 |  | +        Map<String, String> userLayerAfterHandle = getUserLayerAfterHandle(request);
 | 
											
												
													
														|  | 
 |  | +        String peopleLayer = userLayerAfterHandle.get("layer");
 | 
											
												
													
														|  |          for (AdRankItem item : result) {
 |  |          for (AdRankItem item : result) {
 | 
											
												
													
														|  |              double bid = item.getCpa();
 |  |              double bid = item.getCpa();
 | 
											
												
													
														|  |              if (scoreParam.getExpCodeSet().contains(correctCpaExp1) || scoreParam.getExpCodeSet().contains(correctCpaExp2)) {
 |  |              if (scoreParam.getExpCodeSet().contains(correctCpaExp1) || scoreParam.getExpCodeSet().contains(correctCpaExp2)) {
 | 
											
										
											
												
													
														|  | @@ -309,6 +319,10 @@ public class RankStrategyBy688 extends RankStrategyBasic {
 | 
											
												
													
														|  |              if (isGuaranteedFlow && item.getExt().get("isGuaranteed") != null && (boolean) item.getExt().get("isGuaranteed")) {
 |  |              if (isGuaranteedFlow && item.getExt().get("isGuaranteed") != null && (boolean) item.getExt().get("isGuaranteed")) {
 | 
											
												
													
														|  |                  isGuaranteeType = true;
 |  |                  isGuaranteeType = true;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            String layerAndCreativeWeightMapKey = getLayerAndCreativeWeightMapKey(peopleLayer, String.valueOf(item.getAdId()));
 | 
											
												
													
														|  | 
 |  | +            // 人群分层&创意的权重
 | 
											
												
													
														|  | 
 |  | +            double layerAndCreativeWeight = getLayerAndCreativeWeight(layerAndCreativeWeightMapKey);
 | 
											
												
													
														|  |              double scoreCoefficient = creativeScoreCoefficient.getOrDefault(item.getAdId(), 1d);
 |  |              double scoreCoefficient = creativeScoreCoefficient.getOrDefault(item.getAdId(), 1d);
 | 
											
												
													
														|  |              double guaranteeScoreCoefficient = getGuaranteeScoreCoefficient(isGuaranteedFlow, item.getExt());
 |  |              double guaranteeScoreCoefficient = getGuaranteeScoreCoefficient(isGuaranteedFlow, item.getExt());
 | 
											
												
													
														|  |              double score = item.getLrScore() * bid * scoreCoefficient * guaranteeScoreCoefficient;
 |  |              double score = item.getLrScore() * bid * scoreCoefficient * guaranteeScoreCoefficient;
 | 
											
										
											
												
													
														|  | @@ -346,6 +360,54 @@ public class RankStrategyBy688 extends RankStrategyBasic {
 | 
											
												
													
														|  |          return result;
 |  |          return result;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 获取人群分层和创意的权重
 | 
											
												
													
														|  | 
 |  | +     * @param key
 | 
											
												
													
														|  | 
 |  | +     * @return
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private Double getLayerAndCreativeWeight(String key){
 | 
											
												
													
														|  | 
 |  | +        if (StringUtils.isBlank(key)) {
 | 
											
												
													
														|  | 
 |  | +            return 1d;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        return layerAndCreativeWeightMap.getOrDefault(key, 1d);
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 获取人群分层和创意的权重key
 | 
											
												
													
														|  | 
 |  | +     * @param layer
 | 
											
												
													
														|  | 
 |  | +     * @param creativeId
 | 
											
												
													
														|  | 
 |  | +     * @return
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private String getLayerAndCreativeWeightMapKey(String layer, String creativeId){
 | 
											
												
													
														|  | 
 |  | +        if ( StringUtils.isBlank(layer) || StringUtils.isBlank(creativeId)) {
 | 
											
												
													
														|  | 
 |  | +            return null;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        return layer + "_" + creativeId;
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * 获取处理后的人群分层
 | 
											
												
													
														|  | 
 |  | +     * @param request
 | 
											
												
													
														|  | 
 |  | +     * @return
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    private Map<String, String> getUserLayerAfterHandle(RankRecommendRequestParam request){
 | 
											
												
													
														|  | 
 |  | +        Map<String, String> userLayer = this.getUserLayer(request.getMid());
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        String layer = userLayer.getOrDefault("layer", "无曝光");
 | 
											
												
													
														|  | 
 |  | +        String clazz = userLayer.getOrDefault("class", "近期未出现");
 | 
											
												
													
														|  | 
 |  | +        if (StringUtils.isNotEmpty(layer) && layer.equals("已转化")) {
 | 
											
												
													
														|  | 
 |  | +            layer = "有转化";
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (request.getIsFilterUser()) {
 | 
											
												
													
														|  | 
 |  | +            layer = layer + "-炸";
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        userLayer.put("layer", layer);
 | 
											
												
													
														|  | 
 |  | +        userLayer.put("class", clazz);
 | 
											
												
													
														|  | 
 |  | +        return userLayer;
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      private void handleB1Feature(Map<String, String> b1Feature, Map<String, String> cidFeatureMap, String cid) {
 |  |      private void handleB1Feature(Map<String, String> b1Feature, Map<String, String> cidFeatureMap, String cid) {
 | 
											
												
													
														|  |          cidFeatureMap.put("cid_" + cid, "0.1");
 |  |          cidFeatureMap.put("cid_" + cid, "0.1");
 | 
											
												
													
														|  |          // if (StringUtils.isNotBlank(b1Feature.get("adid"))) {
 |  |          // if (StringUtils.isNotBlank(b1Feature.get("adid"))) {
 |