summaryrefslogtreecommitdiffstats
path: root/chromium/third_party/trace-viewer/src/tracing/analysis/analyze_counters.js
blob: 6c18cc9a2f09e6437dbb0726d1866ef47b09c07c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// Copyright (c) 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

'use strict';

base.require('tracing.analysis.util');
base.require('ui');
base.require('tracing.trace_model.counter_sample');
base.exportTo('tracing.analysis', function() {

  var CounterSample = tracing.trace_model.CounterSample;

  function analyzeCounterSamples(results, allSamples) {
    var samplesByCounter = {};
    for (var i = 0; i < allSamples.length; i++) {
      var ctr = allSamples[i].series.counter;
      if (!samplesByCounter[ctr.guid])
        samplesByCounter[ctr.guid] = [];
      samplesByCounter[ctr.guid].push(allSamples[i]);
    }

    for (var guid in samplesByCounter) {
      var samples = samplesByCounter[guid];
      var ctr = samples[0].series.counter;

      var timestampGroups = CounterSample.groupByTimestamp(samples);
      if (timestampGroups.length == 1)
        analyzeSingleCounterTimestamp(results, ctr, timestampGroups[0]);
      else
        analyzeMultipleCounterTimestamps(results, ctr, timestampGroups);
    }
  }

  function analyzeSingleCounterTimestamp(
      results, ctr, samplesWithSameTimestamp) {
    results.appendHeader('Selected counter:');
    var table = results.appendTable('analysis-counter-table', 2);
    results.appendInfoRow(table, 'Title', ctr.name);
    results.appendInfoRowTime(
        table, 'Timestamp', samplesWithSameTimestamp[0].timestamp);
    for (var i = 0; i < samplesWithSameTimestamp.length; i++) {
      var sample = samplesWithSameTimestamp[i];
      results.appendInfoRow(table, sample.series.name, sample.value);
    }
  }

  function analyzeMultipleCounterTimestamps(results, ctr, samplesByTimestamp) {
    results.appendHeader('Counter ' + ctr.name);
    var table = results.appendTable('analysis-counter-table', 2);

    var sampleIndices = [];
    for (var i = 0; i < samplesByTimestamp.length; i++)
      sampleIndices.push(samplesByTimestamp[i][0].getSampleIndex());

    var stats = ctr.getSampleStatistics(sampleIndices);
    for (var i = 0; i < stats.length; i++) {
      var samples = [];
      for (var k = 0; k < sampleIndices.length; ++k)
        samples.push(ctr.getSeries(i).getSample(sampleIndices[k]).value);

      results.appendDataRow(
          table,
          ctr.name + ': series(' + ctr.getSeries(i).name + ')',
          samples,
          null,
          null,
          samples.length,
          stats[i]);
    }
  }

  return {
    analyzeCounterSamples: analyzeCounterSamples,
    analyzeSingleCounterTimestamp: analyzeSingleCounterTimestamp,
    analyzeMultipleCounterTimestamps: analyzeMultipleCounterTimestamps
  };
});