Skip to content

Chrisdehe/my_GNNS

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 

Repository files navigation

my_GNNS

job1

This is a CPU version of GNNS algorithm implemented in python, with Fast Approximate Nearest-Neighbor Search with k-Nearest Neighbor Graph for reference.

The example input of this demo are 10 points, and parameters are as follows:

parameter implication
k = 3 a 3-NN graph
K = 4 pick the first 4 elements as the result
E = 3 each step returns the first 3 neighbors of query node in the graph
D = 2 2 dimension graph
N = 10 10 points in total
R = 5 5 random restarts
T = 5 5 greedy steps

job2

introduction

This is an implement of the approximate algorithm to construct a k-Nearest Neighbor Grpah, with Efficient K-Nearest Neighbor Graph Construction for Generic Similarity Measures for reference.

To run the program correctly, you are supposed to download the dataset sift1M and modify the path of the input file. The code is written by C/C++, which can be compiled by g++.

experiment

Exp1

Set K=7, while N=10000, 20000, 50000, 100000, 200000 respectively, and record the time cost, which is shown in the following table.

image1

Using the cftool in matlab, I get the approximate relation between time-cost and the size of N: y= 0.0001162x1.263

image2

Exp2

Set N=100000, while K=2, 5, 7, 10 respectively, and record the time cost, which is shown in the following table.

image3

Using the cftool in matlab, I get the approximate relation between time-cost and the size of K: y= 36.28x0.9805

image4

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 77.4%
  • Python 22.6%