All Products
Search
Document Center

ApsaraDB for Redis:Implement hybrid search by using TairVector

Last Updated:Jun 05, 2024

This topic describes TairVector-based hybrid search solutions that implement any combination of conditional filtering, vector search, and full-text search.

Background information

Large language models (LLMs) enable the semantic representation of unstructured data such as text, images, audio, and videos by using vectors. Vector-based k-nearest neighbor (kNN) search is expected to play a major role in fields like semantic search, personalized product recommendation, and intelligent Q&A. Typically, most vector database services support the combination of one or two of the following search methods: conditional filtering, full-text search, and vector search. These methods have obvious advantages and disadvantages.

  • Conditional filtering: filters data by using boolean expressions and imposes strict constraints on datasets and their usage, which makes it suitable only for specific scenarios.

  • Full-text search: calculates document relevance by tokenizing a query and returns a list of results that are the most relevant to the query. This method is limited to text-based queries that are prone to input errors and grammar issues.

  • Vector search: performs semantic encoding, calculates the similarity between vectors, and then returns a list of the most similar results. This method can handle multiple types of unstructured data such as documents, images, audio, and videos in various scenarios. However, this method depends heavily on LLMs and may return inaccurate results when processing enterprise-specific data.

You can use TairVector to achieve any combination of the preceding search methods within an involved database. You can combine these three search methods by using a single statement. In this statement, you can use images, text, audio, and videos to implement vector search, use text to implement full-text search, and use boolean expressions to implement conditional filtering. Additionally, TairVector sorts the results of these methods by weight and returns the final candidate list.

This way, you can go beyond the limits of a single search method to increase the hit rate of data retrieval. Specifically, you can use the hybrid_ratio parameter to adjust the weights assigned to different search methods based on specific requests. For more information, see Vector.

Solutions

In this example, the open source fashion-product-images-small dataset is used to demonstrate the performance of different solutions.

Note

When you use open source datasets, you must comply with the associated agreements, laws, and regulations.

Data description

This dataset contains data of 44,000 product data entries. The following table describes the data format.

id (int64)

gender (string)

masterCategory (string)

subCategory (string)

articleType (string)

baseColour (string)

season (string)

year (float64)

usage (string)

productDisplayName (string)

image (dict)

15,970

"Men"

"Apparel"

"Topwear"

"Shirts"

"Navy Blue"

"Fall"

2,011

"Casual"

"Turtle Check Men Navy Blue Shirt"

{ "bytes": [ 255, 216, 255, ... ], "path": null }

39,386

"Men"

"Apparel"

"Bottomwear"

"Jeans"

"Blue"

"Summer"

2,012

"Casual"

"Peter England Men Party Blue Jeans"

{ "bytes": [ 255, 216, 255, ...], "path": null }

59,263

"Women"

"Accessories"

"Watches"

"Watches"

"Silver"

"Winter"

2,016

"Casual"

"Titan Women Silver Watch"

{ "bytes": [ 255, 216, 255, ...], "path": null }

Data conversion

TairVector uses the Key-Key-(Key-Value) format to store vectors. You must first create a vector index. Example: hybrid_index. Then, convert the fields in the preceding table based on the following rules:

  • Convert id to the primary key for search in TairVector. You can use this field to implement point queries. A point query scans only a small amount of data.

  • Convert data in the image field to vectors that are encoded by using LLMs. You can implement search based on these vectors.

  • Convert data in the productDisplayName field to the description of the corresponding data in the image field. You can use the description to implement full-text search.

  • Convert other fields to the lowest level key-value pairs in TairVector. No limits are imposed on the number of these key-value pairs. You can use these key-value pairs to implement conventional filtering by attribute.

The following figure shows the data structure in TairVector.1.jpg

Procedure and sample code

  1. Load the dataset.

  2. Prepare the Tair environment.

  3. Import the dataset to Tair.

  4. Use different solutions to query data.

For more information, see Hybrid search code project.

Important

The sample code is a .ipynb file. Before you use this file, you must run the pip install jupyter command to install related dependencies.

Examples

The following examples describe how to use different solutions to perform search and show the corresponding search results. In these examples, the hybrid_ratio parameter is used to put different weights on search methods to query Green Kidswear. hybrid_ratio specifies the weight of the vector search method. The weight of the full-text search method is calculated by using the following formula: 1 - Value of hybrid_ratio.

  • Vector search: Set the hybrid_ratio parameter to 0.9999.

    topk = 20
    text = "Green Kidswear"
    vector = model.encode([text])[0]
    filter_str = None
    kwargs = {"TEXT" : text, "hybrid_ratio" : 0.9999}
    result = client.tvs_knnsearch(index_name, topk, vector, False, filter_str, **kwargs)
    top_img = [images[id_pos[int(item[0])]] for item in result]
    display_result(top_img)

    Result:

    image.png

  • Full-text search: Set the hybrid_ratio parameter to 0.0001.

    topk = 20
    text = ""Green Kidswear"
    vector = model.encode([text])[0]
    filter_str = None
    kwargs = {"TEXT" : text, "hybrid_ratio" : 0.0001}
    result = client.tvs_knnsearch(index_name, topk, vector, False, filter_str, **kwargs)
    top_img = [images[id_pos[int(item[0])]] for item in result]
    display_result(top_img)

    Result:image.png

  • Hybrid search that combines vector search and full-text search: Set the hybrid_ratio parameter to 0.5.

    topk = 20
    text = ""Green Kidswear"
    vector = model.encode([text])[0]
    filter_str = None
    kwargs = {"TEXT" : text, "hybrid_ratio" : 0.5}
    result = client.tvs_knnsearch(index_name, topk, vector, False, filter_str, **kwargs)
    top_img = [images[id_pos[int(item[0])]] for item in result]
    display_result(top_img)

    Result:

    image.png

  • Hybrid search that combines vector search, full-text search, and conditional filtering: Set the hybrid_ratio parameter to 0.5 and add the subCategory == "Topwear" statement.

    topk = 20
    text = "Green Kidswear"
    vector = model.encode([text])[0]
    filter_str = "subCategory == \"Topwear\""
    kwargs = {"TEXT" : text, "hybrid_ratio" : 0.5}
    result = client.tvs_knnsearch(index_name, topk, vector, False, filter_str, **kwargs)
    print(result)
    top_img = [images[id_pos[int(item[0])]] for item in result]
    display_result(top_img)

    Result:

    image.png

Summary

  • Based on the preceding results, both vector search and full-text search can meet query requirements. Based on the top-ranked candidate sets, the performance of full-text search is slightly higher than that of vector search.

  • For hybrid search solutions, if a product is retrieved by two search methods, the product ranks higher than other products.

  • You can use the hybrid_ratio parameter to adjust the weights of search methods in a hybrid solution. This way, the results can be reranked to obtain relatively more accurate results.

  • You can use conditional filtering to filter out specific candidate sets to improve the hit rate of vector search.