WebKit Bugzilla
New
Browse
Search+
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
87863
Web Inspector: speed up _calculateRetainedSizes function
https://bugs.webkit.org/show_bug.cgi?id=87863
Summary
Web Inspector: speed up _calculateRetainedSizes function
Alexei Filippov
Reported
2012-05-30 09:41:32 PDT
Rewrite the algorithm to be O(n) instead of O(n*log(n)). Before: RESULT heap-snapshot: _calculateRetainedSizes= 86 ms After: RESULT heap-snapshot: _calculateRetainedSizes= 31 ms
Attachments
Patch
(4.17 KB, patch)
2012-05-30 10:00 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Patch
(3.60 KB, patch)
2012-05-31 05:30 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Patch
(12.73 KB, patch)
2012-05-31 06:42 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Patch
(13.28 KB, patch)
2012-06-01 05:41 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Patch
(13.29 KB, patch)
2012-06-01 05:54 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Patch
(13.34 KB, patch)
2012-06-01 06:04 PDT
,
Alexei Filippov
no flags
Details
Formatted Diff
Diff
Show Obsolete
(5)
View All
Add attachment
proposed patch, testcase, etc.
Alexei Filippov
Comment 1
2012-05-30 10:00:05 PDT
Created
attachment 144845
[details]
Patch
Yury Semikhatsky
Comment 2
2012-05-31 00:59:00 PDT
Comment on
attachment 144845
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=144845&action=review
> Source/WebCore/inspector/front-end/HeapSnapshot.js:1253 > + var nodesSelfSize = this._nodes.subarray(this._nodeSelfSizeOffset);
You don't need subarray here, adding this._nodeSelfSizeOffset would probably be more clear to the reader.
> Source/WebCore/inspector/front-end/HeapSnapshot.js:1263 > + nodeStack[nodeStackTop] = rootNodeOrdinal;
Now that we anyways have postorder index we could go though it and update each nodes retained size sequentially. This way you wouldn't need this stack. WDYT?
Yury Semikhatsky
Comment 3
2012-05-31 00:59:17 PDT
(In reply to
comment #0
)
> Rewrite the algorithm to be O(n) instead of O(n*log(n)). > > Before: > RESULT heap-snapshot: _calculateRetainedSizes= 86 ms > > After: > RESULT heap-snapshot: _calculateRetainedSizes= 31 ms
What's the point in optimizing this given that it is such a small fraction of the overall time?
Yury Semikhatsky
Comment 4
2012-05-31 04:50:35 PDT
Comment on
attachment 144845
[details]
Patch Clearing r? until the comments are addressed.
Alexei Filippov
Comment 5
2012-05-31 05:25:51 PDT
(In reply to
comment #2
)
> (From update of
attachment 144845
[details]
) > View in context:
https://bugs.webkit.org/attachment.cgi?id=144845&action=review
> > > Source/WebCore/inspector/front-end/HeapSnapshot.js:1253 > > + var nodesSelfSize = this._nodes.subarray(this._nodeSelfSizeOffset); > > You don't need subarray here, adding this._nodeSelfSizeOffset would probably be more clear to the reader.
I've done that to eliminate extra addition from the loop. But if you think the code became too complicated, I'll change it back.
> > > Source/WebCore/inspector/front-end/HeapSnapshot.js:1263 > > + nodeStack[nodeStackTop] = rootNodeOrdinal; > > Now that we anyways have postorder index we could go though it and update each nodes retained size sequentially. This way you wouldn't need this stack. WDYT?
Cool idea. Done that. The time has reduced to 10ms. (In reply to
comment #3
)
> (In reply to
comment #0
) > > Rewrite the algorithm to be O(n) instead of O(n*log(n)). > > > > Before: > > RESULT heap-snapshot: _calculateRetainedSizes= 86 ms > > > > After: > > RESULT heap-snapshot: _calculateRetainedSizes= 31 ms > > What's the point in optimizing this given that it is such a small fraction of the overall time?
This fraction is small for this particular performance test. You know the current algorithm has O(n*n) for the worst case (e.g. a linked list structure). I checked it on a worst case test having 50k objects. The time it spends in this function has dropped from 10000ms to 2ms.
Yury Semikhatsky
Comment 6
2012-05-31 05:30:39 PDT
(In reply to
comment #5
)
> (In reply to
comment #2
) > > (From update of
attachment 144845
[details]
[details]) > > View in context:
https://bugs.webkit.org/attachment.cgi?id=144845&action=review
> > > > > Source/WebCore/inspector/front-end/HeapSnapshot.js:1253 > > > + var nodesSelfSize = this._nodes.subarray(this._nodeSelfSizeOffset); > > > > You don't need subarray here, adding this._nodeSelfSizeOffset would probably be more clear to the reader. > > I've done that to eliminate extra addition from the loop. But if you think the code became too complicated, I'll change it back. > > > > > > Source/WebCore/inspector/front-end/HeapSnapshot.js:1263 > > > + nodeStack[nodeStackTop] = rootNodeOrdinal; > > > > Now that we anyways have postorder index we could go though it and update each nodes retained size sequentially. This way you wouldn't need this stack. WDYT? > > Cool idea. Done that. The time has reduced to 10ms. >
Mind uploading new patch?
> (In reply to
comment #3
) > > (In reply to
comment #0
) > > > Rewrite the algorithm to be O(n) instead of O(n*log(n)). > > > > > > Before: > > > RESULT heap-snapshot: _calculateRetainedSizes= 86 ms > > > > > > After: > > > RESULT heap-snapshot: _calculateRetainedSizes= 31 ms > > > > What's the point in optimizing this given that it is such a small fraction of the overall time? > > This fraction is small for this particular performance test. You know the current algorithm has O(n*n) for the worst case (e.g. a linked list structure). > I checked it on a worst case test having 50k objects. The time it spends in this function has dropped from 10000ms to 2ms.
Can you convert that into a layout test/performance test?
Alexei Filippov
Comment 7
2012-05-31 05:30:50 PDT
Created
attachment 145061
[details]
Patch
Alexei Filippov
Comment 8
2012-05-31 06:42:55 PDT
Created
attachment 145079
[details]
Patch
Alexei Filippov
Comment 9
2012-05-31 06:43:17 PDT
Added the performance test.
Yury Semikhatsky
Comment 10
2012-05-31 06:52:57 PDT
Comment on
attachment 145079
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=145079&action=review
> PerformanceTests/inspector/performance-test.js:148 > + InspectorTest.measureFunction(WebInspector.HeapSnapshot.prototype, "_buildRetainers");
This file is used not only by profiler.
Ilya Tikhonovsky
Comment 11
2012-05-31 06:55:25 PDT
View in context:
https://bugs.webkit.org/attachment.cgi?id=145079&action=review
> PerformanceTests/inspector/performance-test.js:211 > + timer.done("heap-snapshot");
heap-snapshot is a page name. You have to calculate it from the url or transfer it as an argument.
Alexei Filippov
Comment 12
2012-06-01 05:41:25 PDT
Created
attachment 145276
[details]
Patch
Yury Semikhatsky
Comment 13
2012-06-01 05:50:05 PDT
Comment on
attachment 145276
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=145276&action=review
> PerformanceTests/inspector/heap-performance-test.js:1 > +function test()
heap-performance-test.js -> heap-profiler-performance-test.js or heap-snapshot-performance-test.js
Alexei Filippov
Comment 14
2012-06-01 05:54:23 PDT
Created
attachment 145280
[details]
Patch
Ilya Tikhonovsky
Comment 15
2012-06-01 05:57:55 PDT
Comment on
attachment 145280
[details]
Patch looks good to me
Alexei Filippov
Comment 16
2012-06-01 06:04:11 PDT
Created
attachment 145283
[details]
Patch
WebKit Review Bot
Comment 17
2012-06-04 05:28:54 PDT
Comment on
attachment 145283
[details]
Patch Rejecting
attachment 145283
[details]
from commit-queue.
alexeif@chromium.org
does not have committer permissions according to
http://trac.webkit.org/browser/trunk/Tools/Scripts/webkitpy/common/config/committers.py
. - If you do not have committer rights please read
http://webkit.org/coding/contributing.html
for instructions on how to use bugzilla flags. - If you have committer rights please correct the error in Tools/Scripts/webkitpy/common/config/committers.py by adding yourself to the file (no review needed). The commit-queue restarts itself every 2 hours. After restart the commit-queue will correctly respect your committer rights.
Ilya Tikhonovsky
Comment 18
2012-06-04 05:38:45 PDT
Comment on
attachment 145283
[details]
Patch Clearing flags on attachment: 145283 Committed
r119389
: <
http://trac.webkit.org/changeset/119389
>
Ilya Tikhonovsky
Comment 19
2012-06-04 05:38:55 PDT
All reviewed patches have been landed. Closing bug.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug