src/Pure/Tools/task_statistics.scala
author wenzelm
Sat, 17 Dec 2016 14:13:15 +0100
changeset 64581 ee4b9cea7fb5
parent 64045 c6160d0b0337
child 65318 342efc382558
permissions -rw-r--r--
tuned signature -- suppress pointless exports;

/*  Title:      Pure/Tools/task_statistics.scala
    Author:     Makarius

Future task runtime statistics.
*/

package isabelle


import scala.swing.{Frame, Component}

import org.jfree.data.statistics.HistogramDataset
import org.jfree.chart.{JFreeChart, ChartPanel, ChartFactory}
import org.jfree.chart.plot.{XYPlot, PlotOrientation}
import org.jfree.chart.renderer.xy.{XYBarRenderer, StandardXYBarPainter}


object Task_Statistics
{
  def apply(session_name: String, task_statistics: List[Properties.T]): Task_Statistics =
    new Task_Statistics(session_name, task_statistics)

  def apply(info: Build_Log.Session_Info): Task_Statistics =
    apply(info.session_name, info.task_statistics)
}

final class Task_Statistics private(
  val session_name: String, val task_statistics: List[Properties.T])
{
  private val Task_Name = new Properties.String("task_name")
  private val Run = new Properties.Int("run")

  def chart(bins: Int = 100): JFreeChart =
  {
    val values = new Array[Double](task_statistics.length)
    for ((Run(x), i) <- task_statistics.iterator.zipWithIndex)
      values(i) = java.lang.Math.log10((x max 1).toDouble / 1000000)

    val data = new HistogramDataset
    data.addSeries("tasks", values, bins)

    val c =
      ChartFactory.createHistogram("Task runtime distribution",
        "log10(runtime / s)", "number of tasks", data,
        PlotOrientation.VERTICAL, true, true, true)

    val renderer = c.getPlot.asInstanceOf[XYPlot].getRenderer.asInstanceOf[XYBarRenderer]
    renderer.setMargin(0.1)
    renderer.setBarPainter(new StandardXYBarPainter)

    c
  }

  def show_frame(bins: Int = 100): Unit =
    GUI_Thread.later {
      new Frame {
        iconImage = GUI.isabelle_image()
        title = session_name
        contents = Component.wrap(new ChartPanel(chart(bins)))
        visible = true
      }
    }
}