Percentile
Latency
The vector to search for. Optional, if not set, this endpoint performs a filter-only search.
It must have the same dimensions as the vectors in the namespace.
Example: [0.1, 0.2, 0.3, ..., 76.8]
Fields to rank by for BM25 full text search.
Currently, you can only rank by either BM25 or vector search. For hybrid search, you must do two queries and combine the results client-side. We will expose primitives to combine results server-side in the future.
The attribute must be configured to be BM25 searchable.
Example: ["text", "BM25", "fox jumping"]
Example with multiple fields:
["Sum", [["text", "BM25", "fox jumping"], ["name", "BM25", "fox jumping"]]]
The function used to calculate vector similarity. Possible values are
cosine_distance
or euclidean_squared
.
Number of results to return.
Return vector values in the response.
List of attribute names to return in the response. Can be set to true
to
return all attributes.
Filters provide a way to refine search results by matching against attributes.
For the best performance, prefer to separate documents into namespaces instead of filtering where possible.
See Filtering Parameters below for details.
// Request payload
{
"vector": [0.1, 0.1],
"distance_metric": "euclidean_squared",
"top_k": 10
}
// Response payload
[
{
"dist": 0.0,
"id": 1
},
{
"dist": 2.0,
"id": 2
},
...
]
By default, only the distance and ID are returned.
If include_vectors
is true, the associated vector is included in the vector
key.
If include_attributes
contains any attribute names, those attributes are included in the attributes
key.
// Request payload
{
"vector": [0.1, 0.1],
"distance_metric": "euclidean_squared",
"top_k": 10,
"include_vectors": true,
"include_attributes": ["key1"]
}
// Response payload
[
{
"dist": 0.0,
"id": 1,
"vector": [0.1, 0.1],
"attributes": {"key1": "one"}
},
{
"dist": 2.0,
"id": 2,
"vector": [0.2, 0.2],
"attributes": {"key1": "two"}
},
...
]
Filters allow you to narrow down results by applying conditions to attributes. Conditions are arrays with an attribute name, operation, and value, for example:
["attr_name", "Eq", 42]
["page_id", "In", ["page1", "page2"]]
Values must have the same type as the attribute's value, or an array of that type for operators like In.
Conditions can be combined using And/Or operations:
// basic And condition
"filters": ["And", [
["attr_name", "Eq", 42],
["page_id", "In", ["page1", "page2"]]
]]
// conditions can be nested
"filters": ["And", [
["page_id", "In", ["page1", "page2"]],
["Or", [
["public", "Eq", 1],
["permission_id", "In", ["3iQK2VC4", "wzw8zpnQ"]]
]]
]]
// legacy API: an object may provided instead (implicitly And)
"filters": {
"attr_name": ["Eq", 42],
"page_id": ["In", ["page1", "page2"]],
}
Filters can also be applied to the id
field, which refers to the document ID.
If filtering by id
, the filter operation must be Eq
with a number value, or In
with an array of numbers.
A filter on the id
field will be evaluated as a pre-filter;
i.e. the documents will be fetched by ID, then other filters and the kNN search will be applied.
Exact match for id
or attributes
values.
Inverse of Eq
, for attributes
values.
Matches any id
or attributes
values contained in the provided list. If both the provided value and the target document field are arrays, then this checks if any elements of the two sets intersect.
Inverse of In
, matches any attributes
values not contained in the provided list.
For ints, this is a numeric less-than on attributes
values. For strings, lexicographic less-than.
For ints, this is a numeric less-than-or-equal on attributes
values. For strings, lexicographic less-than-or-equal.
For ints, this is a numeric greater-than on attributes
values. For strings, lexicographic greater-than.
For ints, this is a numeric greater-than-or-equal on attributes
values. For strings, lexicographic greater-than-or-equal.
Unix-style glob match against attributes
values. The full syntax is described in the globset documentation.
Inverse of Glob
, Unix-style glob filters against attributes
values. The full syntax is described in the globset documentation.
Case insensitive version of Glob
.
Case insensitive version of NotGlob
.
Matches if all of the filters match.
Matches if at least one of the filters matches.
{
"vector": [0.1, 0.1],
"distance_metric": "euclidean_squared",
"top_k": 10,
"include_attributes": ["key1"],
"filters": [
"And",
[
["id", "In", [1, 2, 3]],
["key1", "Eq", "one"],
["filename", "NotGlob", "/vendor/**"],
[
"Or",
[
["filename", "Glob", "**.tsx"],
["filename", "Glob", "**.js"]
]
]
]
]
}
When querying without passing vector
or rank_by
fields, this endpoint performs a filter-only search. This mode of operation allows pagination over the contents of a namespace, and supports filtering.
This can be used to delete by filter, by subsequently deleting IDs returned from the search.
Results are sorted in ascending ID order, which allows pagination with an ID greater-than filter. For example,
{"top_k": 10, "filters": ["foo", "Eq", "bar"]}
[{"id": 3}, ..., {"id": 14}]
{"top_k": 10, "filters": ["And", [["foo", "Eq", "bar"], ["id", "Gt", 14]]]}
[{"id": 15}, ...]
Caveats:
Eq
, In
, Lt
, Lte
, Gt
, Gte
, And
and Or
filters (for any non-ID field)