Skip to content

Latest commit

 

History

History
 
 

wavelet_trees

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Benchmarking wavelet trees

Methodology

Explored dimensions:

  • wavelet tree implementations
  • test cases
  • methods (access, rank, select, inverse_select, interval_symbols, lex_count, lex_smaller_count,construct)

Directory structure

  • bin: Contains the executables of the project.
  • results: Contains the results of the experiments.
  • src: Contains the source code of the benchmark.
  • visualize: Contains a R-script which generates a report in LaTeX format.

Prerequisites

  • For the visualization you need the following software:
    • R with package tikzDevice. You can install the package by calling install.packages("filehash", repos="http://cran.r-project.org") and install.packages("tikzDevice", repos="http://R-Forge.R-project.org") in R.
    • pdflatex to generate the pdf reports.

Usage

  • make timing compiles the programs, downloads or generates the test instances, builds the wavelet trees, runs the performance tests and generated a report located at visualize/wt.pdf. The raw numbers of the timings can be found in the results/all.txt. The default benchmark took 28 minutes on my machine (MacBookPro Retina 2.6Ghz Intel Code i7 16GB 1600 Mhz DDR3, SSD). Have a look at the generated report.
  • All created binaries and test results can be deleted by calling make cleanall.

Customization of the benchmark

The project contains several configuration files:

Note that the benchmark will execute every combination of wavelet trees and test cases.