Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/iboud0/hnsw-attribute-filtering-optimization

Optimizing multi-attribute filtering for Approximate Nearest Neighbor (ANN) search using HNSW. This project integrates bitsets and Roaring Bitmaps into HNSWLib to accelerate query performance by reducing evaluation costs for large attribute datasets.
https://github.com/iboud0/hnsw-attribute-filtering-optimization

ann-search approximate-nearest-neighbor bitsets cpp data-structures efficient-filtering hnsw optimization roaring-bitmaps

Last synced: 14 days ago
JSON representation

Optimizing multi-attribute filtering for Approximate Nearest Neighbor (ANN) search using HNSW. This project integrates bitsets and Roaring Bitmaps into HNSWLib to accelerate query performance by reducing evaluation costs for large attribute datasets.

Awesome Lists containing this project

README

        

# HNSW Attribute Filtering Optimization

## Overview
This repository implements an optimized multi-attribute filtering mechanism for Hierarchical Navigable Small World (HNSW) graphs used in Approximate Nearest Neighbor (ANN) search. The goal is to reduce query latency and improve filtering performance for datasets with large attribute spaces (e.g., 1000+ labels per point) by integrating:
- **Bitsets**: For efficient representation and evaluation of attributes.
- **Roaring Bitmaps**: For compact storage and high-performance operations on sparse attributes.

## Features
- **Bitset-based filtering**: Enables rapid evaluation of attribute matches using bitwise operations.
- **Roaring Bitmap integration**: Optimizes storage and set operations for sparse datasets.
- **Dynamic query handling**: Automatically switches between brute-force and ANN search based on filtered set size.
- **HNSWLib enhancements**: Extends HNSW traversal and filtering mechanisms for better performance.

## Project Goals
1. Represent attributes as bitsets and Roaring Bitmaps for efficient filtering.
2. Integrate filtering logic into HNSWLib traversal algorithms.
3. Benchmark performance improvements in query latency and memory consumption.
4. Ensure high recall accuracy and robust performance across various datasets.

## Setup

### Prerequisites

- **C++ Compiler**: GCC, Clang, or equivalent supporting C++17.
- **CMake**: For configuring and building the project.
- **Ninja** (optional): For faster builds (recommended).

### Installation

1. **Clone the repository**:
```bash
git clone https://github.com/your-username/HNSW-Attribute-Filtering-Optimization.git
```

2. **Navigate to the project directory**:
```bash
cd HNSW-Attribute-Filtering-Optimization
```

3. **Create and navigate to the build directory**:
```bash
mkdir build && cd build
```

4. **Build the project**:
```bash
cmake .. -G "Ninja" # Use Ninja for faster builds, or replace with "Unix Makefiles".
ninja # Or use 'make' if "Unix Makefiles" was selected.
```

## Usage

### Running Executables
After building, the executables will be available in the `build` directory. You can run them as follows:

1. **Run the Bitset Filtering Example**:
```bash
./bitset_filter
```

2. **Run the Linear Filtering Example**:
```bash
./linear_filter
```

3. **Run the Roaring Bitmap Filtering Example**:
```bash
./roaring_filter
```

4. **Run the Test Roaring Bitmap**:
```bash
./test_roaring
```

### Output Files
Each filtering example writes its results to a corresponding text file in the `build` directory:

- `bitset_filter_results.txt`
- `linear_filter_results.txt`
- `roaring_filter_results.txt`

#### Running Benchmarks
To evaluate the performance improvements of the optimized filtering:
1. Prepare datasets with varying attribute distributions and save them in a supported format.
2. Run the benchmark tool included in the project:
```bash
./benchmark [dataset_path]
```

#### Modifying Parameters
- Customize the following in `config.h`:
- **Number of attributes per point**: Define the size of the bitsets.
- **Filtering thresholds**: Set constraints for filtering.
- **Traversal parameters**: Adjust HNSW layer configurations and search heuristics.

---

### Contributing
Contributions to the project are welcome! To contribute:
1. Fork this repository.
2. Create a branch for your feature or bug fix:
```bash
git checkout -b feature/your-feature
```
3. Commit your changes with clear messages:
```bash
git commit -m "Add detailed description of changes"
```
4. Push your changes:
```bash
git push origin feature/your-feature
```
5. Open a pull request, explaining your additions or fixes.

---

### Acknowledgments
- The project builds upon the **Hierarchical Navigable Small World Graphs** algorithm. Read the foundational paper here: [HNSW Paper](https://arxiv.org/abs/1603.09320).
- For efficient bitmap operations, we use the [CRoaring Library](https://github.com/RoaringBitmap/CRoaring).

---

### License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.

---

### Contact
For inquiries or feedback, please contact:
- **Ilyas Boudhaine**: [[email protected]](mailto:[email protected])