當前位置: 首頁>>代碼示例>>Java>>正文


Java ScoreFunction類代碼示例

本文整理匯總了Java中org.elasticsearch.common.lucene.search.function.ScoreFunction的典型用法代碼示例。如果您正苦於以下問題:Java ScoreFunction類的具體用法?Java ScoreFunction怎麽用?Java ScoreFunction使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ScoreFunction類屬於org.elasticsearch.common.lucene.search.function包,在下文中一共展示了ScoreFunction類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testWeightFactorNeedsScore

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
public void testWeightFactorNeedsScore() {
    for (boolean needsScore : new boolean[] {true, false}) {
        WeightFactorFunction function = new WeightFactorFunction(10.0f, new ScoreFunction(CombineFunction.REPLACE) {
            @Override
            public LeafScoreFunction getLeafScoreFunction(LeafReaderContext ctx) throws IOException {
                return null;
            }

            @Override
            public boolean needsScores() {
                return needsScore;
            }

            @Override
            protected boolean doEquals(ScoreFunction other) {
                return false;
            }

            @Override
            protected int doHashCode() {
                return 0;
            }
        });
        assertEquals(needsScore, function.needsScores());
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:27,代碼來源:FunctionScoreTests.java

示例2: doToFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected ScoreFunction doToFunction(QueryShardContext context) {
    try {
        SearchScript searchScript = context.getSearchScript(script, ScriptContext.Standard.SEARCH);
        return new ScriptScoreFunction(script, searchScript);
    } catch (Exception e) {
        throw new QueryShardException(context, "script_score: the script could not be loaded", e);
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:10,代碼來源:ScriptScoreFunctionBuilder.java

示例3: doToFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected ScoreFunction doToFunction(QueryShardContext context) {
    MappedFieldType fieldType = context.getMapperService().fullName(field);
    IndexNumericFieldData fieldData = null;
    if (fieldType == null) {
        if(missing == null) {
            throw new ElasticsearchException("Unable to find a field mapper for field [" + field + "]. No 'missing' value defined.");
        }
    } else {
        fieldData = context.getForField(fieldType);
    }
    return new FieldValueFactorFunction(field, factor, modifier, missing, fieldData);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:14,代碼來源:FieldValueFactorFunctionBuilder.java

示例4: doToFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected ScoreFunction doToFunction(QueryShardContext context) throws IOException {
    AbstractDistanceScoreFunction scoreFunction;
    // EMPTY is safe because parseVariable doesn't use namedObject
    try (XContentParser parser = XContentFactory.xContent(functionBytes).createParser(NamedXContentRegistry.EMPTY, functionBytes)) {
        scoreFunction = parseVariable(fieldName, parser, context, multiValueMode);
    }
    return scoreFunction;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:10,代碼來源:DecayFunctionBuilder.java

示例5: doEquals

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected boolean doEquals(ScoreFunction other) {
    NumericFieldDataScoreFunction numericFieldDataScoreFunction = (NumericFieldDataScoreFunction) other;
    if (super.doEquals(other) == false) {
        return false;
    }
    return Objects.equals(this.origin, numericFieldDataScoreFunction.origin);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:9,代碼來源:DecayFunctionBuilder.java

示例6: doToFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected ScoreFunction doToFunction(QueryShardContext context) {
    final MappedFieldType fieldType = context.getMapperService().fullName("_uid");
    if (fieldType == null) {
        // mapper could be null if we are on a shard with no docs yet, so this won't actually be used
        return new RandomScoreFunction();
    }
    final int salt = (context.index().getName().hashCode() << 10) | context.getShardId();
    final IndexFieldData<?> uidFieldData = context.getForField(fieldType);
    return new RandomScoreFunction(this.seed == null ? hash(context.nowInMillis()) : seed, salt, uidFieldData);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:12,代碼來源:RandomScoreFunctionBuilder.java

示例7: toFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
/**
 * Called on a data node, converts this ScoreFunctionBuilder into its corresponding Lucene function object.
 */
public final ScoreFunction toFunction(QueryShardContext context) throws IOException {
    ScoreFunction scoreFunction = doToFunction(context);
    if (weight == null) {
        return scoreFunction;
    }
    return new WeightFactorFunction(weight, scoreFunction);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:11,代碼來源:ScoreFunctionBuilder.java

示例8: getFiltersFunctionScoreQuery

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
public FiltersFunctionScoreQuery getFiltersFunctionScoreQuery(FiltersFunctionScoreQuery.ScoreMode scoreMode,
        CombineFunction combineFunction, ScoreFunction... scoreFunctions) {
    FilterFunction[] filterFunctions = new FilterFunction[scoreFunctions.length];
    for (int i = 0; i < scoreFunctions.length; i++) {
        filterFunctions[i] = new FiltersFunctionScoreQuery.FilterFunction(
            new TermQuery(TERM), scoreFunctions[i]);
    }
    return new FiltersFunctionScoreQuery(new TermQuery(TERM), scoreMode, filterFunctions, Float.MAX_VALUE, Float.MAX_VALUE * -1,
            combineFunction);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:11,代碼來源:FunctionScoreTests.java

示例9: parse

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
/**
 * Parses bodies of the kind
 *
 * <pre>
 * <code>
 * {
 *      "fieldname1" : {
 *          "origin" = "someValue",
 *          "scale" = "someValue"
 *      }
 *
 * }
 * </code>
 * </pre>
 *
 * */
@Override
public ScoreFunction parse(QueryParseContext parseContext, XContentParser parser) throws IOException, QueryParsingException {
    String currentFieldName;
    XContentParser.Token token;
    AbstractDistanceScoreFunction scoreFunction;
    String multiValueMode = "MIN";
    XContentBuilder variableContent = XContentFactory.jsonBuilder();
    String fieldName = null;
    while ((token = parser.nextToken()) == XContentParser.Token.FIELD_NAME) {
        currentFieldName = parser.currentName();
        token = parser.nextToken();
        if (token == XContentParser.Token.START_OBJECT) {
            variableContent.copyCurrentStructure(parser);
            fieldName = currentFieldName;
        } else if (parseContext.parseFieldMatcher().match(currentFieldName, MULTI_VALUE_MODE)) {
            multiValueMode = parser.text();
        } else {
            throw new ElasticsearchParseException("malformed score function score parameters.");
        }
    }
    if (fieldName == null) {
        throw new ElasticsearchParseException("malformed score function score parameters.");
    }
    XContentParser variableParser = XContentFactory.xContent(variableContent.string()).createParser(variableContent.string());
    scoreFunction = parseVariable(fieldName, variableParser, parseContext, MultiValueMode.fromString(multiValueMode.toUpperCase(Locale.ROOT)));
    return scoreFunction;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:44,代碼來源:DecayFunctionParser.java

示例10: parse

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
public ScoreFunction parse(QueryParseContext parseContext, XContentParser parser) throws IOException, QueryParsingException {
    String currentFieldName = null;
    List<CondBoostEntry> condArray = new LinkedList<>();
    float defaultBoost = 1.0f;
    float boostFactor = 1.0f;
    CondBoostFactorFunction.Modifier modifier = CondBoostFactorFunction.Modifier.NONE;
    XContentParser.Token token;
    while ((token = parser.nextToken()) != XContentParser.Token.END_OBJECT) {
        if (token == XContentParser.Token.FIELD_NAME) {
            currentFieldName = parser.currentName();
        } else if (token == XContentParser.Token.START_ARRAY) {
            condArray = parseCondArray(parseContext, parser, currentFieldName);
        } else if (token.isValue()) {
            if (currentFieldName != null) {
                switch (currentFieldName) {
                    case CondBoostEntry.BOOST:
                        defaultBoost = parser.floatValue();
                        break;
                    case "factor":
                        boostFactor = parser.floatValue();
                        break;
                    case "modifier":
                        modifier = CondBoostFactorFunction.Modifier.valueOf(parser.text().toUpperCase(Locale.ROOT));
                        break;
                    default:
                        throw new QueryParsingException(parseContext, NAMES[0] + " query does not support [" + currentFieldName + "]");
                }
            }
        }
    }
    return new CondBoostFactorFunction(parseContext, condArray, defaultBoost, boostFactor, modifier);
}
 
開發者ID:jprante,項目名稱:elasticsearch-functionscore-conditionalboost,代碼行數:34,代碼來源:CondBoostFactorFunctionParser.java

示例11: doToFunction

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected ScoreFunction doToFunction(QueryShardContext context) throws IOException {
    //nothing to do here, weight will be applied by the parent class, no score function
    return null;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:6,代碼來源:WeightBuilder.java

示例12: getFunctionScoreExplanation

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
public Explanation getFunctionScoreExplanation(IndexSearcher searcher, ScoreFunction scoreFunction) throws IOException {
    FunctionScoreQuery functionScoreQuery = new FunctionScoreQuery(new TermQuery(TERM), scoreFunction, 0.0f, CombineFunction.AVG, 100);
    Weight weight = searcher.createNormalizedWeight(functionScoreQuery, true);
    Explanation explanation = weight.explain(searcher.getIndexReader().leaves().get(0), 0);
    return explanation.getDetails()[1];
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:7,代碼來源:FunctionScoreTests.java

示例13: getFiltersFunctionScoreExplanation

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
public Explanation getFiltersFunctionScoreExplanation(IndexSearcher searcher, ScoreFunction... scoreFunctions) throws IOException {
    FiltersFunctionScoreQuery filtersFunctionScoreQuery = getFiltersFunctionScoreQuery(FiltersFunctionScoreQuery.ScoreMode.AVG,
            CombineFunction.AVG, scoreFunctions);
    return getExplanation(searcher, filtersFunctionScoreQuery).getDetails()[1];
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:6,代碼來源:FunctionScoreTests.java

示例14: doEquals

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected boolean doEquals(ScoreFunction other) {
    return false;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:5,代碼來源:FunctionScoreTests.java

示例15: testFunctionScoreHashCodeAndEquals

import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
public void testFunctionScoreHashCodeAndEquals() {
    Float minScore = randomBoolean() ? null : 1.0f;
    CombineFunction combineFunction = randomFrom(CombineFunction.values());
    float maxBoost = randomBoolean() ? Float.POSITIVE_INFINITY : randomFloat();
    ScoreFunction function = randomBoolean() ? null : new DummyScoreFunction(combineFunction);

    FunctionScoreQuery q = new FunctionScoreQuery(new TermQuery(new Term("foo", "bar")), function, minScore, combineFunction, maxBoost);
    FunctionScoreQuery q1 = new FunctionScoreQuery(new TermQuery(new Term("foo", "bar")), function, minScore, combineFunction,
            maxBoost);
    assertEquals(q, q);
    assertEquals(q.hashCode(), q.hashCode());
    assertEquals(q, q1);
    assertEquals(q.hashCode(), q1.hashCode());

    FunctionScoreQuery diffQuery = new FunctionScoreQuery(new TermQuery(new Term("foo", "baz")), function, minScore, combineFunction,
            maxBoost);
    FunctionScoreQuery diffMinScore = new FunctionScoreQuery(q.getSubQuery(), function, minScore == null ? 1.0f : null, combineFunction,
            maxBoost);
    ScoreFunction otherFunciton = function == null ? new DummyScoreFunction(combineFunction) : null;
    FunctionScoreQuery diffFunction = new FunctionScoreQuery(q.getSubQuery(), otherFunciton, minScore, combineFunction, maxBoost);
    FunctionScoreQuery diffMaxBoost = new FunctionScoreQuery(new TermQuery(new Term("foo", "bar")), function, minScore, combineFunction,
            maxBoost == 1.0f ? 0.9f : 1.0f);
    FunctionScoreQuery[] queries = new FunctionScoreQuery[] { diffFunction,
        diffMinScore,
        diffQuery,
        q,
        diffMaxBoost
    };
    final int numIters = randomIntBetween(20, 100);
    for (int i = 0; i < numIters; i++) {
        FunctionScoreQuery left = randomFrom(queries);
        FunctionScoreQuery right = randomFrom(queries);
        if (left == right) {
            assertEquals(left, right);
            assertEquals(left.hashCode(), right.hashCode());
        } else {
            assertNotEquals(left + " == " + right, left, right);
        }
    }

}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:42,代碼來源:FunctionScoreTests.java


注:本文中的org.elasticsearch.common.lucene.search.function.ScoreFunction類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。