All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dotty.tools.dotc.Bench.scala Maven / Gradle / Ivy

package dotty.tools
package dotc

import core.Contexts.*
import reporting.Reporter
import io.AbstractFile

import scala.annotation.internal.sharable
import scala.compiletime.uninitialized

/** A main class for running compiler benchmarks. Can instantiate a given
 *  number of compilers and run each (sequentially) a given number of times
 *  on the same sources.
 */
object Bench extends Driver:

  @sharable private var numRuns = 1
  @sharable private var numCompilers = 1
  @sharable private var waitAfter = -1
  @sharable private var curCompiler = 0
  @sharable private var times: Array[Int] = uninitialized

  override def doCompile(compiler: Compiler, files: List[AbstractFile])(using Context): Reporter =
    var reporter: Reporter = emptyReporter
    for i <- 0 until numRuns do
      val curRun = curCompiler * numRuns + i
      val start = System.nanoTime()
      reporter = super.doCompile(compiler, files)
      times(curRun) = ((System.nanoTime - start) / 1000000).toInt
      println(s"time elapsed: ${times(curRun)}ms")
      if ctx.settings.Xprompt.value || waitAfter == curRun + 1 then
        print("hit  to continue >")
        System.in.nn.read()
    reporter

  def extractNumArg(args: Array[String], name: String, default: Int = 1): (Int, Array[String]) = {
    val pos = args indexOf name
    if (pos < 0) (default, args)
    else (args(pos + 1).toInt, (args take pos) ++ (args drop (pos + 2)))
  }

  def reportTimes() =
    val best = times.sorted
    val measured = numCompilers * numRuns / 3
    val avgBest = best.take(measured).sum / measured
    val avgLast = times.reverse.take(measured).sum / measured
    println(s"best out of ${numCompilers * numRuns} runs: ${best(0)}")
    println(s"average out of best $measured: $avgBest")
    println(s"average out of last $measured: $avgLast")

  override def process(args: Array[String]): Reporter =
    val (numCompilers, args1) = extractNumArg(args, "#compilers")
    val (numRuns, args2) = extractNumArg(args1, "#runs")
    val (waitAfter, args3) = extractNumArg(args2, "#wait-after", -1)
    this.numCompilers = numCompilers
    this.numRuns = numRuns
    this.waitAfter = waitAfter
    this.times = new Array[Int](numCompilers * numRuns)
    var reporter: Reporter = emptyReporter
    curCompiler = 0
    while curCompiler < numCompilers do
      reporter = super.process(args3)
      curCompiler += 1
    reportTimes()
    reporter

end Bench






© 2015 - 2025 Weber Informatics LLC | Privacy Policy