🚀 Try Zilliz Cloud, the fully managed Milvus, for free—experience 10x faster performance! Try Now>>

milvus-logo
LFAI
Home
  • Concepts

Metric Types

Similarity metrics are used to measure similarities among vectors. Choosing an appropriate distance metric helps improve classification and clustering performance significantly.

Currently, Milvus supports these types of similarity Metrics: Euclidean distance (L2), Inner Product (IP), Cosine Similarity (COSINE), JACCARD, HAMMING, and BM25 (specifically designed for full text search on sparse vectors).

The table below summarizes the mapping between different field types and their corresponding metric types.

Field Type

Dimension Range

Supported Metric Types

Default Metric Type

FLOAT_VECTOR

2-32,768

COSINE, L2, IP

COSINE

FLOAT16_VECTOR

2-32,768

COSINE, L2, IP

COSINE

BFLOAT16_VECTOR

2-32,768

COSINE, L2, IP

COSINE

SPARSE_FLOAT_VECTOR

No need to specify the dimension.

IP, BM25 (used only for full text search)

IP

BINARY_VECTOR

8-32,768*8

HAMMING, JACCARD

HAMMING

  • For vector fields of the SPARSE_FLOAT_VECTOR type, use the BM25 metric type only when performing full text search. For more information, refer to Full Text Search.

  • For vector fields of the BINARY_VECTOR type, the dimension value (dim) must be a multiple of 8.

The table below summarizes the characteristics of the similarity distance values of all supported metric types and their value range.

Metric Type

Characteristics of the Similarity Distance Values

Similarity Distance Value Range

L2

A smaller value indicates a greater similarity.

[0, ∞)

IP

A greater value indicates a greater similarity.

[-1, 1]

COSINE

A greater value indicates a greater similarity.

[-1, 1]

JACCARD

A smaller value indicates a greater similarity.

[0, 1]

HAMMING

A smaller value indicates a greater similarity.

[0, dim(vector)]

BM25

Score the relevance based on the term frequency, inverted document frequency, and document normalization.

[0, ∞)

Euclidean distance (L2)

Essentially, Euclidean distance measures the length of a segment that connects 2 points.

The formula for Euclidean distance is as follows:

Euclidean distance formula Euclidean distance formula

where a = (a0, a1,…, an-1) and b = (b0, b1,…, bn-1) are two points in n-dimensional Euclidean space.

It’s the most commonly used distance metric and is very useful when the data are continuous.

Milvus only calculates the value before applying the square root when Euclidean distance is chosen as the distance metric.

Inner product (IP)

The IP distance between two embeddings is defined as follows:

Inner product formula Inner product formula

IP is more useful if you need to compare non-normalized data or when you care about magnitude and angle.

If you use IP to calculate similarities between embeddings, you must normalize your embeddings. After normalization, the inner product equals cosine similarity.

Suppose X’ is normalized from embedding X:

Normalized inner product formula Normalized inner product formula

The correlation between the two embeddings is as follows:

Correlation between embeddings Correlation between embeddings

Cosine similarity

Cosine similarity uses the cosine of the angle between two sets of vectors to measure how similar they are. You can think of the two sets of vectors as line segments starting from the same point, such as [0,0,…], but pointing in different directions.

To calculate the cosine similarity between two sets of vectors A = (a0, a1,…, an-1) and B = (b0, b1,…, bn-1), use the following formula:

Cosine similarity formula Cosine similarity formula

The cosine similarity is always in the interval [-1, 1]. For example, two proportional vectors have a cosine similarity of 1, two orthogonal vectors have a similarity of 0, and two opposite vectors have a similarity of -1. The larger the cosine, the smaller the angle between the two vectors, indicating that these two vectors are more similar to each other.

By subtracting their cosine similarity from 1, you can get the cosine distance between two vectors.

JACCARD distance

JACCARD similarity coefficient measures the similarity between two sample sets and is defined as the cardinality of the intersection of the defined sets divided by the cardinality of the union of them. It can only be applied to finite sample sets.

JACCARD similarity coefficient formula JACCARD similarity coefficient formula

JACCARD distance measures the dissimilarity between data sets and is obtained by subtracting the JACCARD similarity coefficient from 1. For binary variables, JACCARD distance is equivalent to the Tanimoto coefficient.

JACCARD distance formula JACCARD distance formula

HAMMING distance

HAMMING distance measures binary data strings. The distance between two strings of equal length is the number of bit positions at which the bits are different.

For example, suppose there are two strings, 1101 1001 and 1001 1101.

11011001 ⊕ 10011101 = 01000100. Since, this contains two 1s, the HAMMING distance, d (11011001, 10011101) = 2.

BM25 similarity

BM25 is a widely used text relevance measurement method, specifically designed for full text search. It combines the following three key factors:

  • Term Frequency (TF): Measures how frequently a term appears in a document. While higher frequencies often indicate greater importance, BM25 uses the saturation parameter k1 to prevent overly frequent terms from dominating the relevance score.

  • Inverse Document Frequency (IDF): Reflects the importance of a term across the entire corpus. Terms appearing in fewer documents receive a higher IDF value, indicating greater contribution to relevance.

  • Document Length Normalization: Longer documents tend to score higher due to containing more terms. BM25 mitigates this bias by normalizing document lengths, with parameter b controlling the strength of this normalization.

The BM25 scoring is calculated as follows:

BM25 similarity formula BM25 similarity formula

Parameter description:

  • Q: The query text provided by the user.

  • D: The document being evaluated.

  • TF(qi,D): Term frequency, representing how often term qi appears in document D.

  • IDF(qi): Inverse document frequency, calculated as:

    IDF formula IDF formula

    where N is the total number of documents in the corpus, and n(qi) is the number of documents containing term qi.

  • ∣D∣: Length of document D (total number of terms).

  • avgdl: Average length of all documents in the corpus.

  • k1: Controls the influence of term frequency on the score. Higher values increase the importance of term frequency. The typical range is [1.2, 2.0], while Milvus allows a range of [0, 3].

  • b: Controls the degree of length normalization, ranging from 0 to 1. When the value is 0, no normalization is applied; when the value is 1, full normalization is applied.

Try Managed Milvus for Free

Zilliz Cloud is hassle-free, powered by Milvus and 10x faster.

Get Started
Feedback

Was this page helpful?