Files
greptimedb/tests/cases/standalone/common/function/vector/vector.result
Lin Yihai fdbfebf4be feat: Add VEC_PRODUCT, VEC_ELEM_PRODUCT, VEC_NORM. (#5303)
* feat: Add `vec_product(col)` function.

* feat: Add `vec_elem_product` function

* feat: Add `vec_norm` function.
2025-01-09 06:26:51 +00:00

233 lines
11 KiB
Plaintext

SELECT vec_to_string(parse_vec('[1.0, 2.0]'));
+----------------------------------------------+
| vec_to_string(parse_vec(Utf8("[1.0, 2.0]"))) |
+----------------------------------------------+
| [1,2] |
+----------------------------------------------+
SELECT vec_to_string(parse_vec('[1.0, 2.0, 3.0]'));
+---------------------------------------------------+
| vec_to_string(parse_vec(Utf8("[1.0, 2.0, 3.0]"))) |
+---------------------------------------------------+
| [1,2,3] |
+---------------------------------------------------+
SELECT vec_to_string(parse_vec('[]'));
+--------------------------------------+
| vec_to_string(parse_vec(Utf8("[]"))) |
+--------------------------------------+
| [] |
+--------------------------------------+
SELECT vec_to_string(vec_mul('[1.0, 2.0]', '[3.0, 4.0]'));
+---------------------------------------------------------------+
| vec_to_string(vec_mul(Utf8("[1.0, 2.0]"),Utf8("[3.0, 4.0]"))) |
+---------------------------------------------------------------+
| [3,8] |
+---------------------------------------------------------------+
SELECT vec_to_string(vec_mul(parse_vec('[1.0, 2.0]'), '[3.0, 4.0]'));
+--------------------------------------------------------------------------+
| vec_to_string(vec_mul(parse_vec(Utf8("[1.0, 2.0]")),Utf8("[3.0, 4.0]"))) |
+--------------------------------------------------------------------------+
| [3,8] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_mul('[1.0, 2.0]', parse_vec('[3.0, 4.0]')));
+--------------------------------------------------------------------------+
| vec_to_string(vec_mul(Utf8("[1.0, 2.0]"),parse_vec(Utf8("[3.0, 4.0]")))) |
+--------------------------------------------------------------------------+
| [3,8] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_sub('[1.0, 1.0]', '[1.0, 2.0]'));
+---------------------------------------------------------------+
| vec_to_string(vec_sub(Utf8("[1.0, 1.0]"),Utf8("[1.0, 2.0]"))) |
+---------------------------------------------------------------+
| [0,-1] |
+---------------------------------------------------------------+
SELECT vec_to_string(vec_sub('[-1.0, -1.0]', '[1.0, 2.0]'));
+-----------------------------------------------------------------+
| vec_to_string(vec_sub(Utf8("[-1.0, -1.0]"),Utf8("[1.0, 2.0]"))) |
+-----------------------------------------------------------------+
| [-2,-3] |
+-----------------------------------------------------------------+
SELECT vec_to_string(vec_sub('[1.0, 1.0]', parse_vec('[1.0, 2.0]')));
+--------------------------------------------------------------------------+
| vec_to_string(vec_sub(Utf8("[1.0, 1.0]"),parse_vec(Utf8("[1.0, 2.0]")))) |
+--------------------------------------------------------------------------+
| [0,-1] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_sub('[-1.0, -1.0]', parse_vec('[1.0, 2.0]')));
+----------------------------------------------------------------------------+
| vec_to_string(vec_sub(Utf8("[-1.0, -1.0]"),parse_vec(Utf8("[1.0, 2.0]")))) |
+----------------------------------------------------------------------------+
| [-2,-3] |
+----------------------------------------------------------------------------+
SELECT vec_to_string(vec_sub(parse_vec('[1.0, 1.0]'), '[1.0, 2.0]'));
+--------------------------------------------------------------------------+
| vec_to_string(vec_sub(parse_vec(Utf8("[1.0, 1.0]")),Utf8("[1.0, 2.0]"))) |
+--------------------------------------------------------------------------+
| [0,-1] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_sub(parse_vec('[-1.0, -1.0]'), '[1.0, 2.0]'));
+----------------------------------------------------------------------------+
| vec_to_string(vec_sub(parse_vec(Utf8("[-1.0, -1.0]")),Utf8("[1.0, 2.0]"))) |
+----------------------------------------------------------------------------+
| [-2,-3] |
+----------------------------------------------------------------------------+
SELECT vec_elem_sum('[1.0, 2.0, 3.0]');
+---------------------------------------+
| vec_elem_sum(Utf8("[1.0, 2.0, 3.0]")) |
+---------------------------------------+
| 6.0 |
+---------------------------------------+
SELECT vec_elem_sum('[-1.0, -2.0, -3.0]');
+------------------------------------------+
| vec_elem_sum(Utf8("[-1.0, -2.0, -3.0]")) |
+------------------------------------------+
| -6.0 |
+------------------------------------------+
SELECT vec_elem_sum(parse_vec('[1.0, 2.0, 3.0]'));
+--------------------------------------------------+
| vec_elem_sum(parse_vec(Utf8("[1.0, 2.0, 3.0]"))) |
+--------------------------------------------------+
| 6.0 |
+--------------------------------------------------+
SELECT vec_elem_sum(parse_vec('[-1.0, -2.0, -3.0]'));
+-----------------------------------------------------+
| vec_elem_sum(parse_vec(Utf8("[-1.0, -2.0, -3.0]"))) |
+-----------------------------------------------------+
| -6.0 |
+-----------------------------------------------------+
SELECT vec_to_string(vec_div('[1.0, 2.0]', '[3.0, 4.0]'));
+---------------------------------------------------------------+
| vec_to_string(vec_div(Utf8("[1.0, 2.0]"),Utf8("[3.0, 4.0]"))) |
+---------------------------------------------------------------+
| [0.33333334,0.5] |
+---------------------------------------------------------------+
SELECT vec_to_string(vec_div(parse_vec('[1.0, 2.0]'), '[3.0, 4.0]'));
+--------------------------------------------------------------------------+
| vec_to_string(vec_div(parse_vec(Utf8("[1.0, 2.0]")),Utf8("[3.0, 4.0]"))) |
+--------------------------------------------------------------------------+
| [0.33333334,0.5] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_div('[1.0, 2.0]', parse_vec('[3.0, 4.0]')));
+--------------------------------------------------------------------------+
| vec_to_string(vec_div(Utf8("[1.0, 2.0]"),parse_vec(Utf8("[3.0, 4.0]")))) |
+--------------------------------------------------------------------------+
| [0.33333334,0.5] |
+--------------------------------------------------------------------------+
SELECT vec_to_string(vec_div('[1.0, -2.0]', parse_vec('[0.0, 0.0]')));
+---------------------------------------------------------------------------+
| vec_to_string(vec_div(Utf8("[1.0, -2.0]"),parse_vec(Utf8("[0.0, 0.0]")))) |
+---------------------------------------------------------------------------+
| [inf,-inf] |
+---------------------------------------------------------------------------+
SELECT vec_elem_product('[1.0, 2.0, 3.0, 4.0]');
+------------------------------------------------+
| vec_elem_product(Utf8("[1.0, 2.0, 3.0, 4.0]")) |
+------------------------------------------------+
| 24.0 |
+------------------------------------------------+
SELECT vec_elem_product('[-1.0, -2.0, -3.0, 4.0]');
+---------------------------------------------------+
| vec_elem_product(Utf8("[-1.0, -2.0, -3.0, 4.0]")) |
+---------------------------------------------------+
| -24.0 |
+---------------------------------------------------+
SELECT vec_elem_product(parse_vec('[1.0, 2.0, 3.0, 4.0]'));
+-----------------------------------------------------------+
| vec_elem_product(parse_vec(Utf8("[1.0, 2.0, 3.0, 4.0]"))) |
+-----------------------------------------------------------+
| 24.0 |
+-----------------------------------------------------------+
SELECT vec_elem_product(parse_vec('[-1.0, -2.0, -3.0, 4.0]'));
+--------------------------------------------------------------+
| vec_elem_product(parse_vec(Utf8("[-1.0, -2.0, -3.0, 4.0]"))) |
+--------------------------------------------------------------+
| -24.0 |
+--------------------------------------------------------------+
SELECT vec_to_string(vec_norm('[0.0, 2.0, 3.0]'));
+--------------------------------------------------+
| vec_to_string(vec_norm(Utf8("[0.0, 2.0, 3.0]"))) |
+--------------------------------------------------+
| [0,0.5547002,0.8320503] |
+--------------------------------------------------+
SELECT vec_to_string(vec_norm('[1.0, 2.0, 3.0]'));
+--------------------------------------------------+
| vec_to_string(vec_norm(Utf8("[1.0, 2.0, 3.0]"))) |
+--------------------------------------------------+
| [0.26726124,0.5345225,0.8017837] |
+--------------------------------------------------+
SELECT vec_to_string(vec_norm('[7.0, 8.0, 9.0]'));
+--------------------------------------------------+
| vec_to_string(vec_norm(Utf8("[7.0, 8.0, 9.0]"))) |
+--------------------------------------------------+
| [0.5025707,0.5743665,0.64616233] |
+--------------------------------------------------+
SELECT vec_to_string(vec_norm('[7.0, -8.0, 9.0]'));
+---------------------------------------------------+
| vec_to_string(vec_norm(Utf8("[7.0, -8.0, 9.0]"))) |
+---------------------------------------------------+
| [0.5025707,-0.5743665,0.64616233] |
+---------------------------------------------------+
SELECT vec_to_string(vec_norm(parse_vec('[7.0, -8.0, 9.0]')));
+--------------------------------------------------------------+
| vec_to_string(vec_norm(parse_vec(Utf8("[7.0, -8.0, 9.0]")))) |
+--------------------------------------------------------------+
| [0.5025707,-0.5743665,0.64616233] |
+--------------------------------------------------------------+