本文整理匯總了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());
}
}
示例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);
}
}
示例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);
}
示例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;
}
示例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);
}
示例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);
}
示例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);
}
示例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);
}
示例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;
}
示例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;
}
示例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];
}
示例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];
}
示例14: doEquals
import org.elasticsearch.common.lucene.search.function.ScoreFunction; //導入依賴的package包/類
@Override
protected boolean doEquals(ScoreFunction other) {
return false;
}
示例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);
}
}
}