net.nicoulaj.benchmarks.math.DoubleLog.java Source code

Java tutorial

Introduction

Here is the source code for net.nicoulaj.benchmarks.math.DoubleLog.java

Source

/*
 * Copyright (c) 2012-2014 Julien Nicoulaud <julien.nicoulaud@gmail.com>.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included
 * in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package net.nicoulaj.benchmarks.math;

import org.apache.commons.math3.util.FastMath;
import org.openjdk.jmh.annotations.GenerateMicroBenchmark;
import org.openjdk.jmh.annotations.OperationsPerInvocation;
import org.openjdk.jmh.annotations.Setup;
import org.openjdk.jmh.logic.BlackHole;

import static net.nicoulaj.benchmarks.math.MathBenchmark.DATA_SIZE;
import static org.openjdk.jmh.annotations.Level.Iteration;
import static net.nicoulaj.benchmarks.BenchmarkUtils.*;

@OperationsPerInvocation(DATA_SIZE)
public class DoubleLog extends MathBenchmark {

    private double[] data;

    @Setup(Iteration)
    public void setup() {
        data = rndDoubleArray(DATA_SIZE);
    }

    @GenerateMicroBenchmark
    public void math(BlackHole hole) {
        for (int i = 0; i < data.length - 1; i++)
            hole.consume(Math.log(data[i]));
    }

    @GenerateMicroBenchmark
    public void strictmath(BlackHole hole) {
        for (int i = 0; i < data.length - 1; i++)
            hole.consume(StrictMath.log(data[i]));
    }

    @GenerateMicroBenchmark
    public void commonsmath(BlackHole hole) {
        for (int i = 0; i < data.length - 1; i++)
            hole.consume(FastMath.log(data[i]));
    }
}