Commit 8547ac38 authored by Camillo Bruni's avatar Camillo Bruni Committed by Commit Bot

[tools][system-analyzer] Improve timeline.mjs

Make Timeline.selectTimeRange run in O(log(n)) instead of
O(n) comparisons.

Drive-by-fix:
- Use *Index for variable names in Timeline

Bug: v8:10644
Change-Id: I65f3be9f259e6bebcec489526a54712daffd4d15
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2507714
Commit-Queue: Camillo Bruni <cbruni@chromium.org>
Auto-Submit: Camillo Bruni <cbruni@chromium.org>
Reviewed-by: 's avatarShu-yu Guo <syg@chromium.org>
Cr-Commit-Position: refs/heads/master@{#71461}
parent bba4817b
...@@ -8,23 +8,43 @@ import { LogEntry} from "../../../tools/system-analyzer/log/log.mjs"; ...@@ -8,23 +8,43 @@ import { LogEntry} from "../../../tools/system-analyzer/log/log.mjs";
(function testTimeline() { (function testTimeline() {
let timeline = new Timeline(); let timeline = new Timeline();
let id1 = "0x3e7e082470cd"; let id1 = "0x3e7e082470cd";
let id2 = "0x3e7e082470ad"; let id2 = "0x3e7e082470ad";
let time = 12; let time = 10;
let entry1 = new LogEntry(id1, time);
let entry1 = new LogEntry(id1, time + 0);
let entry2 = new LogEntry(id1, time + 1); let entry2 = new LogEntry(id1, time + 1);
let entry3 = new LogEntry(id1, time + 2); let entry3 = new LogEntry(id1, time + 2);
let entry4 = new LogEntry(id1, time + 3); let entry4 = new LogEntry(id1, time + 3);
let entry5 = new LogEntry(id2, time + 3); let entry5 = new LogEntry(id2, time + 3);
let entry6 = new LogEntry(id1, time + 4);
timeline.push(entry1); timeline.push(entry1);
timeline.push(entry2); timeline.push(entry2);
timeline.push(entry3); timeline.push(entry3);
timeline.push(entry4); timeline.push(entry4);
timeline.push(entry5); timeline.push(entry5);
timeline.push(entry6);
assertEquals(timeline.find(time + 0), 0);
assertEquals(timeline.find(time + 1), 1);
assertEquals(timeline.find(time + 2), 2);
assertEquals(timeline.find(time + 3), 3);
assertEquals(timeline.find(time + 4), 5);
assertEquals(timeline.find(time + 5), 5);
assertEquals(timeline.find(time + 2.00), 2);
assertEquals(timeline.find(time + 2.01), 3);
assertEquals(timeline.find(time + 2.90), 3);
assertEquals(timeline.find(time + 3.01), 5);
assertEquals(timeline.find(time + 3.90), 5);
assertEquals(timeline.find(time + 4.00), 5);
let startTime = time; let startTime = time;
let endTime = time + 2; let endTime = time + 2;
timeline.selectTimeRange(startTime, endTime); timeline.selectTimeRange(startTime, endTime);
assertArrayEquals(timeline.selection, [entry1, entry2, entry3]); assertArrayEquals(timeline.selection, [entry1, entry2]);
let entryIdx = timeline.find(time + 1); let entryIdx = timeline.find(time + 1);
let entry = timeline.at(entryIdx); let entry = timeline.at(entryIdx);
assertEquals(entry.time, time + 1); assertEquals(entry.time, time + 1);
......
...@@ -34,8 +34,8 @@ class Timeline { ...@@ -34,8 +34,8 @@ class Timeline {
this._selection = value; this._selection = value;
} }
selectTimeRange(start, end) { selectTimeRange(startTime, endTime) {
this._selection = this.filter(e => e.time >= start && e.time <= end); this._selection = this.range(startTime, endTime);
} }
getChunks(windowSizeMs) { getChunks(windowSizeMs) {
...@@ -134,30 +134,32 @@ class Timeline { ...@@ -134,30 +134,32 @@ class Timeline {
return chunks; return chunks;
} }
range(start, end) { // Return all entries in ({startTime}, {endTime}]
const first = this.find(start); range(startTime, endTime) {
if (first < 0) return []; const firstIndex = this.find(startTime);
const last = this.find(end, first); if (firstIndex < 0) return [];
return this._values.slice(first, last); const lastIndex = this.find(endTime, firstIndex + 1);
return this._values.slice(firstIndex, lastIndex);
} }
// Return the first index for the first element at {time}.
find(time, offset = 0) { find(time, offset = 0) {
return this._find(this._values, each => each.time - time, offset); return this._find(this._values, each => each.time - time, offset);
} }
_find(array, cmp, offset = 0) { // Return the first index for which compareFn(item) is >= 0;
let min = offset; _find(array, compareFn, offset = 0) {
let max = array.length; let minIndex = offset;
while (min < max) { let maxIndex = array.length - 1;
let mid = min + Math.floor((max - min) / 2); while (minIndex < maxIndex) {
let result = cmp(array[mid]); const midIndex = minIndex + (((maxIndex - minIndex) / 2) | 0);
if (result > 0) { if (compareFn(array[midIndex]) < 0) {
max = mid - 1; minIndex = midIndex + 1;
} else { } else {
min = mid + 1; maxIndex = midIndex;
} }
} }
return min; return minIndex;
} }
initializeTypes() { initializeTypes() {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment