[Javadocs] add to o.o.search.rescore,searchafter,slice, sort, and suggest (#3264)

Adds class level javadocs to org.opensearch.search, and
org.opensearch.search.rescore, searchAfter, slice, sort, and suggest
subpackages.

Signed-off-by: Nicholas Walter Knize <nknize@apache.org>
This commit is contained in:
Nick Knize 2022-05-09 18:20:56 -05:00 committed by GitHub
parent 1118dcf372
commit 3b71ea6c1e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
92 changed files with 309 additions and 7 deletions

View File

@ -99,6 +99,11 @@ import java.util.Map;
import java.util.concurrent.Executor; import java.util.concurrent.Executor;
import java.util.function.LongSupplier; import java.util.function.LongSupplier;
/**
* The main search context used during search phase
*
* @opensearch.internal
*/
final class DefaultSearchContext extends SearchContext { final class DefaultSearchContext extends SearchContext {
private final ReaderContext readerContext; private final ReaderContext readerContext;

View File

@ -63,7 +63,11 @@ import java.util.Locale;
import java.util.Objects; import java.util.Objects;
import java.util.function.LongSupplier; import java.util.function.LongSupplier;
/** A formatter for values as returned by the fielddata/doc-values APIs. */ /**
* A formatter for values as returned by the fielddata/doc-values APIs.
*
* @opensearch.internal
*/
public interface DocValueFormat extends NamedWriteable { public interface DocValueFormat extends NamedWriteable {
long MASK_2_63 = 0x8000000000000000L; long MASK_2_63 = 0x8000000000000000L;
BigInteger BIGINTEGER_2_64_MINUS_ONE = BigInteger.ONE.shiftLeft(64).subtract(BigInteger.ONE); // 2^64 -1 BigInteger BIGINTEGER_2_64_MINUS_ONE = BigInteger.ONE.shiftLeft(64).subtract(BigInteger.ONE); // 2^64 -1

View File

@ -58,6 +58,8 @@ import java.util.Locale;
/** /**
* Defines what values to pick in the case a document contains multiple values for a particular field. * Defines what values to pick in the case a document contains multiple values for a particular field.
*
* @opensearch.internal
*/ */
public enum MultiValueMode implements Writeable { public enum MultiValueMode implements Writeable {
/** /**

View File

@ -45,6 +45,8 @@ import java.util.Set;
* Since {@link org.opensearch.search.internal.SearchContext} no longer hold the states of search, the top K results * Since {@link org.opensearch.search.internal.SearchContext} no longer hold the states of search, the top K results
* (i.e., documents that will be rescored by query rescorers) need to be serialized/ deserialized between search phases. * (i.e., documents that will be rescored by query rescorers) need to be serialized/ deserialized between search phases.
* A {@link RescoreDocIds} encapsulates the top K results for each rescorer by its ordinal index. * A {@link RescoreDocIds} encapsulates the top K results for each rescorer by its ordinal index.
*
* @opensearch.internal
*/ */
public final class RescoreDocIds implements Writeable { public final class RescoreDocIds implements Writeable {
public static final RescoreDocIds EMPTY = new RescoreDocIds(Collections.emptyMap()); public static final RescoreDocIds EMPTY = new RescoreDocIds(Collections.emptyMap());

View File

@ -44,7 +44,7 @@ import java.util.Objects;
* A scroll enables scrolling of search request. It holds a {@link #keepAlive()} time that * A scroll enables scrolling of search request. It holds a {@link #keepAlive()} time that
* will control how long to keep the scrolling resources open. * will control how long to keep the scrolling resources open.
* *
* * @opensearch.internal
*/ */
public final class Scroll implements Writeable { public final class Scroll implements Writeable {

View File

@ -40,6 +40,11 @@ import org.opensearch.search.internal.ShardSearchContextId;
import java.io.IOException; import java.io.IOException;
/**
* Error thrown if no search context is available
*
* @opensearch.internal
*/
public class SearchContextMissingException extends OpenSearchException { public class SearchContextMissingException extends OpenSearchException {
private final ShardSearchContextId contextId; private final ShardSearchContextId contextId;

View File

@ -35,6 +35,11 @@ package org.opensearch.search;
import org.opensearch.search.internal.SearchContext; import org.opensearch.search.internal.SearchContext;
import org.opensearch.tasks.Task; import org.opensearch.tasks.Task;
/**
* Prints the search context source
*
* @opensearch.internal
*/
public class SearchContextSourcePrinter { public class SearchContextSourcePrinter {
private final SearchContext searchContext; private final SearchContext searchContext;

View File

@ -39,6 +39,11 @@ import org.opensearch.common.io.stream.StreamOutput;
import java.io.IOException; import java.io.IOException;
/**
* Error thrown if there is a problem during search
*
* @opensearch.internal
*/
public class SearchException extends OpenSearchException implements OpenSearchWrapperException { public class SearchException extends OpenSearchException implements OpenSearchWrapperException {
private final SearchShardTarget shardTarget; private final SearchShardTarget shardTarget;

View File

@ -55,6 +55,8 @@ import org.opensearch.plugins.SearchPlugin.SearchExtSpec;
* of the {@link SearchExtSpec}. * of the {@link SearchExtSpec}.
* *
* @see SearchExtSpec * @see SearchExtSpec
*
* @opensearch.internal
*/ */
public abstract class SearchExtBuilder implements NamedWriteable, ToXContentFragment { public abstract class SearchExtBuilder implements NamedWriteable, ToXContentFragment {

View File

@ -90,6 +90,8 @@ import static org.opensearch.common.xcontent.XContentParserUtils.ensureFieldName
* A single search hit. * A single search hit.
* *
* @see SearchHits * @see SearchHits
*
* @opensearch.internal
*/ */
public final class SearchHit implements Writeable, ToXContentObject, Iterable<DocumentField> { public final class SearchHit implements Writeable, ToXContentObject, Iterable<DocumentField> {

View File

@ -54,6 +54,11 @@ import java.util.Objects;
import static org.opensearch.common.xcontent.XContentParserUtils.ensureExpectedToken; import static org.opensearch.common.xcontent.XContentParserUtils.ensureExpectedToken;
/**
* Encapsulates the results of a search operation
*
* @opensearch.internal
*/
public final class SearchHits implements Writeable, ToXContentFragment, Iterable<SearchHit> { public final class SearchHits implements Writeable, ToXContentFragment, Iterable<SearchHit> {
public static SearchHits empty() { public static SearchHits empty() {
return empty(true); return empty(true);

View File

@ -317,6 +317,8 @@ import static org.opensearch.index.query.CommonTermsQueryBuilder.COMMON_TERMS_QU
/** /**
* Sets up things that can be done at search time like queries, aggregations, and suggesters. * Sets up things that can be done at search time like queries, aggregations, and suggesters.
*
* @opensearch.internal
*/ */
public class SearchModule { public class SearchModule {
public static final Setting<Integer> INDICES_MAX_CLAUSE_COUNT_SETTING = Setting.intSetting( public static final Setting<Integer> INDICES_MAX_CLAUSE_COUNT_SETTING = Setting.intSetting(

View File

@ -41,6 +41,11 @@ import org.opensearch.rest.RestStatus;
import java.io.IOException; import java.io.IOException;
/**
* Main error thrown if there is a problem during parsing a query
*
* @opensearch.internal
*/
public class SearchParseException extends SearchException { public class SearchParseException extends SearchException {
public static final int UNKNOWN_POSITION = -1; public static final int UNKNOWN_POSITION = -1;

View File

@ -50,6 +50,8 @@ import java.io.IOException;
* request ID is particularly important since it is used to reference and maintain a context * request ID is particularly important since it is used to reference and maintain a context
* across search phases to ensure the same point in time snapshot is used for querying and * across search phases to ensure the same point in time snapshot is used for querying and
* fetching etc. * fetching etc.
*
* @opensearch.internal
*/ */
public abstract class SearchPhaseResult extends TransportResponse { public abstract class SearchPhaseResult extends TransportResponse {

View File

@ -151,6 +151,11 @@ import static org.opensearch.common.unit.TimeValue.timeValueHours;
import static org.opensearch.common.unit.TimeValue.timeValueMillis; import static org.opensearch.common.unit.TimeValue.timeValueMillis;
import static org.opensearch.common.unit.TimeValue.timeValueMinutes; import static org.opensearch.common.unit.TimeValue.timeValueMinutes;
/**
* The main search service
*
* @opensearch.internal
*/
public class SearchService extends AbstractLifecycleComponent implements IndexEventListener { public class SearchService extends AbstractLifecycleComponent implements IndexEventListener {
private static final Logger logger = LogManager.getLogger(SearchService.class); private static final Logger logger = LogManager.getLogger(SearchService.class);

View File

@ -46,6 +46,8 @@ import java.util.Objects;
/** /**
* The target that the search request was executed on. * The target that the search request was executed on.
*
* @opensearch.internal
*/ */
public final class SearchShardTarget implements Writeable, Comparable<SearchShardTarget> { public final class SearchShardTarget implements Writeable, Comparable<SearchShardTarget> {

View File

@ -47,6 +47,11 @@ import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
import java.util.Objects; import java.util.Objects;
/**
* Values to sort during search
*
* @opensearch.internal
*/
public class SearchSortValues implements ToXContentFragment, Writeable { public class SearchSortValues implements ToXContentFragment, Writeable {
private static final Object[] EMPTY_ARRAY = new Object[0]; private static final Object[] EMPTY_ARRAY = new Object[0];

View File

@ -41,6 +41,11 @@ import org.opensearch.common.lucene.Lucene;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
/**
* Doc value and formats to sort during search
*
* @opensearch.internal
*/
public class SearchSortValuesAndFormats implements Writeable { public class SearchSortValuesAndFormats implements Writeable {
private final Object[] rawSortValues; private final Object[] rawSortValues;
private final Object[] formattedSortValues; private final Object[] formattedSortValues;

View File

@ -39,6 +39,11 @@ import org.opensearch.common.io.stream.Writeable;
import java.io.IOException; import java.io.IOException;
import java.util.Locale; import java.util.Locale;
/**
* What mode the rescorer should operate in
*
* @opensearch.internal
*/
public enum QueryRescoreMode implements Writeable { public enum QueryRescoreMode implements Writeable {
Avg { Avg {
@Override @Override

View File

@ -47,6 +47,12 @@ import java.util.Set;
import static java.util.stream.Collectors.toSet; import static java.util.stream.Collectors.toSet;
/**
* A concrete query rescorer used to re-rank the Top-K results of a previously
* executed search.
*
* @opensearch.internal
*/
public final class QueryRescorer implements Rescorer { public final class QueryRescorer implements Rescorer {
public static final Rescorer INSTANCE = new QueryRescorer(); public static final Rescorer INSTANCE = new QueryRescorer();

View File

@ -50,6 +50,11 @@ import java.util.Objects;
import static org.opensearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder; import static org.opensearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder;
/**
* Builds a query rescorer object
*
* @opensearch.internal
*/
public class QueryRescorerBuilder extends RescorerBuilder<QueryRescorerBuilder> { public class QueryRescorerBuilder extends RescorerBuilder<QueryRescorerBuilder> {
public static final String NAME = "query"; public static final String NAME = "query";

View File

@ -42,6 +42,8 @@ import java.util.Set;
* Context available to the rescore while it is running. Rescore * Context available to the rescore while it is running. Rescore
* implementations should extend this with any additional resources that * implementations should extend this with any additional resources that
* they will need while rescoring. * they will need while rescoring.
*
* @opensearch.internal
*/ */
public class RescoreContext { public class RescoreContext {
private final int windowSize; private final int windowSize;

View File

@ -42,6 +42,8 @@ import java.io.IOException;
/** /**
* Rescore phase of a search request, used to run potentially expensive scoring models against the top matching documents. * Rescore phase of a search request, used to run potentially expensive scoring models against the top matching documents.
*
* @opensearch.internal
*/ */
public class RescorePhase { public class RescorePhase {

View File

@ -45,6 +45,8 @@ import java.io.IOException;
* Subclasses should borrow heavily from {@link QueryRescorer} because it is * Subclasses should borrow heavily from {@link QueryRescorer} because it is
* fairly well behaved and documents that tradeoffs that it is making. There * fairly well behaved and documents that tradeoffs that it is making. There
* is also an {@code ExampleRescorer} that is worth looking at. * is also an {@code ExampleRescorer} that is worth looking at.
*
* @opensearch.internal
*/ */
public interface Rescorer { public interface Rescorer {
/** /**

View File

@ -49,6 +49,8 @@ import java.util.Objects;
/** /**
* The abstract base builder for instances of {@link RescorerBuilder}. * The abstract base builder for instances of {@link RescorerBuilder}.
*
* @opensearch.internal
*/ */
public abstract class RescorerBuilder<RB extends RescorerBuilder<RB>> public abstract class RescorerBuilder<RB extends RescorerBuilder<RB>>
implements implements

View File

@ -59,6 +59,11 @@ import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Objects; import java.util.Objects;
/**
* Builds a search after object
*
* @opensearch.internal
*/
public class SearchAfterBuilder implements ToXContentObject, Writeable { public class SearchAfterBuilder implements ToXContentObject, Writeable {
public static final ParseField SEARCH_AFTER = new ParseField("search_after"); public static final ParseField SEARCH_AFTER = new ParseField("search_after");
private static final Object[] EMPTY_SORT_VALUES = new Object[0]; private static final Object[] EMPTY_SORT_VALUES = new Object[0];

View File

@ -52,6 +52,8 @@ import java.io.IOException;
* *
* <b>NOTE</b>: With deterministic field values this query can be used across different readers safely. * <b>NOTE</b>: With deterministic field values this query can be used across different readers safely.
* If updates are accepted on the field you must ensure that the same reader is used for all `slice` queries. * If updates are accepted on the field you must ensure that the same reader is used for all `slice` queries.
*
* @opensearch.internal
*/ */
public final class DocValuesSliceQuery extends SliceQuery { public final class DocValuesSliceQuery extends SliceQuery {
public DocValuesSliceQuery(String field, int id, int max) { public DocValuesSliceQuery(String field, int id, int max) {

View File

@ -75,6 +75,8 @@ import java.util.Set;
* (instead of {@code numShards*numSlices}). * (instead of {@code numShards*numSlices}).
* Otherwise the provided field must be a numeric and doc_values must be enabled. In that case a * Otherwise the provided field must be a numeric and doc_values must be enabled. In that case a
* {@link org.opensearch.search.slice.DocValuesSliceQuery} is used to filter the results. * {@link org.opensearch.search.slice.DocValuesSliceQuery} is used to filter the results.
*
* @opensearch.internal
*/ */
public class SliceBuilder implements Writeable, ToXContentObject { public class SliceBuilder implements Writeable, ToXContentObject {

View File

@ -39,6 +39,8 @@ import java.util.Objects;
/** /**
* An abstract {@link Query} that defines an hash function to partition the documents in multiple slices. * An abstract {@link Query} that defines an hash function to partition the documents in multiple slices.
*
* @opensearch.internal
*/ */
public abstract class SliceQuery extends Query { public abstract class SliceQuery extends Query {
private final String field; private final String field;

View File

@ -59,6 +59,8 @@ import java.io.IOException;
* For each segment this filter enumerates the terms dictionary, computes the hash code for each term and fills * For each segment this filter enumerates the terms dictionary, computes the hash code for each term and fills
* a bit set with the documents of all terms whose hash code matches the predicate. * a bit set with the documents of all terms whose hash code matches the predicate.
* <b>NOTE</b>: Documents with no value for that field are ignored. * <b>NOTE</b>: Documents with no value for that field are ignored.
*
* @opensearch.internal
*/ */
public final class TermsSliceQuery extends SliceQuery { public final class TermsSliceQuery extends SliceQuery {
// Fixed seed for computing term hashCode // Fixed seed for computing term hashCode

View File

@ -92,6 +92,8 @@ import static java.util.Collections.emptyList;
* (like {@link BigArrays#overSize(long)}) to get amortized linear number * (like {@link BigArrays#overSize(long)}) to get amortized linear number
* of allocations and to play well with our paged arrays. * of allocations and to play well with our paged arrays.
* </p> * </p>
*
* @opensearch.internal
*/ */
public abstract class BucketedSort implements Releasable { public abstract class BucketedSort implements Releasable {
/** /**

View File

@ -81,6 +81,8 @@ import static org.opensearch.search.sort.NestedSortBuilder.NESTED_FIELD;
/** /**
* A sort builder to sort based on a document field. * A sort builder to sort based on a document field.
*
* @opensearch.internal
*/ */
public class FieldSortBuilder extends SortBuilder<FieldSortBuilder> { public class FieldSortBuilder extends SortBuilder<FieldSortBuilder> {
private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(FieldSortBuilder.class); private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(FieldSortBuilder.class);

View File

@ -84,6 +84,8 @@ import static org.opensearch.search.sort.NestedSortBuilder.NESTED_FIELD;
/** /**
* A geo distance based sorting on a geo point like field. * A geo distance based sorting on a geo point like field.
*
* @opensearch.internal
*/ */
public class GeoDistanceSortBuilder extends SortBuilder<GeoDistanceSortBuilder> { public class GeoDistanceSortBuilder extends SortBuilder<GeoDistanceSortBuilder> {
private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(GeoDistanceSortBuilder.class); private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(GeoDistanceSortBuilder.class);

View File

@ -43,6 +43,8 @@ import java.util.Objects;
/** /**
* A class that encapsulates a minimum and a maximum, that are of the same type and {@link Comparable}. * A class that encapsulates a minimum and a maximum, that are of the same type and {@link Comparable}.
*
* @opensearch.internal
*/ */
public class MinAndMax<T extends Comparable<? super T>> implements Writeable { public class MinAndMax<T extends Comparable<? super T>> implements Writeable {
private final T minValue; private final T minValue;

View File

@ -47,6 +47,11 @@ import java.util.Objects;
import static org.opensearch.search.sort.SortBuilder.parseNestedFilter; import static org.opensearch.search.sort.SortBuilder.parseNestedFilter;
/**
* Builds a sort on nested objects
*
* @opensearch.internal
*/
public class NestedSortBuilder implements Writeable, ToXContentObject { public class NestedSortBuilder implements Writeable, ToXContentObject {
public static final ParseField NESTED_FIELD = new ParseField("nested"); public static final ParseField NESTED_FIELD = new ParseField("nested");
public static final ParseField PATH_FIELD = new ParseField("path"); public static final ParseField PATH_FIELD = new ParseField("path");

View File

@ -49,6 +49,8 @@ import java.util.Objects;
/** /**
* A sort builder allowing to sort by score. * A sort builder allowing to sort by score.
*
* @opensearch.internal
*/ */
public class ScoreSortBuilder extends SortBuilder<ScoreSortBuilder> { public class ScoreSortBuilder extends SortBuilder<ScoreSortBuilder> {

View File

@ -77,6 +77,8 @@ import static org.opensearch.search.sort.NestedSortBuilder.NESTED_FIELD;
/** /**
* Script sort builder allows to sort based on a custom script expression. * Script sort builder allows to sort based on a custom script expression.
*
* @opensearch.internal
*/ */
public class ScriptSortBuilder extends SortBuilder<ScriptSortBuilder> { public class ScriptSortBuilder extends SortBuilder<ScriptSortBuilder> {
private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(ScriptSortBuilder.class); private static final DeprecationLogger deprecationLogger = DeprecationLogger.getLogger(ScriptSortBuilder.class);

View File

@ -34,6 +34,11 @@ package org.opensearch.search.sort;
import org.apache.lucene.search.Sort; import org.apache.lucene.search.Sort;
import org.opensearch.search.DocValueFormat; import org.opensearch.search.DocValueFormat;
/**
* Utility class to hold sort and doc value format instances
*
* @opensearch.internal
*/
public final class SortAndFormats { public final class SortAndFormats {
public final Sort sort; public final Sort sort;

View File

@ -60,6 +60,11 @@ import java.util.Optional;
import static org.opensearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder; import static org.opensearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder;
/**
* Base class for sort object builders
*
* @opensearch.internal
*/
public abstract class SortBuilder<T extends SortBuilder<T>> implements NamedWriteable, ToXContentObject, Rewriteable<SortBuilder<?>> { public abstract class SortBuilder<T extends SortBuilder<T>> implements NamedWriteable, ToXContentObject, Rewriteable<SortBuilder<?>> {
protected SortOrder order = SortOrder.ASC; protected SortOrder order = SortOrder.ASC;

View File

@ -39,7 +39,7 @@ import org.opensearch.search.sort.ScriptSortBuilder.ScriptSortType;
/** /**
* A set of static factory methods for {@link SortBuilder}s. * A set of static factory methods for {@link SortBuilder}s.
* *
* * @opensearch.internal
*/ */
public class SortBuilders { public class SortBuilders {

View File

@ -36,6 +36,11 @@ import java.util.Objects;
import org.apache.lucene.search.SortField; import org.apache.lucene.search.SortField;
import org.opensearch.search.DocValueFormat; import org.opensearch.search.DocValueFormat;
/**
* A holder for SortField and doc value format objects
*
* @opensearch.internal
*/
public final class SortFieldAndFormat { public final class SortFieldAndFormat {
public final SortField field; public final SortField field;

View File

@ -50,6 +50,8 @@ import java.util.Objects;
* <li>avg - Use the average of all values as sort value. Only applicable for number based array fields.</li> * <li>avg - Use the average of all values as sort value. Only applicable for number based array fields.</li>
* <li>median - Use the median of all values as sort value. Only applicable for number based array fields.</li> * <li>median - Use the median of all values as sort value. Only applicable for number based array fields.</li>
* </ul> * </ul>
*
* @opensearch.internal
*/ */
public enum SortMode implements Writeable { public enum SortMode implements Writeable {
/** pick the lowest value **/ /** pick the lowest value **/

View File

@ -43,7 +43,7 @@ import java.util.Locale;
/** /**
* A sorting order. * A sorting order.
* *
* * @opensearch.internal
*/ */
public enum SortOrder implements Writeable { public enum SortOrder implements Writeable {
/** /**

View File

@ -12,6 +12,11 @@ import org.opensearch.common.xcontent.XContentParser;
import java.io.IOException; import java.io.IOException;
/**
* A base parser interface for creating sort objects based on API requests
*
* @opensearch.internal
*/
@FunctionalInterface @FunctionalInterface
public interface SortParser<SB extends SortBuilder<SB>> { public interface SortParser<SB extends SortBuilder<SB>> {
/** /**

View File

@ -45,6 +45,8 @@ import java.util.List;
/** /**
* A {@link Comparable}, {@link DocValueFormat} aware wrapper around a sort value. * A {@link Comparable}, {@link DocValueFormat} aware wrapper around a sort value.
*
* @opensearch.internal
*/ */
public abstract class SortValue implements NamedWriteable, Comparable<SortValue> { public abstract class SortValue implements NamedWriteable, Comparable<SortValue> {
/** /**

View File

@ -41,6 +41,11 @@ import org.apache.lucene.util.automaton.LevenshteinAutomata;
import java.util.Comparator; import java.util.Comparator;
/**
* Settings for the direct spell checker
*
* @opensearch.internal
*/
public class DirectSpellcheckerSettings { public class DirectSpellcheckerSettings {
// NB: If this changes, make sure to change the default in TermBuilderSuggester // NB: If this changes, make sure to change the default in TermBuilderSuggester

View File

@ -42,6 +42,8 @@ import java.util.Objects;
/** /**
* An enum representing the valid sorting options * An enum representing the valid sorting options
*
* @opensearch.internal
*/ */
public enum SortBy implements Writeable { public enum SortBy implements Writeable {
/** Sort should first be based on score, then document frequency and then the term itself. */ /** Sort should first be based on score, then document frequency and then the term itself. */

View File

@ -71,6 +71,8 @@ import static org.opensearch.common.xcontent.XContentParserUtils.ensureExpectedT
/** /**
* Top level suggest result, containing the result for each suggestion. * Top level suggest result, containing the result for each suggestion.
*
* @opensearch.internal
*/ */
public class Suggest implements Iterable<Suggest.Suggestion<? extends Entry<? extends Option>>>, Writeable, ToXContentFragment { public class Suggest implements Iterable<Suggest.Suggestion<? extends Entry<? extends Option>>>, Writeable, ToXContentFragment {

View File

@ -57,6 +57,8 @@ import java.util.Objects;
* <p> * <p>
* Suggesting works by suggesting terms/phrases that appear in the suggest text that are similar compared * Suggesting works by suggesting terms/phrases that appear in the suggest text that are similar compared
* to the terms in provided text. These suggestions are based on several options described in this class. * to the terms in provided text. These suggestions are based on several options described in this class.
*
* @opensearch.internal
*/ */
public class SuggestBuilder implements Writeable, ToXContentObject { public class SuggestBuilder implements Writeable, ToXContentObject {
protected static final ParseField GLOBAL_TEXT_FIELD = new ParseField("text"); protected static final ParseField GLOBAL_TEXT_FIELD = new ParseField("text");

View File

@ -38,6 +38,8 @@ import org.opensearch.search.suggest.term.TermSuggestionBuilder;
/** /**
* A static factory for building suggester lookup queries * A static factory for building suggester lookup queries
*
* @opensearch.internal
*/ */
public abstract class SuggestBuilders { public abstract class SuggestBuilders {

View File

@ -46,6 +46,8 @@ import java.util.Map;
/** /**
* Suggest phase of a search request, used to collect suggestions * Suggest phase of a search request, used to collect suggestions
*
* @opensearch.internal
*/ */
public class SuggestPhase { public class SuggestPhase {

View File

@ -37,6 +37,11 @@ import org.apache.lucene.util.CharsRefBuilder;
import java.io.IOException; import java.io.IOException;
/**
* Base class used for all suggester implementations
*
* @opensearch.internal
*/
public abstract class Suggester<T extends SuggestionSearchContext.SuggestionContext> { public abstract class Suggester<T extends SuggestionSearchContext.SuggestionContext> {
protected abstract Suggest.Suggestion<? extends Suggest.Suggestion.Entry<? extends Suggest.Suggestion.Entry.Option>> innerExecute( protected abstract Suggest.Suggestion<? extends Suggest.Suggestion.Entry<? extends Suggest.Suggestion.Entry.Option>> innerExecute(

View File

@ -53,6 +53,8 @@ import java.util.Objects;
/** /**
* Base class for the different suggestion implementations. * Base class for the different suggestion implementations.
*
* @opensearch.internal
*/ */
public abstract class SuggestionBuilder<T extends SuggestionBuilder<T>> implements NamedWriteable, ToXContentFragment { public abstract class SuggestionBuilder<T extends SuggestionBuilder<T>> implements NamedWriteable, ToXContentFragment {

View File

@ -38,6 +38,11 @@ import org.opensearch.index.query.QueryShardContext;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.Map; import java.util.Map;
/**
* Context used for suggestion based search
*
* @opensearch.internal
*/
public class SuggestionSearchContext { public class SuggestionSearchContext {
private final Map<String, SuggestionContext> suggestions = new LinkedHashMap<>(4); private final Map<String, SuggestionContext> suggestions = new LinkedHashMap<>(4);

View File

@ -42,6 +42,11 @@ import org.opensearch.common.xcontent.XContentBuilder;
import java.io.IOException; import java.io.IOException;
/**
* Stats for completion suggester
*
* @opensearch.internal
*/
public class CompletionStats implements Writeable, ToXContentFragment { public class CompletionStats implements Writeable, ToXContentFragment {
private static final String COMPLETION = "completion"; private static final String COMPLETION = "completion";

View File

@ -51,6 +51,11 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
/**
* The completion suggester implementation
*
* @opensearch.internal
*/
public class CompletionSuggester extends Suggester<CompletionSuggestionContext> { public class CompletionSuggester extends Suggester<CompletionSuggestionContext> {
public static final CompletionSuggester INSTANCE = new CompletionSuggester(); public static final CompletionSuggester INSTANCE = new CompletionSuggester();

View File

@ -76,6 +76,7 @@ import static org.opensearch.search.suggest.Suggest.COMPARATOR;
* .. * ..
* } * }
* *
* @opensearch.internal
*/ */
public final class CompletionSuggestion extends Suggest.Suggestion<CompletionSuggestion.Entry> { public final class CompletionSuggestion extends Suggest.Suggestion<CompletionSuggestion.Entry> {

View File

@ -67,6 +67,8 @@ import java.util.Objects;
* for users as they type search terms. The implementation of the completion service uses FSTs that * for users as they type search terms. The implementation of the completion service uses FSTs that
* are created at index-time and so must be defined in the mapping with the type "completion" before * are created at index-time and so must be defined in the mapping with the type "completion" before
* indexing. * indexing.
*
* @opensearch.internal
*/ */
public class CompletionSuggestionBuilder extends SuggestionBuilder<CompletionSuggestionBuilder> { public class CompletionSuggestionBuilder extends SuggestionBuilder<CompletionSuggestionBuilder> {

View File

@ -44,6 +44,11 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
/**
* Context used for the completion suggester
*
* @opensearch.internal
*/
public class CompletionSuggestionContext extends SuggestionSearchContext.SuggestionContext { public class CompletionSuggestionContext extends SuggestionSearchContext.SuggestionContext {
protected CompletionSuggestionContext(QueryShardContext shardContext) { protected CompletionSuggestionContext(QueryShardContext shardContext) {

View File

@ -49,6 +49,8 @@ import java.util.Objects;
/** /**
* Fuzzy options for completion suggester * Fuzzy options for completion suggester
*
* @opensearch.internal
*/ */
public class FuzzyOptions implements ToXContentFragment, Writeable { public class FuzzyOptions implements ToXContentFragment, Writeable {
static final ParseField FUZZY_OPTIONS = new ParseField("fuzzy"); static final ParseField FUZZY_OPTIONS = new ParseField("fuzzy");

View File

@ -49,6 +49,8 @@ import java.io.IOException;
/** /**
* Regular expression options for completion suggester * Regular expression options for completion suggester
*
* @opensearch.internal
*/ */
public class RegexOptions implements ToXContentFragment, Writeable { public class RegexOptions implements ToXContentFragment, Writeable {
static final ParseField REGEX_OPTIONS = new ParseField("regex"); static final ParseField REGEX_OPTIONS = new ParseField("regex");

View File

@ -47,6 +47,8 @@ import java.util.Map;
* This collector groups suggestions coming from the same document but matching different contexts * This collector groups suggestions coming from the same document but matching different contexts
* or surface form together. When different contexts or surface forms match the same suggestion form only * or surface form together. When different contexts or surface forms match the same suggestion form only
* the best one per document (sorted by weight) is kept. * the best one per document (sorted by weight) is kept.
*
* @opensearch.internal
**/ **/
class TopSuggestGroupDocsCollector extends TopSuggestDocsCollector { class TopSuggestGroupDocsCollector extends TopSuggestDocsCollector {
private Map<Integer, List<CharSequence>> docContexts = new HashMap<>(); private Map<Integer, List<CharSequence>> docContexts = new HashMap<>();

View File

@ -61,6 +61,8 @@ import java.util.stream.Collectors;
* category (string) value. * category (string) value.
* {@link CategoryQueryContext} defines options for constructing * {@link CategoryQueryContext} defines options for constructing
* a unit of query context for this context type * a unit of query context for this context type
*
* @opensearch.internal
*/ */
public class CategoryContextMapping extends ContextMapping<CategoryQueryContext> { public class CategoryContextMapping extends ContextMapping<CategoryQueryContext> {

View File

@ -48,6 +48,8 @@ import static org.opensearch.search.suggest.completion.context.CategoryContextMa
/** /**
* Defines the query context for {@link CategoryContextMapping} * Defines the query context for {@link CategoryContextMapping}
*
* @opensearch.internal
*/ */
public final class CategoryQueryContext implements ToXContentObject { public final class CategoryQueryContext implements ToXContentObject {
public static final String NAME = "category"; public static final String NAME = "category";

View File

@ -34,6 +34,8 @@ package org.opensearch.search.suggest.completion.context;
/** /**
* Builder for {@link ContextMapping} * Builder for {@link ContextMapping}
*
* @opensearch.internal
*/ */
public abstract class ContextBuilder<E extends ContextMapping<?>> { public abstract class ContextBuilder<E extends ContextMapping<?>> {

View File

@ -57,6 +57,8 @@ import java.util.function.Function;
* filter and/or boost suggestions at query time for {@link CompletionFieldMapper}. * filter and/or boost suggestions at query time for {@link CompletionFieldMapper}.
* *
* Implementations have to define how contexts are parsed at query/index time * Implementations have to define how contexts are parsed at query/index time
*
* @opensearch.internal
*/ */
public abstract class ContextMapping<T extends ToXContent> implements ToXContentFragment { public abstract class ContextMapping<T extends ToXContent> implements ToXContentFragment {

View File

@ -65,6 +65,8 @@ import static org.opensearch.search.suggest.completion.context.ContextMapping.FI
* ContextMappings indexes context-enabled suggestion fields * ContextMappings indexes context-enabled suggestion fields
* and creates context queries for defined {@link ContextMapping}s * and creates context queries for defined {@link ContextMapping}s
* for a {@link CompletionFieldMapper} * for a {@link CompletionFieldMapper}
*
* @opensearch.internal
*/ */
public class ContextMappings implements ToXContent, Iterable<ContextMapping<?>> { public class ContextMappings implements ToXContent, Iterable<ContextMapping<?>> {

View File

@ -75,6 +75,8 @@ import static org.opensearch.geometry.utils.Geohash.stringEncode;
* *
* {@link GeoQueryContext} defines the options for constructing * {@link GeoQueryContext} defines the options for constructing
* a unit of query context for this context type * a unit of query context for this context type
*
* @opensearch.internal
*/ */
public class GeoContextMapping extends ContextMapping<GeoQueryContext> { public class GeoContextMapping extends ContextMapping<GeoQueryContext> {

View File

@ -54,6 +54,8 @@ import static org.opensearch.search.suggest.completion.context.GeoContextMapping
/** /**
* Defines the query context for {@link GeoContextMapping} * Defines the query context for {@link GeoContextMapping}
*
* @opensearch.internal
*/ */
public final class GeoQueryContext implements ToXContentObject { public final class GeoQueryContext implements ToXContentObject {
public static final String NAME = "geo"; public static final String NAME = "geo";

View File

@ -39,6 +39,12 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.CandidateSe
import java.io.IOException; import java.io.IOException;
//TODO public for tests //TODO public for tests
/**
* Base class for phrase candidates
*
* @opensearch.internal
*/
public abstract class CandidateGenerator { public abstract class CandidateGenerator {
public abstract boolean isKnownWord(BytesRef term) throws IOException; public abstract boolean isKnownWord(BytesRef term) throws IOException;

View File

@ -37,6 +37,11 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.CandidateSe
import java.io.IOException; import java.io.IOException;
/**
* Scores phrase candidates
*
* @opensearch.internal
*/
final class CandidateScorer { final class CandidateScorer {
private final WordScorer scorer; private final WordScorer scorer;
private final int maxNumCorrections; private final int maxNumCorrections;

View File

@ -38,6 +38,12 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.Candidate;
import java.util.Arrays; import java.util.Arrays;
//TODO public for tests //TODO public for tests
/**
* Correction in phrase suggester
*
* @opensearch.internal
*/
public final class Correction implements Comparable<Correction> { public final class Correction implements Comparable<Correction> {
public static final Correction[] EMPTY = new Correction[0]; public static final Correction[] EMPTY = new Correction[0];

View File

@ -65,6 +65,11 @@ import static java.lang.Math.max;
import static java.lang.Math.min; import static java.lang.Math.min;
import static java.lang.Math.round; import static java.lang.Math.round;
/**
* Generates the phrase directly from the IndexReader
*
* @opensearch.internal
*/
public final class DirectCandidateGenerator extends CandidateGenerator { public final class DirectCandidateGenerator extends CandidateGenerator {
private final DirectSpellChecker spellchecker; private final DirectSpellChecker spellchecker;

View File

@ -57,6 +57,11 @@ import java.util.Locale;
import java.util.Objects; import java.util.Objects;
import java.util.function.Consumer; import java.util.function.Consumer;
/**
* Builder for a phrase candidate directly retrieved from an IndexReader
*
* @opensearch.internal
*/
public final class DirectCandidateGeneratorBuilder implements CandidateGenerator { public final class DirectCandidateGeneratorBuilder implements CandidateGenerator {
private static final String TYPE = "direct_generator"; private static final String TYPE = "direct_generator";

View File

@ -54,6 +54,8 @@ import java.util.Objects;
* href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram * href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram
* Smoothing</a> for details. * Smoothing</a> for details.
* </p> * </p>
*
* @opensearch.internal
*/ */
public final class Laplace extends SmoothingModel { public final class Laplace extends SmoothingModel {
public static final String NAME = "laplace"; public static final String NAME = "laplace";

View File

@ -38,6 +38,11 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.Candidate;
import java.io.IOException; import java.io.IOException;
/**
* Scorer implementation based on a laplace computation
*
* @opensearch.internal
*/
final class LaplaceScorer extends WordScorer { final class LaplaceScorer extends WordScorer {
private double alpha; private double alpha;

View File

@ -38,7 +38,12 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.Candidate;
import java.io.IOException; import java.io.IOException;
//TODO public for tests /**
* Linear interpolation based scoring
*
* @opensearch.internal
*/
// TODO public for tests
public final class LinearInterpolatingScorer extends WordScorer { public final class LinearInterpolatingScorer extends WordScorer {
private final double unigramLambda; private final double unigramLambda;

View File

@ -54,6 +54,8 @@ import java.util.Objects;
* href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram * href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram
* Smoothing</a> for details. * Smoothing</a> for details.
* </p> * </p>
*
* @opensearch.internal
*/ */
public final class LinearInterpolation extends SmoothingModel { public final class LinearInterpolation extends SmoothingModel {
public static final String NAME = "linear"; public static final String NAME = "linear";

View File

@ -39,7 +39,12 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.CandidateSe
import java.io.IOException; import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
//TODO public for tests /**
* Wrapper for a multi-candidate generator
*
* @opensearch.internal
*/
// TODO public for tests
public final class MultiCandidateGeneratorWrapper extends CandidateGenerator { public final class MultiCandidateGeneratorWrapper extends CandidateGenerator {
private final CandidateGenerator[] candidateGenerator; private final CandidateGenerator[] candidateGenerator;

View File

@ -45,6 +45,11 @@ import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
/**
* Spell checker based on a noisy channel
*
* @opensearch.internal
*/
final class NoisyChannelSpellChecker { final class NoisyChannelSpellChecker {
public static final double REAL_WORD_LIKELIHOOD = 0.95d; public static final double REAL_WORD_LIKELIHOOD = 0.95d;
public static final int DEFAULT_TOKEN_LIMIT = 10; public static final int DEFAULT_TOKEN_LIMIT = 10;

View File

@ -64,6 +64,11 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
/**
* Phrase suggestion implementation
*
* @opensearch.internal
*/
public final class PhraseSuggester extends Suggester<PhraseSuggestionContext> { public final class PhraseSuggester extends Suggester<PhraseSuggestionContext> {
private final BytesRef SEPARATOR = new BytesRef(" "); private final BytesRef SEPARATOR = new BytesRef(" ");
private static final String SUGGESTION_TEMPLATE_VAR_NAME = "suggestion"; private static final String SUGGESTION_TEMPLATE_VAR_NAME = "suggestion";

View File

@ -50,6 +50,8 @@ import static org.opensearch.common.xcontent.ConstructingObjectParser.optionalCo
/** /**
* Suggestion entry returned from the {@link PhraseSuggester}. * Suggestion entry returned from the {@link PhraseSuggester}.
*
* @opensearch.internal
*/ */
public class PhraseSuggestion extends Suggest.Suggestion<PhraseSuggestion.Entry> { public class PhraseSuggestion extends Suggest.Suggestion<PhraseSuggestion.Entry> {

View File

@ -68,6 +68,8 @@ import java.util.Set;
/** /**
* Defines the actual suggest command for phrase suggestions ( {@code phrase}). * Defines the actual suggest command for phrase suggestions ( {@code phrase}).
*
* @opensearch.internal
*/ */
public class PhraseSuggestionBuilder extends SuggestionBuilder<PhraseSuggestionBuilder> { public class PhraseSuggestionBuilder extends SuggestionBuilder<PhraseSuggestionBuilder> {

View File

@ -45,6 +45,11 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
/**
* Context used during phrase suggestion
*
* @opensearch.internal
*/
class PhraseSuggestionContext extends SuggestionContext { class PhraseSuggestionContext extends SuggestionContext {
static final boolean DEFAULT_COLLATE_PRUNE = false; static final boolean DEFAULT_COLLATE_PRUNE = false;
static final boolean DEFAULT_REQUIRE_UNIGRAM = true; static final boolean DEFAULT_REQUIRE_UNIGRAM = true;

View File

@ -41,6 +41,11 @@ import org.opensearch.search.suggest.phrase.WordScorer.WordScorerFactory;
import java.io.IOException; import java.io.IOException;
/**
* Smooths the scoring calculation
*
* @opensearch.internal
*/
public abstract class SmoothingModel implements NamedWriteable, ToXContentFragment { public abstract class SmoothingModel implements NamedWriteable, ToXContentFragment {
@Override @Override

View File

@ -55,6 +55,8 @@ import java.util.Objects;
* href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram * href="http://en.wikipedia.org/wiki/N-gram#Smoothing_techniques">N-Gram
* Smoothing</a> for details. * Smoothing</a> for details.
* </p> * </p>
*
* @opensearch.internal
*/ */
public final class StupidBackoff extends SmoothingModel { public final class StupidBackoff extends SmoothingModel {
/** /**

View File

@ -38,6 +38,11 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.Candidate;
import java.io.IOException; import java.io.IOException;
/**
* naive backoff scorer
*
* @opensearch.internal
*/
class StupidBackoffScorer extends WordScorer { class StupidBackoffScorer extends WordScorer {
private final double discount; private final double discount;

View File

@ -44,7 +44,12 @@ import org.opensearch.search.suggest.phrase.DirectCandidateGenerator.CandidateSe
import java.io.IOException; import java.io.IOException;
//TODO public for tests /**
* Scores by words
*
* @opensearch.internal
*/
// TODO public for tests
public abstract class WordScorer { public abstract class WordScorer {
protected final IndexReader reader; protected final IndexReader reader;
protected final String field; protected final String field;

View File

@ -49,6 +49,11 @@ import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
/**
* The Term Suggester implementation
*
* @opensearch.internal
*/
public final class TermSuggester extends Suggester<TermSuggestionContext> { public final class TermSuggester extends Suggester<TermSuggestionContext> {
public static final TermSuggester INSTANCE = new TermSuggester(); public static final TermSuggester INSTANCE = new TermSuggester();

View File

@ -54,6 +54,8 @@ import static org.opensearch.common.xcontent.ConstructingObjectParser.constructo
/** /**
* The suggestion responses corresponding with the suggestions in the request. * The suggestion responses corresponding with the suggestions in the request.
*
* @opensearch.internal
*/ */
public class TermSuggestion extends Suggestion<TermSuggestion.Entry> { public class TermSuggestion extends Suggestion<TermSuggestion.Entry> {

View File

@ -77,6 +77,8 @@ import static org.opensearch.search.suggest.phrase.DirectCandidateGeneratorBuild
* Defines the actual suggest command. Each command uses the global options * Defines the actual suggest command. Each command uses the global options
* unless defined in the suggestion itself. All options are the same as the * unless defined in the suggestion itself. All options are the same as the
* global options, but are only applicable for this suggestion. * global options, but are only applicable for this suggestion.
*
* @opensearch.internal
*/ */
public class TermSuggestionBuilder extends SuggestionBuilder<TermSuggestionBuilder> { public class TermSuggestionBuilder extends SuggestionBuilder<TermSuggestionBuilder> {

View File

@ -35,6 +35,11 @@ import org.opensearch.index.query.QueryShardContext;
import org.opensearch.search.suggest.DirectSpellcheckerSettings; import org.opensearch.search.suggest.DirectSpellcheckerSettings;
import org.opensearch.search.suggest.SuggestionSearchContext.SuggestionContext; import org.opensearch.search.suggest.SuggestionSearchContext.SuggestionContext;
/**
* Context used during term suggestion
*
* @opensearch.internal
*/
final class TermSuggestionContext extends SuggestionContext { final class TermSuggestionContext extends SuggestionContext {
private final DirectSpellcheckerSettings settings = new DirectSpellcheckerSettings(); private final DirectSpellcheckerSettings settings = new DirectSpellcheckerSettings();