Multiple target vectors
v1.26In a multi-target vector search, Weaviate searches multiple target vector spaces concurrently. These results are combined using a "join strategy" to produce a single set of search results.
There are multiple ways to specify the target vectors and query vectors, such as:
- Specify target vector names only
- Specify query vectors
- Specify target vector names and join strategy
- Weight raw vector distances
- Weight normalized vector distances
Multi-target vector search is available for near_xxx queries (from v1.26), as well as hybrid queries (from v1.27).
Available join strategies.
- minimum (default) Use the minimum of all vector distances.
- sum Use the sum of the vector distances.
- average Use the average of the vector distances.
- manual weights Use the sum of weighted distances, where the weight is provided for each target vector.
- relative score Use the sum of weighted normalized distances, where the weight is provided for each target vector.
Specify target vector names only
As a minimum, specify the target vector names as an array of named vectors. This will use the default join strategy.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_text(
query="a wild animal",
limit=2,
target_vector=["jeopardy_questions_vector", "jeopardy_answers_vector"], # Specify the target vectors
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
return_metadata=MetadataQuery(distance=True)
Specify query vectors
You can specify multiple query vectors in the search query with a nearVector search. This allows use of a different query vector for each corresponding target vector.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_vector(
# Specify the query vectors for each target vector
near_vector={
"jeopardy_questions_vector": v1,
"jeopardy_answers_vector": v2,
},
limit=2,
target_vector=["jeopardy_questions_vector", "jeopardy_answers_vector"], # Specify the target vectors
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
return_metadata=MetadataQuery(distance=True)
You can also specify the query vectors as an array of vectors. The array will be parsed according to the order of the specified target vectors.
Specify array(s) of query vectors
v1.27You can also specify the same target vector multiple times with different query vectors. In other words, you can use multiple query vectors for the same target vector.
The query vectors in this case are specified as an array of vectors. There are multiple ways to specify the target vectors in this case:
Target vector names only
The target vectors can be specified as an array as shown here.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_vector(
# Specify the query vectors for each target vector
near_vector={
"jeopardy_questions_vector": v1,
"jeopardy_answers_vector": [v2, v3]
},
limit=2,
# Specify the target vectors as a list
target_vector=[
"jeopardy_questions_vector",
"jeopardy_answers_vector",
],
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
return_metadata=MetadataQuery(distance=True)
Target vectors and weights
If you want to provide weights for each target vector you can do it as shown here.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import TargetVectors, MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_vector(
# Specify the query vectors for each target vector
near_vector={
"jeopardy_questions_vector": v1,
"jeopardy_answers_vector": [v2, v3]
},
limit=2,
# Specify the target vectors and weights
target_vector=TargetVectors.manual_weights({
"jeopardy_questions_vector": 10,
"jeopardy_answers_vector": [30, 30], # Matches the order of the vectors above
}),
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
return_metadata=MetadataQuery(distance=True)
Specify target vector names and join strategy
Specify target vectors as an array of named vectors and how to join the result sets.
The sum, average, minimum join strategies only require the name of the strategy and the target vectors.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import TargetVectors, MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_text(
query="a wild animal",
limit=2,
target_vector=TargetVectors.average(["jeopardy_questions_vector", "jeopardy_answers_vector"]), # Specify the target vectors and the join strategy
# .sum(), .minimum(), .manual_weights(), .relative_score() also available
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
print(o.metadata.distance)
Weight raw vector distances
Search by sums of weighted, raw distances to each target vector.
The weighting in detail
Each distance between the query vector and the target vector is multiplied by the specified weight, then the resulting weighted distances are summed for each object to produce a combined distance. The search results are sorted by this combined distance.
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import TargetVectors, MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_text(
query="a wild animal",
limit=2,
target_vector=TargetVectors.manual_weights({
"jeopardy_questions_vector": 10,
"jeopardy_answers_vector": 50
}),
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
print(o.metadata.distance)
Weight normalized vector distances
Search by sums of weighted, normalized distances to each target vector.
The weighting in detail
Each distance is normalized against other results for that target vector. Each normalized distance between the query vector and the target vector is multiplied by the specified weight. The resulting weighted distances are summed for each object to produce a combined distance. The search results are sorted by this combined distance.
For a more detailed explanation of how scores are normalized, see the blog post on hybrid relative score fusion
If a snippet doesn't work or you have feedback, please open a GitHub issue.
from weaviate.classes.query import TargetVectors, MetadataQuery
collection = client.collections.use("JeopardyTiny")
response = collection.query.near_text(
query="a wild animal",
limit=2,
target_vector=TargetVectors.relative_score({
"jeopardy_questions_vector": 10,
"jeopardy_answers_vector": 10
}),
return_metadata=MetadataQuery(distance=True)
)
for o in response.objects:
print(o.properties)
print(o.metadata.distance)
Related pages
Questions and feedback
If you have any questions or feedback, let us know in the user forum.
