com.yahoo.schema.parser.ConvertParsedRanking Maven / Gradle / Ivy
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.schema.parser;
import com.yahoo.schema.RankProfile;
import com.yahoo.schema.RankProfileRegistry;
import com.yahoo.schema.Schema;
import com.yahoo.schema.document.RankType;
import java.util.List;
/**
* Helper for converting ParsedRankProfile etc to RankProfile with settings
*
* @author arnej27959
*/
public class ConvertParsedRanking {
private final RankProfileRegistry rankProfileRegistry;
// for unit test
ConvertParsedRanking() {
this(new RankProfileRegistry());
}
public ConvertParsedRanking(RankProfileRegistry rankProfileRegistry) {
this.rankProfileRegistry = rankProfileRegistry;
}
private RankProfile makeRankProfile(Schema schema, String name) {
if (name.equals("default")) {
return rankProfileRegistry.get(schema, "default");
}
return new RankProfile(name, schema, rankProfileRegistry);
}
void convertRankProfile(Schema schema, ParsedRankProfile parsed) {
RankProfile profile = makeRankProfile(schema, parsed.name());
for (String name : parsed.getInherited())
profile.inherit(name);
parsed.isStrict().ifPresent(profile::setStrict);
parsed.isUseSignificanceModel().ifPresent(profile::setUseSignificanceModel);
for (var constant : parsed.getConstants().values())
profile.add(constant);
for (var onnxModel : parsed.getOnnxModels())
profile.add(onnxModel);
for (var input : parsed.getInputs().entrySet())
profile.addInput(input.getKey(), input.getValue());
for (var func : parsed.getFunctions()) {
String name = func.name();
List parameters = func.getParameters();
String expression = func.getExpression();
boolean inline = func.getInline();
profile.addFunction(name, parameters, expression, inline);
}
parsed.getRankScoreDropLimit().ifPresent(profile::setRankScoreDropLimit);
parsed.getSecondPhaseRankScoreDropLimit().ifPresent(profile::setSecondPhaseRankScoreDropLimit);
parsed.getTermwiseLimit().ifPresent(profile::setTermwiseLimit);
parsed.getPostFilterThreshold().ifPresent(profile::setPostFilterThreshold);
parsed.getApproximateThreshold().ifPresent(profile::setApproximateThreshold);
parsed.getTargetHitsMaxAdjustmentFactor().ifPresent(profile::setTargetHitsMaxAdjustmentFactor);
parsed.getKeepRankCount().ifPresent(profile::setKeepRankCount);
parsed.getMinHitsPerThread().ifPresent(profile::setMinHitsPerThread);
parsed.getNumSearchPartitions().ifPresent(profile::setNumSearchPartitions);
parsed.getNumThreadsPerSearch().ifPresent(profile::setNumThreadsPerSearch);
parsed.getReRankCount().ifPresent(profile::setRerankCount);
parsed.getMatchPhase().ifPresent(profile::setMatchPhase);
parsed.getDiversity().ifPresent(profile::setDiversity);
parsed.getFirstPhaseExpression().ifPresent(profile::setFirstPhaseRanking);
parsed.getSecondPhaseExpression().ifPresent(profile::setSecondPhaseRanking);
parsed.getGlobalPhaseExpression().ifPresent(profile::setGlobalPhaseRanking);
parsed.getGlobalPhaseRerankCount().ifPresent(profile::setGlobalPhaseRerankCount);
for (var value : parsed.getMatchFeatures()) {
profile.addMatchFeatures(value);
}
for (var value : parsed.getRankFeatures()) {
profile.addRankFeatures(value);
}
for (var value : parsed.getSummaryFeatures()) {
profile.addSummaryFeatures(value);
}
parsed.getInheritedMatchFeatures().ifPresent(profile::setInheritedMatchFeatures);
parsed.getInheritedSummaryFeatures().ifPresent(profile::setInheritedSummaryFeatures);
if (parsed.getIgnoreDefaultRankFeatures()) {
profile.setIgnoreDefaultRankFeatures(true);
}
for (var mutateOp : parsed.getMutateOperations()) {
profile.addMutateOperation(mutateOp);
}
parsed.getFieldsWithRankFilter().forEach
((fieldName, isFilter) -> profile.addRankSetting(fieldName, RankProfile.RankSetting.Type.PREFERBITVECTOR, isFilter));
parsed.getFieldsWithRankWeight().forEach
((fieldName, weight) -> profile.addRankSetting(fieldName, RankProfile.RankSetting.Type.WEIGHT, weight));
parsed.getFieldsWithRankType().forEach
((fieldName, rankType) -> profile.addRankSetting(fieldName, RankProfile.RankSetting.Type.RANKTYPE, RankType.fromString(rankType)));
parsed.getRankProperties().forEach
((key, values) -> {for (String value : values) profile.addRankProperty(key, value);});
// always?
rankProfileRegistry.add(profile);
}
}