你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
series_cosine_similarity()
计算两个数值向量的余弦相似度。
函数 series_cosine_similarity()
接受两个数值序列作为输入,并计算它们的余弦相似度。
语法
series_cosine_similarity(
series1,
series2, [
*magnitude1, [
*magnitude2]])
详细了解语法约定。
参数
客户 | 类型 | 必需 | 说明 |
---|---|---|---|
series1, series2 | dynamic |
✔️ | 具有数值数据的输入数组。 |
级1级,级2级 | real |
第一个向量和第二个向量分别的可选数量级。 数量级是矢量本身的点积的平方根。 如果未提供数量级,将对其进行计算。 |
返回
返回一个 real
类型的值,其值为 series1 与 series2 的余弦相似度。
如果两个序列长度不相等,则较长的序列将截断为较短序列的长度。
将忽略输入序列的任何非数值元素。
备注
如果一个或两个输入数组为空,则结果为 null
。
优化性能
为了在使用此函数时提高性能并降低存储要求,请考虑使用 Vector16
编码策略来存储不需要 64 位精度的浮点矢量,例如 ML 矢量嵌入。 利用 Vector16
浮点表示形式的 配置文件可以显著优化操作,并将存储大小减少 4 倍。 有关 Vector16
编码策略的更多详细信息,请参阅编码策略类型。
示例
datatable(s1:dynamic, s2:dynamic)
[
dynamic([0.1,0.2,0.1,0.2]), dynamic([0.11,0.2,0.11,0.21]),
dynamic([0.1,0.2,0.1,0.2]), dynamic([1,2,3,4]),
]
| extend cosine_similarity=series_cosine_similarity(s1, s2)
s1 | s2 | cosine_similarity |
---|---|---|
[0.1,0.2,0.1,0.2] | [0.11,0.2,0.11,0.21] | 0.99935343825504 |
[0.1,0.2,0.1,0.2] | [1,2,3,4] | 0.923760430703401 |