module Simulation.Aivika.Experiment.TimingStatsWriter
(TimingStatsWriter(..),
defaultTimingStatsWriter) where
import Simulation.Aivika.Experiment.Types
import Simulation.Aivika.Experiment.HtmlWriter
import Simulation.Aivika.Statistics
data TimingStatsWriter a =
TimingStatsWriter { timingStatsWidth :: Int,
timingStatsTimeText :: String,
timingStatsMeanText :: String,
timingStatsDeviationText :: String,
timingStatsMinText :: String,
timingStatsMaxText :: String,
timingStatsFormatter :: ShowS,
timingStatsWrite :: TimingStatsWriter a -> String ->
TimingStats a -> HtmlWriter ()
}
defaultTimingStatsWriter :: (Show a, TimingData a) => TimingStatsWriter a
defaultTimingStatsWriter =
TimingStatsWriter {
timingStatsWidth = 400,
timingStatsMeanText = "mean",
timingStatsTimeText = "time",
timingStatsDeviationText = "deviation",
timingStatsMinText = "minimum",
timingStatsMaxText = "maximum",
timingStatsFormatter = id,
timingStatsWrite = \writer name stats ->
do let format x = timingStatsFormatter writer x
writeHtml "<p>"
writeHtml "<table frame='border' cellspacing='4' width='"
writeHtml $ show $ timingStatsWidth writer
writeHtml "'>"
writeHtml "<tr>"
writeHtml "<td colspan='3'>"
writeHtml "<p align='center'>"
writeHtmlText name
writeHtml "</h4>"
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "<tr>"
writeHtml "<td>"
writeHtmlText $ timingStatsMeanText writer
writeHtml "</td>"
writeHtml "<td colspan='2'>"
writeHtmlText $ format $ show $ timingStatsMean stats
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "<tr>"
writeHtml "<td>"
writeHtmlText $ timingStatsDeviationText writer
writeHtml "</td>"
writeHtml "<td colspan='2'>"
writeHtmlText $ format $ show $ timingStatsDeviation stats
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "<tr>"
writeHtml "<td>"
writeHtmlText $ timingStatsMinText writer
writeHtml "</td>"
writeHtml "<td>"
writeHtmlText $ format $ show $ timingStatsMin stats
writeHtml "</td>"
writeHtml "<td>"
writeHtmlText "("
writeHtmlText $ timingStatsTimeText writer
writeHtmlText " = "
writeHtmlText $ format $ show $ timingStatsMinTime stats
writeHtmlText ")"
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "<tr>"
writeHtml "<td>"
writeHtmlText $ timingStatsMaxText writer
writeHtml "</td>"
writeHtml "<td>"
writeHtmlText $ format $ show $ timingStatsMax stats
writeHtml "</td>"
writeHtml "<td>"
writeHtmlText "("
writeHtmlText $ timingStatsTimeText writer
writeHtmlText " = "
writeHtmlText $ format $ show $ timingStatsMaxTime stats
writeHtmlText ")"
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "<tr>"
writeHtml "<td>"
writeHtmlText $ timingStatsTimeText writer
writeHtml "</td>"
writeHtml "<td colspan='2'>"
writeHtml "["
writeHtml $ format $ show $ timingStatsStartTime stats
writeHtml "; "
writeHtml $ format $ show $ timingStatsLastTime stats
writeHtml "]"
writeHtml "</td>"
writeHtml "</tr>"
writeHtml "</table>"
writeHtml "</p>"
}