The T1 and T2 tracks of the competition restrict the evaluation of algorithms to standard Azure CPU servers with 64GB of RAM and 2TB of SSD. The only restriction in the T3 track is that the evaluation machine can be any hardware that is commercially available ( including any commercially available add-on PCIe boards ). T3 will maintain four leaderboards:
- One based on recall/average precision
- One based on throughput
- One based on power consumption
- One based on hardware cost
You can see the latest leaderboards' status here.
Participants must submit their algorithm via a pull request and index file(s) upload (one per participating dataset). Participants are not required to submit proprietary source code such as software drivers or firmware.
Competition evaluators will evaluate the participant's algorithm and hardware via one of these options:
- Participants send their hardware to the organizers at the participant's expense.
- Participants give organizers remote access to the hardware.
- Participants run the evaluation benchmarks on their own, and send the results to the organizers.
You will need the following installed on your machine:
- Python ( we tested with Anaconda using an environment created for Python version 3.8.5 )
- Note that we tested everything on Ubuntu Linux 18.04 but other environments should be possible.
- It's assumed that all the software drivers and services need to support your hardware are installed on development machines. For example, to run the T3 baseline, your system must have a Cuda 11 compatibile GPU, Cuda 11.0, and the cuda 11.0 docker run-time installed. See the T3 baseline installation instructions. Cuda versions greater than 11.0 should be possible, but weren't tested.
This section will present a small tutorial about how to use this framework and several of the key scripts you will use throughout the development of your algorithm and eventual submission.
First, clone this repository and cd into the project directory:
git clone <REPO_URL>
Install the python package requirements:
pip install -r requirements.txt
Create a small, sample dataset:
python create_dataset.py --dataset random-xs
Build the docker container for the T3 baseline:
python install.py --dockerfile t3/faiss_t3/Dockerfile
Run a benchmark evaluation using the algorithm's definition file:
python run.py --t3 --definitions t3/faiss_t3/algos.yaml --dataset random-xs
Please note that the --t3 flag is important.
Now analyze the results:
python plot.py --definitions t3/faiss_t3/algos.yaml --dataset random-xs
This will place a plot of the algorithms performance, recall/average_precision-vs-throughput, into the results/ directory.
First, please create a short name for your team without spaces or special characters. Henceforth in these instructions, this will be referenced as [your_team_name].
Create a custom branch off main in this repository:
git checkout -b t3/[your_team_name]
In the t3/ directory, create a sub-directory using that name.
mkdir t3/[your_team_name]
This framework evaluates algorithms in Docker containers by default. Your algorithm's Dockerfile should live in your team's subdirectory at t3/[your_team_name]. Ideally, your Docker file should contain everything needed to install and run your algorithm on a system with the same hardware. Given the nature of T3, this will not likely be entirely possible since custom hardware host drivers and certain low level host libraries require an installation step outside of what can be accomplished with Docker alone. Please make your best effort to include as much installation and setup within your Docker container, as we want to promote as much transparency as possible among all participants.
Please consult the Dockerfile here for an example.
To build your Docker container, run:
python install.py --dockerfile t3/[your_team_name]/Dockerfile
Develop and add your algorithm's python class to the benchmark/algorithms directory.
- You will need to subclass from the BaseANN class and implement the functions of that parent class.
- You should consult the examples already in the directory.
As you develop and test your algorithm, you will likely need to test on smaller datasets. This framework provides a way to create datasets of various sizes. For example, to create a dataset with 10000 20-dimensional random floating point vectors, run:
python create_dataset.py --dataset random-xs
To see a complete list of datasets, run the following:
python create_dataset.py --help
When you are ready to test on the competition datasets, use the create_dataset.py script as follows:
python create_dataset.py --dataset [sift-1B|bigann-1B|text2image-1B|msturing-1B|msspacev-1B|ssnpp-1B]
To benchmark your algorithm, first create an algorithm configuration yaml in your teams directory called algos.yaml. This file contains the index build parameters and query parameters that will get passed to your algorithm at run-time. Please look at this example.
Now you can benchmark your algorithm using the run.py script:
python run.py --t3 --definitions t3/[your_team_name]/algos.yaml --dataset random-xs
This will write the results to the toplevel results directory.
Now you can analyze the results by running:
python plot.py --definitions t3/[your_team_name]/algos.yaml --dataset random-xs
This will place a plot of the algorithms performance, recall/average_precision-vs-throughput, into the toplevel results directory.
The plot.py script supports other benchmarks. To see a complete list, run:
python plot.py --help
A submission is composed of the following:
- 1 index binary file(s) for each dataset for which you are participating (see Index File section below.)
- 1 algos.yaml with only one set of build parameters and at most 10 sets of query parameters for each dataset in which you are participating. Please put that file into the t3/[your_team_name]/ directory.
- Your algorithm's python class ( placed in the benchmark/algorithms/ directory.)
- 1 README file with specific information about your hardware and software (see README File section below.)
- Evidence of the cost of your hardware components (see README File section below.)
- Optional information (see Optional Information section below.)
The binary index file(s) must be http or azcopy accessible and is referenced within your t3/[your_team_name]/algos.yaml config file. Please see the baseline algos.yaml example.
Your submission's top-level directory should contain a README.md with the following sections:
- Hardware Configuration And Cost This section must contain a table that breaks down the hardware components of your system and the cost. Each entry should link to evidence of the component cost.
- Hardware Access This section describes how evaluators acquire access to the hardware (specific instructions or contact information.)
- No Source Declarations This section must contain a list of software components that were not provided with the submission.
- Hardware Setup And Software Installation This section should contain any hardware and software installation instructions.
- Run Competition Algorithm This section should contain instructions to run the competition algorithm, for example, run scripts.
Please consult the baseline README example.
Please feel free to append sections to the base README requirements. For example, you can include other benchmarks of interest.
There are several ways to get help as you develop your algorithm using this framework:
- You can submit an issue at this github repository.
- Send an email to the competition's T3 organizer, [email protected]
- Send en email to the competition's googlegroup, [email protected]
T3 will maintain four different leaderboards 1) one based on recall/average precision 2) one based on throughput 3) one based on power consumption and 4) one based on cost. The details of the ranking metrics are described here.
A performance baseline has been established for this competition, based on both queries per second (qps) and recall/average precision (recall measured as recall@10.) For the recall leaderboard, we will rank participants by recall@10/average precision at 2K qps.
The table below shows the baseline recall@10 for all the (knn search type) datasets at or above 2K qps ( or as close to it as possible. )
dataset | recall@10 |
---|---|
msturing-1B | 0.909 |
bigann-1B | 0.927 |
text2image-1B | 0.860 |
deep-1B | 0.943 |
msspacev-1B | 0.909 |
For the throughput leaderboard, we will rank participants by qps at or above 90% recall@10 (or close to it as possible.) The table below shows the baseline throughput for all the (knn search type) datasets near 90% recall@10.
dataset | qps |
---|---|
msturing-1B | 2359.485 |
bigann-1B | 3086.656 |
text2image-1B | 1762.363 |
deep-1B | 4417.036 |
msspacev-1B | 2770.848 |
The following tables show the baseline performance on the range search dataset:
Instead of recall, the range search dataset utilizes average precision:
dataset | ap |
---|---|
ssnpp-1B | 0.979 |
For throughput:
dataset | qps |
---|---|
ssnpp-1B | 5572.272 |
The following table shows the baseline performance on all datasets for power, shown as watt-seconds/query:
dataset | wspq |
---|---|
msturing-1B | 0.204 |
bigann-1B | 0.167 |
text2image-1B | 0.123 |
deep-1B | 0.113 |
msspacev-1B | 0.167 |
ssnpp-1B | 0.095 |
The following table shows the baseline performance on all datasets for cost:
dataset | cost |
---|---|
msturing-1B | $1,018,332.30 |
bigann-1B | $785,282.45 |
text2image-1B | $1,298,436.77 |
deep-1B | $545,952.10 |
msspacev-1B | $873,460.84 |
ssnpp-1B | $429,634.84 |
Details of how power is measured and how cost is computed are explained further down.
Baselines were measured on an 56 core Intel Xeon system with 700GB RAM and a V100 Nvidia GPU using the FAISS library using the index strategy called IVF1048576,SQ8.
Please consult this document for a detailed discussion about how the baseline is used to inform competition thresholds and participant scoring, as well as recent developments on baseline performance.
This leaderboard leverages the standard recall@10 vs throughput benchmark that has become a standard benchmark when evaluating and comparing approximate nearest neighbor algorithms. We will rank participants based on recall@10/average_precision at 2K qps por each dataset. The evaluation framework allows for 10 different search parameter sets and we will use the best value of recall@10 from the set.
The final ranking will be based on a computed score, which is the sum of the improvements in recall over the baseline for the participating databases. A submission must participate in at least 3 databases.
Participants that cannot meet or exceed the 2000 qps minimum threshold ( or 1762.363 qps for Text2Image ) for a dataset will be dropped from ranking consideration for that dataset.
Please consult this document for a detailed discussion about how the baseline is used to inform competition thresholds and participant scoring.
This leaderboard also leverages the standard recall@10 vs throughput benchmark. We will rank participants based on throughput (qps) at the recall@10 threshold of 90%. The evaluation framework allows for 10 different search parameter sets and we will use the best value of throughput from the set.
The final ranking will be based on a computed score, which is the sum of the improvements in throughput over the baseline for the participating databases. A submission must participate in at least 3 databases.
Please consult this document for a detailed discussion about how the baseline is used to inform competition thresholds and participant scoring.
This leaderboard is related to power consumption, which is an important consideration when scaling applications and servers in a datacenter. The primary ranking metric is ( kilowatt-hour / query.) Participants must meet or exceed the recall@10 and 2000QPS minimum threshold ( for Text2Image, the baseline performance is the minimum threshold.) The reason for those minimum thresholds is to discourage algorithm’s designers from purposefully sacrificing too much performance in order to lower the power consumption.
The evaluation framework leverages the power sensors available in the standard IPMI power management interface of most commercial server chassis’. We also leverage the open source project ipmicap ( https://github.com/fractalsproject/ipmicap ) to capture the power sensors and calculate the power consumption.
During evaluation, for each search parameter set, power consumption is acquired over at least 10 seconds running search on the entire query set. During that 10 seconds, multiple consecutive runs on the query set may occur in order to maintain a minimum duration of 10 seconds. Also, the duration may be greater than 10 seconds if a run of 1 query set takes longer than 10 seconds. So a run could be composed of 1 batch query or several and the duration will be at least 10 seconds The power consumption acquired for the run is divided by the total number of queries performed during the run, resulting in ( kilowatt-hour / query ). Up to 10 search parameter sets are allowed, and we use the minimum value for ranking participants, for each dataset.
The final ranking will be based on a computed score, which is the sum of the improvements in power consumption over the baseline for the participating databases. A submission must participate in at least 3 databases.
There are no direct thresholds for this benchmark/leaderboard. Indirectly, participants that cannot meet or exceed the recall@10 threshold ( or 0.86 for Text2Image ) for a dataset will be dropped from ranking consideration for that dataset. Scoring will be based on the baseline performance for power consumption, shown here for each dataset:
Please consult this document for a detailed discussion about how the baseline is used to inform participant scoring for this benchmark.
This leaderboard is related to cost, which is an important consideration when scaling applications and servers in a datacenter. The primary ranking metric will be an estimate of capital expense (capex) + operational expense (opex) that is required to scale the participant’s system to 100,000 qps that meets or exceeds the baseline recall@10.
The formula for the capex estimate is as follows:
capex = (MSRP of all the hardware components of the system ) X ( minimum number of systems needed to scale to support 100,000 qps )
The hardware components include the chassis and all of the electronics within the chassis including the power supplies, motherboard, HDD/SSD, and all extension boards. Participants must provide evidence of MSRP of components ( either published on a web-site or a copy of a invoice/receipt with customer identifiable information removed. ) Volume based pricing is not considered.
The formula for the opex estimate is as follows:
opex = ( max qps at or greater than the baseline recall @10 threshold ) X ( kilowatt-hour / query ) X ( seconds / hour ) X ( hours / year) X ( 5 years ) X ( dollars / kilowatt-hour ) X ( minimum number of systems needed to scale to support 100,000 qps )
Notes on this formula:
- We will use the maximum qps actually measured that meets or exceeds the baseline recall@10 threshold across all query set parameters.
- We do not account for the cost related to the physical footprint of the system(s) such as the cost of the space occupied by the system(s) in the datacenter.
- We assume linear horizontal scalability of systems with zero cost. In other words, we do not account for the costs associated when actually clustering multiple systems needed to obtain 100,000 qps ( networking equipment, costs due to routing traffic among systems, costs due to merging results, etc. )
- We will use $0.10 / kilowatt-hour for the power consumption cost.
- 5 years is the standard hardware depreciation schedule used for tax purposes with the Internal Revenue Service
- We’d like to thank David Rensin, former Senior Director at Google Cloud, now SVP at Pendo.io for his valuable contribution and consultation with respect to the capex and opex formulas.
The final ranking will be based on a computed score, which is the sum of the improvements in cost over the baseline for the participating databases. A submission must participate in at least 3 databases.
There are no direct thresholds for this benchmark/leaderboard. Indirectly, participants that cannot meet or exceed the recall@10 minimum threshold ( or 0.86 for Text2Image ) for a dataset will be dropped from ranking consideration for that dataset.
How a participant's algorithm is benchmarked will depend on how they registered for the T3 competition, one of these options:
- Participant sent hardware to competition evaluator at participant's expense.
- Participant is giving the competition valuator remote SSH access to their machine.
- Participant will run the evaluation framework on their own and send the benchmark results to the competition evaluator.
Evaluation steps for each option is detailed in the next sections.
Evaluators will work with participant's that send hardware during competition on-boarding. Hardware will be sent and returned at the participant's expense.
Evaluators and participants will work closely to make sure the hardware is properly installed and configured.
Evaluators may allow remote access to the machines in order to complete the setup, as needed.
Participants give competition evaluators access to remote machines via SSH.
This is a very special case, and not all participant's will have this option. In this case, the participant will run the evaluation on their own. They will export the data to a CSV via the export.py script and send it to the the competition evaluators. Participants are still required to submit a pull request and upload their best index.
The hardware chassis which houses all the hardware must support the IPMI management interface.
Determine the IP address, port, and authentication credentials of that interface.
Follow the instructions at IPMICAP open-source project ( http://www.github.com/fractalsproject/ipmicap ) to access the IPMI and configure it to listen to an available port number.
Capture the machine IP address of the machine which is running IPMICAP ( it does not have to be the same machine as the target hardware.
Now run the following for each competition dataset:
python run.py --dataset [DATASET] --t3 --definitions [DEFINITION FILE] --sensors [S1 S2 ...] --sessions --powercapture [IPMICAP_MACHINE_IP]:[IPMICAP_LISTEN_PORT]:[TIME_IN_SECONDS]
where S1, S2,... = the sensor records for all POWER_IN sensors ( please see the IPMCAP documentation to determine these sensor records.
This will monitor power consumption over that period of time ( 10 seconds is a good number ).
You can retrieve a plot of the power consumptions ( measured as watt-seconds/query ) using the plot.py script.