OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <!-- | 2 <!-- |
3 Copyright (c) 2013 The Chromium Authors. All rights reserved. | 3 Copyright (c) 2013 The Chromium Authors. All rights reserved. |
4 Use of this source code is governed by a BSD-style license that can be | 4 Use of this source code is governed by a BSD-style license that can be |
5 found in the LICENSE file. | 5 found in the LICENSE file. |
6 --> | 6 --> |
7 | 7 |
8 <link rel="import" href="/tracing/base/iteration_helpers.html"> | 8 <link rel="import" href="/tracing/base/iteration_helpers.html"> |
9 <link rel="import" href="/tracing/base/range_utils.html"> | 9 <link rel="import" href="/tracing/base/math/range_utils.html"> |
| 10 <link rel="import" href="/tracing/base/math/statistics.html"> |
10 <link rel="import" href="/tracing/base/scalar.html"> | 11 <link rel="import" href="/tracing/base/scalar.html"> |
11 <link rel="import" href="/tracing/base/statistics.html"> | |
12 <link rel="import" href="/tracing/base/unit.html"> | 12 <link rel="import" href="/tracing/base/unit.html"> |
13 <link rel="import" href="/tracing/core/auditor.html"> | 13 <link rel="import" href="/tracing/core/auditor.html"> |
14 <link rel="import" href="/tracing/model/alert.html"> | 14 <link rel="import" href="/tracing/model/alert.html"> |
15 <link rel="import" href="/tracing/model/frame.html"> | 15 <link rel="import" href="/tracing/model/frame.html"> |
16 <link rel="import" href="/tracing/model/helpers/android_model_helper.html"> | 16 <link rel="import" href="/tracing/model/helpers/android_model_helper.html"> |
17 <link rel="import" href="/tracing/model/thread_time_slice.html"> | 17 <link rel="import" href="/tracing/model/thread_time_slice.html"> |
18 <link rel="import" href="/tracing/model/user_model/response_expectation.html"> | 18 <link rel="import" href="/tracing/model/user_model/response_expectation.html"> |
19 | 19 |
20 <script> | 20 <script> |
21 'use strict'; | 21 'use strict'; |
22 | 22 |
23 /** | 23 /** |
24 * @fileoverview Class for Android-specific Auditing. | 24 * @fileoverview Class for Android-specific Auditing. |
25 */ | 25 */ |
26 tr.exportTo('tr.e.audits', function() { | 26 tr.exportTo('tr.e.audits', function() { |
27 var SCHEDULING_STATE = tr.model.SCHEDULING_STATE; | 27 var SCHEDULING_STATE = tr.model.SCHEDULING_STATE; |
28 var Auditor = tr.c.Auditor; | 28 var Auditor = tr.c.Auditor; |
29 var AndroidModelHelper = tr.model.helpers.AndroidModelHelper; | 29 var AndroidModelHelper = tr.model.helpers.AndroidModelHelper; |
30 var ColorScheme = tr.b.ColorScheme; | 30 var ColorScheme = tr.b.ColorScheme; |
31 var Statistics = tr.b.Statistics; | 31 var Statistics = tr.b.math.Statistics; |
32 var FRAME_PERF_CLASS = tr.model.FRAME_PERF_CLASS; | 32 var FRAME_PERF_CLASS = tr.model.FRAME_PERF_CLASS; |
33 var Alert = tr.model.Alert; | 33 var Alert = tr.model.Alert; |
34 var EventInfo = tr.model.EventInfo; | 34 var EventInfo = tr.model.EventInfo; |
35 var Scalar = tr.b.Scalar; | 35 var Scalar = tr.b.Scalar; |
36 var timeDurationInMs = tr.b.Unit.byName.timeDurationInMs; | 36 var timeDurationInMs = tr.b.Unit.byName.timeDurationInMs; |
37 | 37 |
38 // TODO: extract from VSYNC, since not all devices have vsync near 60fps | 38 // TODO: extract from VSYNC, since not all devices have vsync near 60fps |
39 var EXPECTED_FRAME_TIME_MS = 16.67; | 39 var EXPECTED_FRAME_TIME_MS = 16.67; |
40 | 40 |
41 function getStart(e) { return e.start; } | 41 function getStart(e) { return e.start; } |
(...skipping 484 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
526 events.push.apply(events, app.getFrames()); | 526 events.push.apply(events, app.getFrames()); |
527 }); | 527 }); |
528 | 528 |
529 var mergerFunction = function(events) { | 529 var mergerFunction = function(events) { |
530 var ir = new tr.model.um.ResponseExpectation( | 530 var ir = new tr.model.um.ResponseExpectation( |
531 this.model, 'Rendering', | 531 this.model, 'Rendering', |
532 events[0].min, | 532 events[0].min, |
533 events[events.length - 1].max - events[0].min); | 533 events[events.length - 1].max - events[0].min); |
534 this.model.userModel.expectations.push(ir); | 534 this.model.userModel.expectations.push(ir); |
535 }.bind(this); | 535 }.bind(this); |
536 tr.b.mergeRanges(tr.b.convertEventsToRanges(events), 30, mergerFunction); | 536 tr.b.math.mergeRanges( |
| 537 tr.b.math.convertEventsToRanges(events), 30, mergerFunction); |
537 }, | 538 }, |
538 | 539 |
539 addInputInteractionRecords: function() { | 540 addInputInteractionRecords: function() { |
540 var inputSamples = []; | 541 var inputSamples = []; |
541 this.helper.apps.forEach(function(app) { | 542 this.helper.apps.forEach(function(app) { |
542 inputSamples.push.apply(inputSamples, app.getInputSamples()); | 543 inputSamples.push.apply(inputSamples, app.getInputSamples()); |
543 }); | 544 }); |
544 | 545 |
545 var mergerFunction = function(events) { | 546 var mergerFunction = function(events) { |
546 var ir = new tr.model.um.ResponseExpectation( | 547 var ir = new tr.model.um.ResponseExpectation( |
547 this.model, 'Input', | 548 this.model, 'Input', |
548 events[0].min, | 549 events[0].min, |
549 events[events.length - 1].max - events[0].min); | 550 events[events.length - 1].max - events[0].min); |
550 this.model.userModel.expectations.push(ir); | 551 this.model.userModel.expectations.push(ir); |
551 }.bind(this); | 552 }.bind(this); |
552 var inputRanges = inputSamples.map(function(sample) { | 553 var inputRanges = inputSamples.map(function(sample) { |
553 return tr.b.Range.fromExplicitRange(sample.timestamp, sample.timestamp); | 554 return tr.b.math.Range.fromExplicitRange( |
| 555 sample.timestamp, sample.timestamp); |
554 }); | 556 }); |
555 tr.b.mergeRanges(inputRanges, 30, mergerFunction); | 557 tr.b.math.mergeRanges(inputRanges, 30, mergerFunction); |
556 } | 558 } |
557 }; | 559 }; |
558 | 560 |
559 Auditor.register(AndroidAuditor); | 561 Auditor.register(AndroidAuditor); |
560 | 562 |
561 function AppAnnotator() { | 563 function AppAnnotator() { |
562 this.titleInfoLookup = new Map(); | 564 this.titleInfoLookup = new Map(); |
563 this.titleParentLookup = new Map(); | 565 this.titleParentLookup = new Map(); |
564 this.build_(); | 566 this.build_(); |
565 } | 567 } |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
746 this.applyEventInfosRecursive_(new Map(), slice); | 748 this.applyEventInfosRecursive_(new Map(), slice); |
747 }, this); | 749 }, this); |
748 } | 750 } |
749 }; | 751 }; |
750 | 752 |
751 return { | 753 return { |
752 AndroidAuditor, | 754 AndroidAuditor, |
753 }; | 755 }; |
754 }); | 756 }); |
755 </script> | 757 </script> |
OLD | NEW |