plot average heap size;
authorwenzelm
Wed, 17 May 2017 22:32:48 +0200
changeset 65859 95ddb6dea0d5
parent 65858 9418a9fad835
child 65860 ce6be2e40d47
plot average heap size;
src/Pure/Admin/build_status.scala
--- a/src/Pure/Admin/build_status.scala	Wed May 17 22:27:33 2017 +0200
+++ b/src/Pure/Admin/build_status.scala	Wed May 17 22:32:48 2017 +0200
@@ -81,7 +81,10 @@
     def check_timing: Boolean = entries.length >= 3
     def check_heap: Boolean =
       entries.length >= 3 &&
-      entries.forall(entry => entry.heap_size > 0 || entry.heap_size_max > 0)
+      entries.forall(entry =>
+        entry.maximum_heap > 0 ||
+        entry.average_heap > 0 ||
+        entry.final_heap > 0)
   }
   sealed case class Entry(
     pull_date: Date,
@@ -89,8 +92,9 @@
     afp_version: String,
     timing: Timing,
     ml_timing: Timing,
-    heap_size: Long,
-    heap_size_max: Long,
+    maximum_heap: Long,
+    average_heap: Long,
+    final_heap: Long,
     ml_statistics: ML_Statistics)
 
   def read_data(options: Options,
@@ -187,8 +191,9 @@
                     Build_Log.Data.ml_timing_elapsed,
                     Build_Log.Data.ml_timing_cpu,
                     Build_Log.Data.ml_timing_gc),
-                heap_size = res.long(Build_Log.Data.heap_size),
-                heap_size_max = ml_stats.heap_size_max,
+                maximum_heap = ml_stats.maximum_heap_size,
+                average_heap = ml_stats.average_heap_size,
+                final_heap = res.long(Build_Log.Data.heap_size),
                 ml_statistics = ml_stats)
 
             val sessions = data_entries.getOrElse(data_name, Map.empty)
@@ -262,8 +267,9 @@
                       entry.timing.resources.minutes,
                       entry.ml_timing.elapsed.minutes,
                       entry.ml_timing.resources.minutes,
-                      heap_scale(entry.heap_size),
-                      heap_scale(entry.heap_size_max)).mkString(" "))))
+                      heap_scale(entry.maximum_heap),
+                      heap_scale(entry.average_heap),
+                      heap_scale(entry.final_heap)).mkString(" "))))
 
               val max_time =
                 ((0.0 /: session.entries){ case (m, entry) =>
@@ -318,10 +324,12 @@
 
               val heap_plots =
                 List(
-                  """ using 1:6 smooth sbezier title "final heap (smooth)" """,
-                  """ using 1:6 smooth csplines title "final heap" """,
-                  """ using 1:7 smooth sbezier title "max heap (smooth)" """,
-                  """ using 1:7 smooth csplines title "max heap" """)
+                  """ using 1:6 smooth sbezier title "maximum heap (smooth)" """,
+                  """ using 1:6 smooth csplines title "maximum heap" """,
+                  """ using 1:7 smooth sbezier title "average heap (smooth)" """,
+                  """ using 1:7 smooth csplines title "average heap" """,
+                  """ using 1:8 smooth sbezier title "final heap (smooth)" """,
+                  """ using 1:8 smooth csplines title "final heap" """)
 
               val plot_names =
                 (if (session.check_timing)