Skip to content

YuexuanXu7/iRangeGraph

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

iRangeGraph

This repo is the implementation of iRangeGraph: Improvising Range-dedicated Graphs for Range-filtering Nearest Neighbor Search

Quick Start

Build

mkdir build && cd build && cmake .. && make

Construct Index

parameters:

--data_path: The input data over which to build an index, in .bin format. The first 4 bytes represent number of points as integer. The next 4 bytes represent the dimension of data as integer. The following n*d*sizeof(float) bytes contain the contents of the data one data point in a time. The data points should be already sorted in ascending order by the attribute.

--index_file: The constructed index will be saved to this file, in .bin format.

--M: The degree of the graph index.

--ef_construction: The size of result set during index building.

--threads: The number of threads for index building.

command:

./tests/buildindex --data_path [path to data points] --index_file [file path to save index] --M [integer] --ef_construction [integer] --threads [integer]

Search For Single-Attribute

parameters:

--data_path: The data points over which the index is built, in .bin format. The first 4 bytes represent number of points as integer. The next 4 bytes represent the dimension of data as integer. The following n*d*sizeof(float) bytes contain the contents of the data one data point in a time. The data points should be already sorted in ascending order by the attribute.

--query_path: The query vectors, in .bin format. The first 4 bytes represent number of points as integer. The next 4 bytes represent the dimension of data as integer. The following n*d*sizeof(float) bytes contain the contents of the query one query point in a time.

--range_saveprefix: The path of folder where query range files will be saved. 0~9 denotes query range fractions formula respectively, and 17 denotes mixed range fraction.

--groundtruth_saveprefix: The path of folder where groundtruth files will be saved.

--index_file: The file path where the constructed index is saved, in .bin format.

--result_saveprefix: The path of folder where result files will be saved.

--M: The degree of the graph index. It should equal the 'M' used for constructing index.

command:

./tests/search --data_path [path to data points] --query_path [path to query points] --range_saveprefix [folder path to save query ranges] --groundtruth_saveprefix [folder path to save groundtruth] --index_file [path of the index file] --result_saveprefix [folder path to save results] --M [integer]

Search For Multi-Attribute

parameter:

--data_path: The data points over which the index is built, in .bin format. The first 4 bytes represent number of points as integer. The next 4 bytes represent the dimension of data as integer. The following n*d*sizeof(float) bytes contain the contents of the data one data point in a time. There is no need to pre-sort the data points by any attribute. Just make sure data points and attribute1 and attribute2 match one by one in order.

--query_path: The query vectors, in .bin format. The first 4 bytes represent number of points as integer. The next 4 bytes represent the dimension of data as integer. The following n*d*sizeof(float) bytes contain the contents of the query one query point in a time.

--range_saveprefix: The path of folder where query range files will be saved.

--groundtruth_saveprefix: The path of folder where groundtruth files will be saved.

--index_file: The file path where the constructed index is saved, which is built with data points sorted by the first attribute (See Construct Index, note that the data points should be pre-sorted by attribute1 when building the index).

--result_saveprefix: The path of folder where result files will be saved.

--attribute1_file: The path of the first attribute file, in .bin format. n*sizeof(int) bytes contain the first attributes of the data for one data point in a time.

--attribute2_file: The path of the second attribute file, in .bin format. n*sizeof(int) bytes contain the second attributes of the data for one data point in a time.

--M: The degree of the graph index. It should equal the 'M' used for constructing index by the first attribute.

command:

./tests/search_multi --data_path [path to data points] --query_path [path to query points] --range_saveprefix [folder path to save query ranges] --groundtruth_saveprefix [folder path to save groundtruth] --index_file [path of the index file] --result_saveprefix [folder path to save results] --attribute1 [path to first attributes] --attribute2 [path to second attributes] --M [integer]

Datasets

Dataset Vector Type Dimension Attribute Type
WIT image 2048 image size
TripClick text 768 publication date
Redcaps multi-modality 512 timestamp
YouTube-RGB video 1024 # of likes, # of comments
YouTube-Audio audio 128 publish time, # of views

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published