| /* |
| * Copyright (C) 2010 Google Inc. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package benchmarks.regression; |
| |
| import com.google.caliper.Param; |
| import com.google.caliper.Runner; |
| import com.google.caliper.SimpleBenchmark; |
| |
| /** |
| * Many of these tests are bogus in that the cost will vary wildly depending on inputs. |
| * For _my_ current purposes, that's okay. But beware! |
| */ |
| public class StrictMathBenchmark extends SimpleBenchmark { |
| private final double d = 1.2; |
| private final float f = 1.2f; |
| private final int i = 1; |
| private final long l = 1L; |
| |
| public void timeAbsD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.abs(d); |
| } |
| } |
| |
| public void timeAbsF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.abs(f); |
| } |
| } |
| |
| public void timeAbsI(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.abs(i); |
| } |
| } |
| |
| public void timeAbsL(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.abs(l); |
| } |
| } |
| |
| public void timeAcos(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.acos(d); |
| } |
| } |
| |
| public void timeAsin(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.asin(d); |
| } |
| } |
| |
| public void timeAtan(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.atan(d); |
| } |
| } |
| |
| public void timeAtan2(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.atan2(3, 4); |
| } |
| } |
| |
| public void timeCbrt(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.cbrt(d); |
| } |
| } |
| |
| public void timeCeil(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.ceil(d); |
| } |
| } |
| |
| public void timeCopySignD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.copySign(d, d); |
| } |
| } |
| |
| public void timeCopySignF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.copySign(f, f); |
| } |
| } |
| |
| public void timeCos(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.cos(d); |
| } |
| } |
| |
| public void timeCosh(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.cosh(d); |
| } |
| } |
| |
| public void timeExp(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.exp(d); |
| } |
| } |
| |
| public void timeExpm1(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.expm1(d); |
| } |
| } |
| |
| public void timeFloor(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.floor(d); |
| } |
| } |
| |
| public void timeGetExponentD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.getExponent(d); |
| } |
| } |
| |
| public void timeGetExponentF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.getExponent(f); |
| } |
| } |
| |
| public void timeHypot(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.hypot(d, d); |
| } |
| } |
| |
| public void timeIEEEremainder(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.IEEEremainder(d, d); |
| } |
| } |
| |
| public void timeLog(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.log(d); |
| } |
| } |
| |
| public void timeLog10(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.log10(d); |
| } |
| } |
| |
| public void timeLog1p(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.log1p(d); |
| } |
| } |
| |
| public void timeMaxD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.max(d, d); |
| } |
| } |
| |
| public void timeMaxF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.max(f, f); |
| } |
| } |
| |
| public void timeMaxI(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.max(i, i); |
| } |
| } |
| |
| public void timeMaxL(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.max(l, l); |
| } |
| } |
| |
| public void timeMinD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.min(d, d); |
| } |
| } |
| |
| public void timeMinF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.min(f, f); |
| } |
| } |
| |
| public void timeMinI(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.min(i, i); |
| } |
| } |
| |
| public void timeMinL(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.min(l, l); |
| } |
| } |
| |
| public void timeNextAfterD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.nextAfter(d, d); |
| } |
| } |
| |
| public void timeNextAfterF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.nextAfter(f, f); |
| } |
| } |
| |
| public void timeNextUpD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.nextUp(d); |
| } |
| } |
| |
| public void timeNextUpF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.nextUp(f); |
| } |
| } |
| |
| public void timePow(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.pow(d, d); |
| } |
| } |
| |
| public void timeRandom(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.random(); |
| } |
| } |
| |
| public void timeRint(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.rint(d); |
| } |
| } |
| |
| public void timeRoundD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.round(d); |
| } |
| } |
| |
| public void timeRoundF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.round(f); |
| } |
| } |
| |
| public void timeScalbD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.scalb(d, 5); |
| } |
| } |
| |
| public void timeScalbF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.scalb(f, 5); |
| } |
| } |
| |
| public void timeSignumD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.signum(d); |
| } |
| } |
| |
| public void timeSignumF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.signum(f); |
| } |
| } |
| |
| public void timeSin(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.sin(d); |
| } |
| } |
| |
| public void timeSinh(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.sinh(d); |
| } |
| } |
| |
| public void timeSqrt(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.sqrt(d); |
| } |
| } |
| |
| public void timeTan(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.tan(d); |
| } |
| } |
| |
| public void timeTanh(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.tanh(d); |
| } |
| } |
| |
| public void timeToDegrees(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.toDegrees(d); |
| } |
| } |
| |
| public void timeToRadians(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.toRadians(d); |
| } |
| } |
| |
| public void timeUlpD(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.ulp(d); |
| } |
| } |
| |
| public void timeUlpF(int reps) { |
| for (int rep = 0; rep < reps; ++rep) { |
| StrictMath.ulp(f); |
| } |
| } |
| } |