aboutsummaryrefslogtreecommitdiffstats
path: root/vespajlib/src/test/java/com/yahoo/text/MapParserMicroBenchmark.java
blob: 71c0e95c339ef0b5b621f39ada66c55ab9d09312 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Copyright Yahoo. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.text;

import java.util.HashMap;
import java.util.Map;

/**
 * A benchmark of map parsing.
 * Expected time on Jon's mac: 200 microseconds per 1k size map.
 *
 * @author bratseth
 */
public class MapParserMicroBenchmark {

    private static String generateValues(int size) {
        StringBuilder b = new StringBuilder("{");
        for (int i=0; i<size; i++)
            b.append("a").append(i).append(":").append(i+1).append(",");
        b.setLength(b.length() - 1);
        b.append("}");
        return b.toString();
    }

    public void benchmark(int repetitions,int mapSize) {
        String values = generateValues(mapSize);
        System.out.println("Ranking expression parsing");
        System.out.println("  warming up");
        rankingExpressionParserParse(1000, values, mapSize);
        long startTime = System.currentTimeMillis();
        System.out.println(  "starting ....");
        rankingExpressionParserParse(repetitions, values, mapSize);
        long totalTime = System.currentTimeMillis() - startTime;
        System.out.println("  Total time: " + totalTime + " ms, time per expression: " + (totalTime*1000/repetitions) + " microseconds");
    }

    private void rankingExpressionParserParse(int repetitions, String values, int expectedMapSize) {
        Map<String,Double> map = new HashMap<>();
        for (int i=0; i<repetitions; i++) {
            rankingExpressionParserParse(values, map);
            if ( map.size()!=expectedMapSize)
                throw new RuntimeException("Expected size: " + expectedMapSize + ", actual size: " + map.size());
            map.clear();
        }
    }
    private Map<String,Double> rankingExpressionParserParse(String values, Map<String,Double> map) {
        return new DoubleMapParser().parse(values,map);
    }

    public static void main(String[] args) {
        new MapParserMicroBenchmark().benchmark(100*1000,1000);
    }

    private static class DoubleMapParser extends MapParser<Double> {

        @Override
        protected Double parseValue(String s) {
            return Double.parseDouble(s);
        }

    }

}