From 0457ba10ac5b83da741820e38bbbd308530f396e Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Sun, 22 Oct 2023 17:16:10 +0000 Subject: [PATCH 1/6] Build: Released 3.1.0 [skip ci] # [3.1.0](https://github.com/ashvardanian/simsimd/compare/v3.0.0...v3.1.0) (2023-10-22) ### Add * Cachaing for hardware capabilities ([5903954](https://github.com/ashvardanian/simsimd/commit/59039546eed596551b88867d5856ef214a382eb4)) ### Fix * SVE dispatch ([f4a8012](https://github.com/ashvardanian/simsimd/commit/f4a801254383d436a7cc68f664b93e48ad89b94b)) ### Improve * Batch benchmarks using USearch ([445b450](https://github.com/ashvardanian/simsimd/commit/445b4500bc44cce6477eba731e8e3310b989a6c5)) --- VERSION | 2 +- package.json | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/VERSION b/VERSION index 4a36342f..fd2a0186 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -3.0.0 +3.1.0 diff --git a/package.json b/package.json index 0142c564..83884246 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "simsimd", - "version": "3.0.0", + "version": "3.1.0", "description": "Vector Similarity Functions 3x-200x Faster than SciPy and NumPy", "author": "Ash Vardanian", "license": "Apache 2.0", @@ -29,9 +29,9 @@ "benchmark": "^2.1.4", "conventional-changelog-eslint": "^3.0.9", "mathjs": "^11.11.2", - "usearch": "^2.7.2", "node-gyp": "^8.3.0", "semantic-release": "^21.1.2", - "typescript": "^5.1.6" + "typescript": "^5.1.6", + "usearch": "^2.7.2" } } From 2bb2c5791fa972b37fc1facef3fff98c078077a1 Mon Sep 17 00:00:00 2001 From: Ash Vardanian <1983160+ashvardanian@users.noreply.github.com> Date: Sun, 22 Oct 2023 23:49:22 +0000 Subject: [PATCH 2/6] Fix: Prefer AVX512 to AVX2 and SVE to NEON --- include/simsimd/simsimd.h | 142 +++++++++++++++++++++----------------- 1 file changed, 79 insertions(+), 63 deletions(-) diff --git a/include/simsimd/simsimd.h b/include/simsimd/simsimd.h index 49b46257..ef6fc2d7 100644 --- a/include/simsimd/simsimd.h +++ b/include/simsimd/simsimd.h @@ -213,28 +213,31 @@ inline static void simsimd_find_metric_punned( // #if SIMSIMD_TARGET_ARM_NEON if (viable & simsimd_cap_arm_neon_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_ip, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_cos, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_l2sq, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_js, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_kl, *c = simsimd_cap_arm_neon_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_ip, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_cos, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_l2sq, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_js, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f32_kl, *c = simsimd_cap_arm_neon_k; return; + default: break; } #endif #if SIMSIMD_TARGET_X86_AVX512 if (viable & simsimd_cap_x86_avx512_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_ip, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_cos, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_l2sq, *c = simsimd_cap_x86_avx512_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_ip, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_cos, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f32_l2sq, *c = simsimd_cap_x86_avx512_k; return; + default: break; } #endif if (viable & simsimd_cap_serial_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_ip, *c = simsimd_cap_serial_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_cos, *c = simsimd_cap_serial_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_l2sq, *c = simsimd_cap_serial_k; break; - case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_js, *c = simsimd_cap_serial_k; break; - case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_kl, *c = simsimd_cap_serial_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_ip, *c = simsimd_cap_serial_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_cos, *c = simsimd_cap_serial_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_l2sq, *c = simsimd_cap_serial_k; return; + case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_js, *c = simsimd_cap_serial_k; return; + case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f32_kl, *c = simsimd_cap_serial_k; return; + default: break; } break; @@ -242,48 +245,53 @@ inline static void simsimd_find_metric_punned( // // Half-precision floating-point vectors case simsimd_datatype_f16_k: - #if SIMSIMD_TARGET_ARM_NEON - if (viable & simsimd_cap_arm_neon_k) - switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_ip, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_cos, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_l2sq, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_js, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_kl, *c = simsimd_cap_arm_neon_k; break; - } - #endif #if SIMSIMD_TARGET_ARM_SVE if (viable & simsimd_cap_arm_sve_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_ip, *c = simsimd_cap_arm_sve_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_cos, *c = simsimd_cap_arm_sve_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_l2sq, *c = simsimd_cap_arm_sve_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_ip, *c = simsimd_cap_arm_sve_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_cos, *c = simsimd_cap_arm_sve_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_sve_f16_l2sq, *c = simsimd_cap_arm_sve_k; return; + default: break; } #endif - #if SIMSIMD_TARGET_X86_AVX2 - if (viable & simsimd_cap_x86_avx2_k) + #if SIMSIMD_TARGET_ARM_NEON + if (viable & simsimd_cap_arm_neon_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_ip, *c = simsimd_cap_x86_avx2_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_cos, *c = simsimd_cap_x86_avx2_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_l2sq, *c = simsimd_cap_x86_avx2_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_ip, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_cos, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_l2sq, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_js, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_neon_f16_kl, *c = simsimd_cap_arm_neon_k; return; + default: break; } #endif #if SIMSIMD_TARGET_X86_AVX512 if (viable & simsimd_cap_x86_avx512_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_ip, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_cos, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_l2sq, *c = simsimd_cap_x86_avx512_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_ip, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_cos, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_f16_l2sq, *c = simsimd_cap_x86_avx512_k; return; + default: break; + } + #endif + #if SIMSIMD_TARGET_X86_AVX2 + if (viable & simsimd_cap_x86_avx2_k) + switch (kind) { + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_ip, *c = simsimd_cap_x86_avx2_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_cos, *c = simsimd_cap_x86_avx2_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_f16_l2sq, *c = simsimd_cap_x86_avx2_k; return; + default: break; } #endif if (viable & simsimd_cap_serial_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_ip, *c = simsimd_cap_serial_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_cos, *c = simsimd_cap_serial_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_l2sq, *c = simsimd_cap_serial_k; break; - case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_js, *c = simsimd_cap_serial_k; break; - case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_kl, *c = simsimd_cap_serial_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_ip, *c = simsimd_cap_serial_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_cos, *c = simsimd_cap_serial_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_l2sq, *c = simsimd_cap_serial_k; return; + case simsimd_metric_js_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_js, *c = simsimd_cap_serial_k; return; + case simsimd_metric_kl_k: *m = (simsimd_metric_punned_t)&simsimd_serial_f16_kl, *c = simsimd_cap_serial_k; return; + default: break; } break; @@ -293,33 +301,37 @@ inline static void simsimd_find_metric_punned( // #if SIMSIMD_TARGET_ARM_NEON if (viable & simsimd_cap_arm_neon_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_ip, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_cos, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_l2sq, *c = simsimd_cap_arm_neon_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_ip, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_cos, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_neon_i8_l2sq, *c = simsimd_cap_arm_neon_k; return; + default: break; } #endif - #if SIMSIMD_TARGET_X86_AVX2 - if (viable & simsimd_cap_x86_avx2_k) + #if SIMSIMD_TARGET_X86_AVX512 + if (viable & simsimd_cap_x86_avx512_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_ip, *c = simsimd_cap_x86_avx2_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_cos, *c = simsimd_cap_x86_avx2_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_l2sq, *c = simsimd_cap_x86_avx2_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_ip, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_cos, *c = simsimd_cap_x86_avx512_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_l2sq, *c = simsimd_cap_x86_avx512_k; return; + default: break; } #endif - #if SIMSIMD_TARGET_X86_AVX512 - if (viable & simsimd_cap_x86_avx512_k) + #if SIMSIMD_TARGET_X86_AVX2 + if (viable & simsimd_cap_x86_avx2_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_ip, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_cos, *c = simsimd_cap_x86_avx512_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_i8_l2sq, *c = simsimd_cap_x86_avx512_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_ip, *c = simsimd_cap_x86_avx2_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_cos, *c = simsimd_cap_x86_avx2_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_avx2_i8_l2sq, *c = simsimd_cap_x86_avx2_k; return; + default: break; } #endif if (viable & simsimd_cap_serial_k) switch (kind) { - case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_ip, *c = simsimd_cap_serial_k; break; - case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_cos, *c = simsimd_cap_serial_k; break; - case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_l2sq, *c = simsimd_cap_serial_k; break; + case simsimd_metric_ip_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_ip, *c = simsimd_cap_serial_k; return; + case simsimd_metric_cos_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_cos, *c = simsimd_cap_serial_k; return; + case simsimd_metric_l2sq_k: *m = (simsimd_metric_punned_t)&simsimd_serial_i8_l2sq, *c = simsimd_cap_serial_k; return; + default: break; } break; @@ -330,29 +342,33 @@ inline static void simsimd_find_metric_punned( // #if SIMSIMD_TARGET_ARM_NEON if (viable & simsimd_cap_arm_neon_k) switch (kind) { - case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_neon_b8_hamming, *c = simsimd_cap_arm_neon_k; break; - case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_neon_b8_jaccard, *c = simsimd_cap_arm_neon_k; break; + case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_neon_b8_hamming, *c = simsimd_cap_arm_neon_k; return; + case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_neon_b8_jaccard, *c = simsimd_cap_arm_neon_k; return; + default: break; } #endif #if SIMSIMD_TARGET_ARM_SVE if (viable & simsimd_cap_arm_sve_k) switch (kind) { - case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_sve_b8_hamming, *c = simsimd_cap_arm_sve_k; break; - case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_sve_b8_jaccard, *c = simsimd_cap_arm_sve_k; break; + case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_sve_b8_hamming, *c = simsimd_cap_arm_sve_k; return; + case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_sve_b8_jaccard, *c = simsimd_cap_arm_sve_k; return; + default: break; } #endif #if SIMSIMD_TARGET_X86_AVX512 if (viable & simsimd_cap_x86_avx512vpopcntdq_k) switch (kind) { - case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_b8_hamming, *c = simsimd_cap_x86_avx512vpopcntdq_k; break; - case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_b8_jaccard, *c = simsimd_cap_x86_avx512vpopcntdq_k; break; + case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_b8_hamming, *c = simsimd_cap_x86_avx512vpopcntdq_k; return; + case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_avx512_b8_jaccard, *c = simsimd_cap_x86_avx512vpopcntdq_k; return; + default: break; } #endif if (viable & simsimd_cap_serial_k) switch (kind) { - case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_serial_b8_hamming, *c = simsimd_cap_serial_k; break; - case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_serial_b8_jaccard, *c = simsimd_cap_serial_k; break; + case simsimd_metric_hamming_k: *m = (simsimd_metric_punned_t)&simsimd_serial_b8_hamming, *c = simsimd_cap_serial_k; return; + case simsimd_metric_jaccard_k: *m = (simsimd_metric_punned_t)&simsimd_serial_b8_jaccard, *c = simsimd_cap_serial_k; return; + default: break; } break; From 2cd8bd999f1d33adb7fec3cca68d373390098658 Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Sun, 22 Oct 2023 23:50:08 +0000 Subject: [PATCH 3/6] Build: Released 3.1.1 [skip ci] ## [3.1.1](https://github.com/ashvardanian/simsimd/compare/v3.1.0...v3.1.1) (2023-10-22) ### Fix * Prefer AVX512 to AVX2 and SVE to NEON ([2bb2c57](https://github.com/ashvardanian/simsimd/commit/2bb2c5791fa972b37fc1facef3fff98c078077a1)) --- VERSION | 2 +- package.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/VERSION b/VERSION index fd2a0186..94ff29cc 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -3.1.0 +3.1.1 diff --git a/package.json b/package.json index 83884246..2be89dcd 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "simsimd", - "version": "3.1.0", + "version": "3.1.1", "description": "Vector Similarity Functions 3x-200x Faster than SciPy and NumPy", "author": "Ash Vardanian", "license": "Apache 2.0", From 32d470f6e9adb4ac8d125ec0a537765978754e2c Mon Sep 17 00:00:00 2001 From: Ash Vardanian <1983160+ashvardanian@users.noreply.github.com> Date: Sun, 22 Oct 2023 23:54:43 +0000 Subject: [PATCH 4/6] Make: Rebasing the branch --- .github/workflows/release.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index cf4ebf33..f948312a 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -40,8 +40,9 @@ jobs: - name: Perform rebase run: | + git fetch origin main git checkout main-dev - git rebase main + git rebase origin/main - name: Push changes uses: CasperWA/push-protected@v2 From 0b409e41b6f6ad4785007b89f71b84633b937316 Mon Sep 17 00:00:00 2001 From: semantic-release-bot Date: Sun, 22 Oct 2023 23:55:53 +0000 Subject: [PATCH 5/6] Build: Released 3.1.2 [skip ci] ## [3.1.2](https://github.com/ashvardanian/simsimd/compare/v3.1.1...v3.1.2) (2023-10-22) ### Make * Rebasing the branch ([32d470f](https://github.com/ashvardanian/simsimd/commit/32d470f6e9adb4ac8d125ec0a537765978754e2c)) --- VERSION | 2 +- package.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/VERSION b/VERSION index 94ff29cc..ef538c28 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -3.1.1 +3.1.2 diff --git a/package.json b/package.json index 2be89dcd..f0fe3573 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "simsimd", - "version": "3.1.1", + "version": "3.1.2", "description": "Vector Similarity Functions 3x-200x Faster than SciPy and NumPy", "author": "Ash Vardanian", "license": "Apache 2.0", From 5f05eb3547d9434405fe07f82a094a4078b348fe Mon Sep 17 00:00:00 2001 From: Ash Vardanian <1983160+ashvardanian@users.noreply.github.com> Date: Mon, 23 Oct 2023 00:38:18 +0000 Subject: [PATCH 6/6] Make: Freeze Ubuntu 22.04 for builds --- .github/workflows/release.yml | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index f948312a..f2ec35ab 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -59,7 +59,7 @@ jobs: strategy: fail-fast: false matrix: - os: [ubuntu-20.04, macOS-11, windows-2022] + os: [ubuntu-22.04, macOS-11, windows-2022] steps: - uses: actions/checkout@v3 with: @@ -67,11 +67,11 @@ jobs: - uses: actions/setup-python@v3 - name: Setup Docker - if: matrix.os == 'ubuntu-20.04' + if: matrix.os == 'ubuntu-22.04' uses: docker-practice/actions-setup-docker@master - name: Setup QEMU - if: matrix.os == 'ubuntu-20.04' + if: matrix.os == 'ubuntu-22.04' uses: docker/setup-qemu-action@v2.1.0 - name: Install CIBuildWheel @@ -88,7 +88,7 @@ jobs: publish_python: name: Publish Python needs: build_wheels - runs-on: ubuntu-20.04 + runs-on: ubuntu-22.04 environment: name: pypi url: https://pypi.org/p/simsimd @@ -111,7 +111,7 @@ jobs: publish_javascript: name: Publish JavaScript needs: versioning - runs-on: ubuntu-latest + runs-on: ubuntu-22.04 steps: - uses: actions/checkout@v3 with: