All notable changes to this project are documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning. See the CONTRIBUTING guide for instructions on how to add changelog entries.
- Removed JDK 11 and 17 version from CI runs #1921
- Add Support for Multi Values in innerHit for Nested k-NN Fields in Lucene and FAISS (#2283)[opensearch-project#2283]
- Add binary index support for Lucene engine. (#2292)[opensearch-project#2292]
- Add expand_nested_docs Parameter support to NMSLIB engine (#2331)[opensearch-project#2331]
- Introduced a writing layer in native engines where relies on the writing interface to process IO. (#2241)[opensearch-project#2241]
- Allow method parameter override for training based indices (#2290) https://github.com/opensearch-project/k-NN/pull/2290]
- Optimizes lucene query execution to prevent unnecessary rewrites (#2305)[opensearch-project#2305]
- Add check to directly use ANN Search when filters match all docs. (#2320)[opensearch-project#2320]
- Use one formula to calculate cosine similarity (#2357)[opensearch-project#2357]
- Add WithFieldName implementation to KNNQueryBuilder (#2398)[opensearch-project#2398]
- Make the build work for M series MacOS without manual code changes and local JAVA_HOME config (#2397)[opensearch-project#2397]
- Fixing the bug when a segment has no vector field present for disk based vector search (#2282)[opensearch-project#2282]
- Fixing the bug where search fails with "fields" parameter for an index with a knn_vector field (#2314)[opensearch-project#2314]
- Fix for NPE while merging segments after all the vector fields docs are deleted (#2365)[opensearch-project#2365]
- Allow validation for non knn index only after 2.17.0 (#2315)[opensearch-project#2315]
- Fixing the bug to prevent updating the index.knn setting after index creation(#2348)[opensearch-project#2348]
- Release query vector memory after execution (#2346)[opensearch-project#2346]
- Fix shard level rescoring disabled setting flag (#2352)[opensearch-project#2352]
- Fix filter rewrite logic which was resulting in getting inconsistent / incorrect results for cases where filter was getting rewritten for shards (#2359)[opensearch-project#2359]
- Fixing it to retrieve space_type from index setting when both method and top level don't have the value. #2374
- Updated C++ version in JNI from c++11 to c++17 #2259
- Upgrade bytebuddy and objenesis version to match OpenSearch core and, update github ci runner for macos #2279
- Select index settings based on cluster version2236
- Added periodic cache maintenance for QuantizationStateCache and NativeMemoryCache #2308
- Added null checks for fieldInfo in ExactSearcher to avoid NPE while running exact search for segments with no vector field (#2278)[opensearch-project#2278]
- Added Lucene BWC tests (#2313)[opensearch-project#2313]
- Upgrade jsonpath from 2.8.0 to 2.9.02325
- Bump Faiss commit from 1f42e81 to 0cbc2a8 to accelerate hamming distance calculation using _mm512_popcnt_epi64 intrinsic and also add avx512-fp16 instructions to boost performance #2381
- Enabled indices.breaker.total.use_real_memory setting via build.gradle for integTest Cluster to catch heap CB in local ITs and github CI actions #2395