Home | History | Annotate | Download | only in runner
      1 /*
      2  * Copyright (C) 2013 Google Inc.
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  * http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 package com.google.caliper.runner;
     18 
     19 import static java.math.RoundingMode.CEILING;
     20 import static java.util.concurrent.TimeUnit.NANOSECONDS;
     21 
     22 import com.google.caliper.util.ShortDuration;
     23 import com.google.common.base.Ticker;
     24 import com.google.common.math.LongMath;
     25 
     26 /**
     27  * A utility that calculates the finest granularity that can be expected from subsequent calls to
     28  * {@link System#nanoTime()}.  Note that this utility necessarily invokes {@link System#nanoTime()}
     29  * directly rather than using {@link Ticker} because the extra indirection might cause additional
     30  * overhead.
     31  */
     32 final class NanoTimeGranularityTester {
     33   private static final int TRIALS = 1000;
     34 
     35   ShortDuration testNanoTimeGranularity() {
     36     long total = 0L;
     37     for (int i = 0; i < TRIALS; i++) {
     38       long first = System.nanoTime();
     39       long second = System.nanoTime();
     40       long third = System.nanoTime();
     41       long fourth = System.nanoTime();
     42       long fifth = System.nanoTime();
     43       long sixth = System.nanoTime();
     44       long seventh = System.nanoTime();
     45       long eighth = System.nanoTime();
     46       long ninth = System.nanoTime();
     47       total += second - first;
     48       total += third - second;
     49       total += fourth - third;
     50       total += fifth - fourth;
     51       total += sixth - fifth;
     52       total += seventh - sixth;
     53       total += eighth - seventh;
     54       total += ninth - eighth;
     55     }
     56     return ShortDuration.of(LongMath.divide(total, TRIALS * 8, CEILING), NANOSECONDS);
     57   }
     58 }
     59