diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2015-02-10 22:42:40 +0100 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2015-02-10 22:42:40 +0100 |
commit | 08b5c0090fd7eb4d17a19568ccae883dfd5c2b21 (patch) | |
tree | d4e90aa630bd002de48b0ee86c11508a6af44dad /microbenchmark-template | |
parent | 80e19825ce083c88f99ba1575d66ab721b557190 (diff) | |
download | sonarqube-08b5c0090fd7eb4d17a19568ccae883dfd5c2b21.tar.gz sonarqube-08b5c0090fd7eb4d17a19568ccae883dfd5c2b21.zip |
Add micro-benchmark for comparing hash implementations
Diffstat (limited to 'microbenchmark-template')
-rw-r--r-- | microbenchmark-template/src/main/java/org/sonar/microbenchmark/HashBenchmark.java | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/microbenchmark-template/src/main/java/org/sonar/microbenchmark/HashBenchmark.java b/microbenchmark-template/src/main/java/org/sonar/microbenchmark/HashBenchmark.java new file mode 100644 index 00000000000..d25aad355b6 --- /dev/null +++ b/microbenchmark-template/src/main/java/org/sonar/microbenchmark/HashBenchmark.java @@ -0,0 +1,86 @@ +package org.sonar.microbenchmark; + +import net.jpountz.xxhash.XXHash32; +import net.jpountz.xxhash.XXHash64; +import net.jpountz.xxhash.XXHashFactory; +import org.apache.commons.codec.digest.DigestUtils; +import org.apache.commons.lang.StringUtils; +import org.openjdk.jmh.annotations.Benchmark; +import org.openjdk.jmh.annotations.BenchmarkMode; +import org.openjdk.jmh.annotations.Fork; +import org.openjdk.jmh.annotations.Measurement; +import org.openjdk.jmh.annotations.Mode; +import org.openjdk.jmh.annotations.OutputTimeUnit; +import org.openjdk.jmh.annotations.Param; +import org.openjdk.jmh.annotations.Scope; +import org.openjdk.jmh.annotations.Setup; +import org.openjdk.jmh.annotations.State; +import org.openjdk.jmh.annotations.Warmup; +import org.openjdk.jmh.runner.Runner; +import org.openjdk.jmh.runner.RunnerException; +import org.openjdk.jmh.runner.options.Options; +import org.openjdk.jmh.runner.options.OptionsBuilder; + +import java.util.concurrent.TimeUnit; + +/** + * + * See https://code.google.com/p/xxhash/ and https://github.com/jpountz/lz4-java + * + */ +@OutputTimeUnit(TimeUnit.MILLISECONDS) +@State(Scope.Thread) +@Fork(1) +@Warmup(iterations = 3) +@Measurement(iterations = 3) +@BenchmarkMode(Mode.Throughput) +public class HashBenchmark { + + @Param({"1", "100", "1000", "10000", "100000", "1000000"}) + public int size; + + XXHash32 xxHash32 = XXHashFactory.fastestInstance().hash32(); + XXHash64 xxHash64 = XXHashFactory.fastestInstance().hash64(); + + byte[] bytes; + + @Setup + public void setup() throws Exception { + bytes = StringUtils.repeat("3", size).getBytes(); + } + + @Benchmark + public String commonsCodecMd5() throws Exception { + return DigestUtils.md5Hex(bytes); + } + + @Benchmark + public String commonsCodecSha1() throws Exception { + return DigestUtils.sha1Hex(bytes); + } + + @Benchmark + public int xxhash32() throws Exception { + int seed = 0x9747b28c; // used to initialize the hash value, use whatever + // value you want, but always the same + return xxHash32.hash(bytes, 0, bytes.length, seed); + } + + @Benchmark + public long xxhash64() throws Exception { + int seed = 0x9747b28c; // used to initialize the hash value, use whatever + // value you want, but always the same + return xxHash64.hash(bytes, 0, bytes.length, seed); + } + + /** + * You can this benchmark with maven command-line (see run.sh) or by executing this method + * in IDE + */ + public static void main(String[] args) throws RunnerException { + Options opt = new OptionsBuilder() + .include(HashBenchmark.class.getSimpleName()) + .build(); + new Runner(opt).run(); + } +} |