Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(208)

Side by Side Diff: test/js-perf-test/Generators/generators.js

Issue 2026503002: Add js-perf-test benchmark for generators. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | test/js-perf-test/Generators/run.js » ('j') | test/js-perf-test/JSTests.json » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2016 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5
6 new BenchmarkSuite('Generators', [1000], [
7 new Benchmark('Basic', false, false, 0, Basic),
8 new Benchmark('Loop', false, false, 0, Loop),
9 new Benchmark('Input', false, false, 0, Input),
10 new Benchmark('YieldStar', false, false, 0, YieldStar),
11 ]);
12
13
14 // ----------------------------------------------------------------------------
15 // Benchmark: Basic
16 // ----------------------------------------------------------------------------
17
18 function* five() {
19 yield 1;
20 yield 2;
21 yield 3;
22 yield 4;
23 yield 5;
24 }
25
26 function Basic() {
27 let g = five();
28 let sum = 0;
29 sum += g.next().value;
30 sum += g.next().value;
31 sum += g.next().value;
32 sum += g.next().value;
33 sum += g.next().value;
34 if (sum != 15 || !g.next().done) throw "wrong";
35 }
36
37
38 // ----------------------------------------------------------------------------
39 // Benchmark: Loop
40 // ----------------------------------------------------------------------------
41
42 function* fibonacci() {
43 let x = 0;
44 let y = 1;
45 yield x;
46 while (true) {
47 yield y;
48 let tmp = x;
49 x = y;
50 y += tmp;
51 }
52 }
53
54 function Loop() {
55 let n = 0;
56 let x;
57 for (x of fibonacci()) {
58 if (++n === 42) break;
59 }
60 if (x != 165580141) throw "wrong";
61 }
62
63
64
65 // ----------------------------------------------------------------------------
66 // Benchmark: Input
67 // ----------------------------------------------------------------------------
68
69 function* multiples(x) {
70 let skip = function.sent || 0;
71 let next = 0;
72 while (true) {
73 if (skip === 0) {
74 skip = yield next;
75 } else {
76 skip--;
77 }
78 next += x;
79 }
80 }
81
82 function Input() {
83 let g = multiples(3);
84 results = [g.next(2), g.next(0), g.next(5), g.next(10)];
85 if (results.slice(-1)[0].value != 60) throw "wrong";
86 }
87
88
89 // ----------------------------------------------------------------------------
90 // Benchmark: YieldStar
91 // ----------------------------------------------------------------------------
92
93 function* infix(node) {
94 if (node) {
95 yield* infix(node.left);
96 yield node.label;
97 yield* infix(node.right);
98 }
99 }
100
101 class Node {
102 constructor(label, left, right) {
103 this.label = label;
104 this.left = left;
105 this.right = right;
106 }
107 }
108
109 function YieldStar() {
110 let tree = new Node(1,
111 new Node(2,
112 new Node(3,
113 new Node(4,
114 new Node(16,
115 new Node(5,
116 new Node(23,
117 new Node(0),
118 new Node(17)),
119 new Node(44, new Node(20)))),
120 new Node(7,
121 undefined,
122 new Node(23,
123 new Node(0),
124 new Node(41, undefined, new Node(11))))),
125 new Node(8)),
126 new Node(5)),
127 new Node(6, undefined, new Node(7)));
128 let labels = [...(infix(tree))];
129 // 0,23,17,5,20,44,16,4,7,0,23,41,11,3,8,2,5,1,6,7
130 if (labels[0] != 0) throw "wrong";
131 }
OLDNEW
« no previous file with comments | « no previous file | test/js-perf-test/Generators/run.js » ('j') | test/js-perf-test/JSTests.json » ('J')

Powered by Google App Engine
This is Rietveld 408576698