From 8a0604e87d76aa80abe1f07970b859e1f0aee845 Mon Sep 17 00:00:00 2001 From: Liam Thompson <32779855+leemthompo@users.noreply.github.com> Date: Mon, 6 Jan 2025 18:56:35 +0100 Subject: [PATCH 1/2] =?UTF-8?q?[DOCS]=C2=A0Add=20full-text=20search=20over?= =?UTF-8?q?view=20(#119462)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/reference/analysis.asciidoc | 3 +- docs/reference/analysis/tokenizers.asciidoc | 8 ++ .../search/full-text-search-overview.svg | 81 ++++++++++++++++++ docs/reference/intro.asciidoc | 7 +- .../full-text-filtering-tutorial.asciidoc | 3 +- .../full-text-search.asciidoc | 82 +++++++++++++++++++ .../search-your-data.asciidoc | 3 +- 7 files changed, 179 insertions(+), 8 deletions(-) create mode 100644 docs/reference/images/search/full-text-search-overview.svg create mode 100644 docs/reference/search/search-your-data/full-text-search.asciidoc diff --git a/docs/reference/analysis.asciidoc b/docs/reference/analysis.asciidoc index 72ab42d22b911..e8fbc3bd81b6d 100644 --- a/docs/reference/analysis.asciidoc +++ b/docs/reference/analysis.asciidoc @@ -9,8 +9,7 @@ -- _Text analysis_ is the process of converting unstructured text, like -the body of an email or a product description, into a structured format that's -optimized for search. +the body of an email or a product description, into a structured format that's <>. [discrete] [[when-to-configure-analysis]] diff --git a/docs/reference/analysis/tokenizers.asciidoc b/docs/reference/analysis/tokenizers.asciidoc index 38e4ebfcabc39..89928f07b5638 100644 --- a/docs/reference/analysis/tokenizers.asciidoc +++ b/docs/reference/analysis/tokenizers.asciidoc @@ -1,6 +1,14 @@ [[analysis-tokenizers]] == Tokenizer reference +.Difference between {es} tokenization and neural tokenization +[NOTE] +==== +{es}'s tokenization process produces linguistic tokens, optimized for search and retrieval. +This differs from neural tokenization in the context of machine learning and natural language processing. Neural tokenizers translate strings into smaller, subword tokens, which are encoded into vectors for consumptions by neural networks. +{es} does not have built-in neural tokenizers. +==== + A _tokenizer_ receives a stream of characters, breaks it up into individual _tokens_ (usually individual words), and outputs a stream of _tokens_. For instance, a <> tokenizer breaks diff --git a/docs/reference/images/search/full-text-search-overview.svg b/docs/reference/images/search/full-text-search-overview.svg new file mode 100644 index 0000000000000..e7a1c5ba14cfa --- /dev/null +++ b/docs/reference/images/search/full-text-search-overview.svg @@ -0,0 +1,81 @@ + + + + + + + + + + + + + + + Full-text search with Elasticsearch + + + + + Source documents + + + + Analysis pipeline + Transforms text to normalized terms + + + + Inverted index + Search-optimized data structure + + + + Search query + + + + Relevance scoring + Similarity algorithm scores documents + + + + Search results + Most relevant first + + + + + + + + + + + + + + \ No newline at end of file diff --git a/docs/reference/intro.asciidoc b/docs/reference/intro.asciidoc index e0100b1c5640b..e163e4d45403d 100644 --- a/docs/reference/intro.asciidoc +++ b/docs/reference/intro.asciidoc @@ -260,7 +260,7 @@ Refer to <> for a hands-on examp *{esql}* is a new piped query language and compute engine which was first added in version *8.11*. -{esql} does not yet support all the features of Query DSL, like full-text search and semantic search. +{esql} does not yet support all the features of Query DSL. Look forward to new {esql} features and functionalities in each release. Refer to <> for a full overview of the query languages available in {es}. @@ -280,7 +280,7 @@ The <> accepts queries written in Query DS Query DSL support a wide range of search techniques, including the following: -* <>: Search text that has been analyzed and indexed to support phrase or proximity queries, fuzzy matches, and more. +* <>: Search text that has been analyzed and indexed to support phrase or proximity queries, fuzzy matches, and more. * <>: Search for exact matches using `keyword` fields. * <>: Search `semantic_text` fields using dense or sparse vector search on embeddings generated in your {es} cluster. * <>: Search for similar dense vectors using the kNN algorithm for embeddings generated outside of {es}. @@ -328,8 +328,7 @@ directly executed within {es} itself. The <> accepts queries written in {esql} syntax. -Today, it supports a subset of the features available in Query DSL, like aggregations, filters, and transformations. -It does not yet support full-text search or semantic search. +Today, it supports a subset of the features available in Query DSL, but it is rapidly evolving. It comes with a comprehensive set of <> for working with data and has robust integration with {kib}'s Discover, dashboards and visualizations. diff --git a/docs/reference/quickstart/full-text-filtering-tutorial.asciidoc b/docs/reference/quickstart/full-text-filtering-tutorial.asciidoc index a024305588cae..b602ee5076434 100644 --- a/docs/reference/quickstart/full-text-filtering-tutorial.asciidoc +++ b/docs/reference/quickstart/full-text-filtering-tutorial.asciidoc @@ -4,7 +4,7 @@ Basics: Full-text search and filtering ++++ -This is a hands-on introduction to the basics of full-text search with {es}, also known as _lexical search_, using the <> and <>. +This is a hands-on introduction to the basics of <> with {es}, also known as _lexical search_, using the <> and <>. You'll also learn how to filter data, to narrow down search results based on exact criteria. In this scenario, we're implementing a search function for a cooking blog. @@ -632,6 +632,7 @@ This tutorial introduced the basics of full-text search and filtering in {es}. Building a real-world search experience requires understanding many more advanced concepts and techniques. Here are some resources once you're ready to dive deeper: +* <>: Learn about the core components of full-text search in {es}. * <>: Understand all your options for searching and analyzing data in {es}. * <>: Understand how text is processed for full-text search. * <>: Learn about more advanced search techniques using the `_search` API, including semantic search. diff --git a/docs/reference/search/search-your-data/full-text-search.asciidoc b/docs/reference/search/search-your-data/full-text-search.asciidoc new file mode 100644 index 0000000000000..8641d0e45748a --- /dev/null +++ b/docs/reference/search/search-your-data/full-text-search.asciidoc @@ -0,0 +1,82 @@ +[[full-text-search]] +== Full-text search + +.Hands-on introduction to full-text search +[TIP] +==== +Would you prefer to jump straight into a hands-on tutorial? +Refer to our quick start <>. +==== + +Full-text search, also known as lexical search, is a technique for fast, efficient searching through text fields in documents. +Documents and search queries are transformed to enable returning https://www.elastic.co/what-is/search-relevance[relevant] results instead of simply exact term matches. +Fields of type <> are analyzed and indexed for full-text search. + +Built on decades of information retrieval research, full-text search delivers reliable results that scale predictably as your data grows. Because it runs efficiently on CPUs, {es}'s full-text search requires minimal computational resources compared to GPU-intensive vector operations. + +You can combine full-text search with <> to build modern hybrid search applications. While vector search may require additional GPU resources, the full-text component remains cost-effective by leveraging existing CPU infrastructure. + +[discrete] +[[full-text-search-how-it-works]] +=== How full-text search works + +The following diagram illustrates the components of full-text search. + +image::images/search/full-text-search-overview.svg[Components of full-text search from analysis to relevance scoring, align=center, width=500] + +At a high level, full-text search involves the following: + +* <>: Analysis consists of a pipeline of sequential transformations. Text is transformed into a format optimized for searching using techniques such as stemming, lowercasing, and stop word elimination. {es} contains a number of built-in <> and tokenizers, including options to analyze specific language text. You can also create custom analyzers. ++ +[TIP] +==== +Refer to <> to learn how to test an analyzer and inspect the tokens and metadata it generates. +==== +* *Inverted index creation*: After analysis is complete, {es} builds an inverted index from the resulting tokens. +An inverted index is a data structure that maps each token to the documents that contain it. +It's made up of two key components: +** *Dictionary*: A sorted list of all unique terms in the collection of documents in your index. +** *Posting list*: For each term, a list of document IDs where the term appears, along with optional metadata like term frequency and position. +* *Relevance scoring*: Results are ranked by how relevant they are to the given query. The relevance score of each document is represented by a positive floating-point number called the `_score`. The higher the `_score`, the more relevant the document. ++ +The default <> {es} uses for calculating relevance scores is https://en.wikipedia.org/wiki/Okapi_BM25[Okapi BM25], a variation of the https://en.wikipedia.org/wiki/Tf–idf[TF-IDF algorithm]. BM25 calculates relevance scores based on term frequency, document frequency, and document length. +Refer to this https://www.elastic.co/blog/practical-bm25-part-2-the-bm25-algorithm-and-its-variables[technical blog post] for a deep dive into BM25. +* *Full-text search query*: Query text is analyzed <>, and the resulting tokens are used to search the inverted index. ++ +Query DSL supports a number of <>. ++ +As of 8.17, {esql} also supports <> functions. + +[discrete] +[[full-text-search-getting-started]] +=== Getting started + +For a hands-on introduction to full-text search, refer to the <>. + +[discrete] +[[full-text-search-learn-more]] +=== Learn more + +Here are some resources to help you learn more about full-text search with {es}. + +*Core concepts* + +Learn about the core components of full-text search: + +* <> +* <> +** <> +** <> + +*{es} query languages* + +Learn how to build full-text search queries using {es}'s query languages: + +* <> +* <> + +*Advanced topics* + +For a technical deep dive into {es}'s BM25 implementation read this blog post: https://www.elastic.co/blog/practical-bm25-part-2-the-bm25-algorithm-and-its-variables[The BM25 Algorithm and its Variables]. + +To learn how to optimize the relevance of your search results, refer to <>. \ No newline at end of file diff --git a/docs/reference/search/search-your-data/search-your-data.asciidoc b/docs/reference/search/search-your-data/search-your-data.asciidoc index 9ef1ae0ebc59b..90a273a8cfe4d 100644 --- a/docs/reference/search/search-your-data/search-your-data.asciidoc +++ b/docs/reference/search/search-your-data/search-your-data.asciidoc @@ -18,7 +18,7 @@ Search for exact values:: Search for <> of numbers, dates, IPs, or strings. -Full-text search:: +<>:: Use <> to query <> and find documents that best match query terms. @@ -43,6 +43,7 @@ DSL, with a simplified user experience. Create search applications based on your results directly in the Kibana Search UI. include::search-api.asciidoc[] +include::full-text-search.asciidoc[] include::../../how-to/recipes.asciidoc[] // ☝️ search relevance recipes include::retrievers-overview.asciidoc[] From 5a644e16bf4b413dfd2a4991fb15a7bebb62a93a Mon Sep 17 00:00:00 2001 From: Liam Thompson Date: Tue, 7 Jan 2025 11:22:18 +0100 Subject: [PATCH 2/2] Fix info per 8.16 --- docs/reference/intro.asciidoc | 1 + .../search/search-your-data/full-text-search.asciidoc | 8 +++++--- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/docs/reference/intro.asciidoc b/docs/reference/intro.asciidoc index e163e4d45403d..1e1c5277c7b84 100644 --- a/docs/reference/intro.asciidoc +++ b/docs/reference/intro.asciidoc @@ -264,6 +264,7 @@ Refer to <> for a hands-on examp Look forward to new {esql} features and functionalities in each release. Refer to <> for a full overview of the query languages available in {es}. +{esql} does not yet support all the features of Query DSL, like full-text search and semantic search. [discrete] [[search-analyze-query-dsl]] diff --git a/docs/reference/search/search-your-data/full-text-search.asciidoc b/docs/reference/search/search-your-data/full-text-search.asciidoc index 8641d0e45748a..f9e04d846994b 100644 --- a/docs/reference/search/search-your-data/full-text-search.asciidoc +++ b/docs/reference/search/search-your-data/full-text-search.asciidoc @@ -45,7 +45,10 @@ Refer to this https://www.elastic.co/blog/practical-bm25-part-2-the-bm25-algorit + Query DSL supports a number of <>. + -As of 8.17, {esql} also supports <> functions. +[INFO] +==== +As of 8.17, {esql} also supports full-text search functions. +==== [discrete] [[full-text-search-getting-started]] @@ -70,10 +73,9 @@ Learn about the core components of full-text search: *{es} query languages* -Learn how to build full-text search queries using {es}'s query languages: +Learn how to build full-text search queries using Query DSL: * <> -* <> *Advanced topics*