Flutter Impeller
geometry_benchmarks.cc
Go to the documentation of this file.
1 // Copyright 2013 The Flutter 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 #include "flutter/benchmarking/benchmarking.h"
6 
10 
11 namespace impeller {
12 
13 namespace {
14 /// A path with many connected cubic components, including
15 /// overlaps/self-intersections/multi-contour.
16 Path CreateCubic();
17 /// Similar to the path above, but with all cubics replaced by quadratics.
18 Path CreateQuadratic();
19 } // namespace
20 
22 
23 template <class... Args>
24 static void BM_Polyline(benchmark::State& state, Args&&... args) {
25  auto args_tuple = std::make_tuple(std::move(args)...);
26  auto path = std::get<Path>(args_tuple);
27  bool tessellate = std::get<bool>(args_tuple);
28 
29  size_t point_count = 0u;
30  size_t single_point_count = 0u;
31  while (state.KeepRunning()) {
32  auto polyline = path.CreatePolyline(1.0f);
33  single_point_count = polyline.points.size();
34  point_count += single_point_count;
35  if (tessellate) {
37  FillType::kNonZero, polyline,
38  [](const float* vertices, size_t vertices_count,
39  const uint16_t* indices, size_t indices_count) { return true; });
40  }
41  }
42  state.counters["SinglePointCount"] = single_point_count;
43  state.counters["TotalPointCount"] = point_count;
44 }
45 
46 BENCHMARK_CAPTURE(BM_Polyline, cubic_polyline, CreateCubic(), false);
47 BENCHMARK_CAPTURE(BM_Polyline, cubic_polyline_tess, CreateCubic(), true);
48 BENCHMARK_CAPTURE(BM_Polyline, quad_polyline, CreateQuadratic(), false);
49 BENCHMARK_CAPTURE(BM_Polyline, quad_polyline_tess, CreateQuadratic(), true);
50 
51 namespace {
52 Path CreateCubic() {
53  return PathBuilder{}
54  .MoveTo({359.934, 96.6335})
55  .CubicCurveTo({358.189, 96.7055}, {356.436, 96.7908}, {354.673, 96.8895})
56  .CubicCurveTo({354.571, 96.8953}, {354.469, 96.9016}, {354.367, 96.9075})
57  .CubicCurveTo({352.672, 97.0038}, {350.969, 97.113}, {349.259, 97.2355})
58  .CubicCurveTo({349.048, 97.2506}, {348.836, 97.2678}, {348.625, 97.2834})
59  .CubicCurveTo({347.019, 97.4014}, {345.407, 97.5299}, {343.789, 97.6722})
60  .CubicCurveTo({343.428, 97.704}, {343.065, 97.7402}, {342.703, 97.7734})
61  .CubicCurveTo({341.221, 97.9086}, {339.736, 98.0505}, {338.246, 98.207})
62  .CubicCurveTo({337.702, 98.2642}, {337.156, 98.3292}, {336.612, 98.3894})
63  .CubicCurveTo({335.284, 98.5356}, {333.956, 98.6837}, {332.623, 98.8476})
64  .CubicCurveTo({332.495, 98.8635}, {332.366, 98.8818}, {332.237, 98.8982})
65  .LineTo({332.237, 102.601})
66  .LineTo({321.778, 102.601})
67  .LineTo({321.778, 100.382})
68  .CubicCurveTo({321.572, 100.413}, {321.367, 100.442}, {321.161, 100.476})
69  .CubicCurveTo({319.22, 100.79}, {317.277, 101.123}, {315.332, 101.479})
70  .CubicCurveTo({315.322, 101.481}, {315.311, 101.482}, {315.301, 101.484})
71  .LineTo({310.017, 105.94})
72  .LineTo({309.779, 105.427})
73  .LineTo({314.403, 101.651})
74  .CubicCurveTo({314.391, 101.653}, {314.379, 101.656}, {314.368, 101.658})
75  .CubicCurveTo({312.528, 102.001}, {310.687, 102.366}, {308.846, 102.748})
76  .CubicCurveTo({307.85, 102.955}, {306.855, 103.182}, {305.859, 103.4})
77  .CubicCurveTo({305.048, 103.579}, {304.236, 103.75}, {303.425, 103.936})
78  .LineTo({299.105, 107.578})
79  .LineTo({298.867, 107.065})
80  .LineTo({302.394, 104.185})
81  .LineTo({302.412, 104.171})
82  .CubicCurveTo({301.388, 104.409}, {300.366, 104.67}, {299.344, 104.921})
83  .CubicCurveTo({298.618, 105.1}, {297.89, 105.269}, {297.165, 105.455})
84  .CubicCurveTo({295.262, 105.94}, {293.36, 106.445}, {291.462, 106.979})
85  .CubicCurveTo({291.132, 107.072}, {290.802, 107.163}, {290.471, 107.257})
86  .CubicCurveTo({289.463, 107.544}, {288.455, 107.839}, {287.449, 108.139})
87  .CubicCurveTo({286.476, 108.431}, {285.506, 108.73}, {284.536, 109.035})
88  .CubicCurveTo({283.674, 109.304}, {282.812, 109.579}, {281.952, 109.859})
89  .CubicCurveTo({281.177, 110.112}, {280.406, 110.377}, {279.633, 110.638})
90  .CubicCurveTo({278.458, 111.037}, {277.256, 111.449}, {276.803, 111.607})
91  .CubicCurveTo({276.76, 111.622}, {276.716, 111.637}, {276.672, 111.653})
92  .CubicCurveTo({275.017, 112.239}, {273.365, 112.836}, {271.721, 113.463})
93  .LineTo({271.717, 113.449})
94  .CubicCurveTo({271.496, 113.496}, {271.238, 113.559}, {270.963, 113.628})
95  .CubicCurveTo({270.893, 113.645}, {270.822, 113.663}, {270.748, 113.682})
96  .CubicCurveTo({270.468, 113.755}, {270.169, 113.834}, {269.839, 113.926})
97  .CubicCurveTo({269.789, 113.94}, {269.732, 113.957}, {269.681, 113.972})
98  .CubicCurveTo({269.391, 114.053}, {269.081, 114.143}, {268.756, 114.239})
99  .CubicCurveTo({268.628, 114.276}, {268.5, 114.314}, {268.367, 114.354})
100  .CubicCurveTo({268.172, 114.412}, {267.959, 114.478}, {267.752, 114.54})
101  .CubicCurveTo({263.349, 115.964}, {258.058, 117.695}, {253.564, 119.252})
102  .CubicCurveTo({253.556, 119.255}, {253.547, 119.258}, {253.538, 119.261})
103  .CubicCurveTo({251.844, 119.849}, {250.056, 120.474}, {248.189, 121.131})
104  .CubicCurveTo({248, 121.197}, {247.812, 121.264}, {247.621, 121.331})
105  .CubicCurveTo({247.079, 121.522}, {246.531, 121.715}, {245.975, 121.912})
106  .CubicCurveTo({245.554, 122.06}, {245.126, 122.212}, {244.698, 122.364})
107  .CubicCurveTo({244.071, 122.586}, {243.437, 122.811}, {242.794, 123.04})
108  .CubicCurveTo({242.189, 123.255}, {241.58, 123.472}, {240.961, 123.693})
109  .CubicCurveTo({240.659, 123.801}, {240.357, 123.909}, {240.052, 124.018})
110  .CubicCurveTo({239.12, 124.351}, {238.18, 124.687}, {237.22, 125.032})
111  .LineTo({237.164, 125.003})
112  .CubicCurveTo({236.709, 125.184}, {236.262, 125.358}, {235.81, 125.538})
113  .CubicCurveTo({235.413, 125.68}, {234.994, 125.832}, {234.592, 125.977})
114  .CubicCurveTo({234.592, 125.977}, {234.591, 125.977}, {234.59, 125.977})
115  .CubicCurveTo({222.206, 130.435}, {207.708, 135.753}, {192.381, 141.429})
116  .CubicCurveTo({162.77, 151.336}, {122.17, 156.894}, {84.1123, 160})
117  .LineTo({360, 160})
118  .LineTo({360, 119.256})
119  .LineTo({360, 106.332})
120  .LineTo({360, 96.6307})
121  .CubicCurveTo({359.978, 96.6317}, {359.956, 96.6326}, {359.934, 96.6335})
122  .Close()
123  .MoveTo({337.336, 124.143})
124  .CubicCurveTo({337.274, 122.359}, {338.903, 121.511}, {338.903, 121.511})
125  .CubicCurveTo({338.903, 121.511}, {338.96, 123.303}, {337.336, 124.143})
126  .Close()
127  .MoveTo({340.082, 121.849})
128  .CubicCurveTo({340.074, 121.917}, {340.062, 121.992}, {340.046, 122.075})
129  .CubicCurveTo({340.039, 122.109}, {340.031, 122.142}, {340.023, 122.177})
130  .CubicCurveTo({340.005, 122.26}, {339.98, 122.346}, {339.952, 122.437})
131  .CubicCurveTo({339.941, 122.473}, {339.931, 122.507}, {339.918, 122.544})
132  .CubicCurveTo({339.873, 122.672}, {339.819, 122.804}, {339.75, 122.938})
133  .CubicCurveTo({339.747, 122.944}, {339.743, 122.949}, {339.74, 122.955})
134  .CubicCurveTo({339.674, 123.08}, {339.593, 123.205}, {339.501, 123.328})
135  .CubicCurveTo({339.473, 123.366}, {339.441, 123.401}, {339.41, 123.438})
136  .CubicCurveTo({339.332, 123.534}, {339.243, 123.625}, {339.145, 123.714})
137  .CubicCurveTo({339.105, 123.75}, {339.068, 123.786}, {339.025, 123.821})
138  .CubicCurveTo({338.881, 123.937}, {338.724, 124.048}, {338.539, 124.143})
139  .CubicCurveTo({338.532, 123.959}, {338.554, 123.79}, {338.58, 123.626})
140  .CubicCurveTo({338.58, 123.625}, {338.58, 123.625}, {338.58, 123.625})
141  .CubicCurveTo({338.607, 123.455}, {338.65, 123.299}, {338.704, 123.151})
142  .CubicCurveTo({338.708, 123.14}, {338.71, 123.127}, {338.714, 123.117})
143  .CubicCurveTo({338.769, 122.971}, {338.833, 122.838}, {338.905, 122.712})
144  .CubicCurveTo({338.911, 122.702}, {338.916, 122.69200000000001},
145  {338.922, 122.682})
146  .CubicCurveTo({338.996, 122.557}, {339.072, 122.444}, {339.155, 122.34})
147  .CubicCurveTo({339.161, 122.333}, {339.166, 122.326}, {339.172, 122.319})
148  .CubicCurveTo({339.256, 122.215}, {339.339, 122.12}, {339.425, 122.037})
149  .CubicCurveTo({339.428, 122.033}, {339.431, 122.03}, {339.435, 122.027})
150  .CubicCurveTo({339.785, 121.687}, {340.106, 121.511}, {340.106, 121.511})
151  .CubicCurveTo({340.106, 121.511}, {340.107, 121.645}, {340.082, 121.849})
152  .Close()
153  .MoveTo({340.678, 113.245})
154  .CubicCurveTo({340.594, 113.488}, {340.356, 113.655}, {340.135, 113.775})
155  .CubicCurveTo({339.817, 113.948}, {339.465, 114.059}, {339.115, 114.151})
156  .CubicCurveTo({338.251, 114.379}, {337.34, 114.516}, {336.448, 114.516})
157  .CubicCurveTo({335.761, 114.516}, {335.072, 114.527}, {334.384, 114.513})
158  .CubicCurveTo({334.125, 114.508}, {333.862, 114.462}, {333.605, 114.424})
159  .CubicCurveTo({332.865, 114.318}, {332.096, 114.184}, {331.41, 113.883})
160  .CubicCurveTo({330.979, 113.695}, {330.442, 113.34}, {330.672, 112.813})
161  .CubicCurveTo({331.135, 111.755}, {333.219, 112.946}, {334.526, 113.833})
162  .CubicCurveTo({334.54, 113.816}, {334.554, 113.8}, {334.569, 113.784})
163  .CubicCurveTo({333.38, 112.708}, {331.749, 110.985}, {332.76, 110.402})
164  .CubicCurveTo({333.769, 109.82}, {334.713, 111.93}, {335.228, 113.395})
165  .CubicCurveTo({334.915, 111.889}, {334.59, 109.636}, {335.661, 109.592})
166  .CubicCurveTo({336.733, 109.636}, {336.408, 111.889}, {336.07, 113.389})
167  .CubicCurveTo({336.609, 111.93}, {337.553, 109.82}, {338.563, 110.402})
168  .CubicCurveTo({339.574, 110.984}, {337.942, 112.708}, {336.753, 113.784})
169  .CubicCurveTo({336.768, 113.8}, {336.782, 113.816}, {336.796, 113.833})
170  .CubicCurveTo({338.104, 112.946}, {340.187, 111.755}, {340.65, 112.813})
171  .CubicCurveTo({340.71, 112.95}, {340.728, 113.102}, {340.678, 113.245})
172  .Close()
173  .MoveTo({346.357, 106.771})
174  .CubicCurveTo({346.295, 104.987}, {347.924, 104.139}, {347.924, 104.139})
175  .CubicCurveTo({347.924, 104.139}, {347.982, 105.931}, {346.357, 106.771})
176  .Close()
177  .MoveTo({347.56, 106.771})
178  .CubicCurveTo({347.498, 104.987}, {349.127, 104.139}, {349.127, 104.139})
179  .CubicCurveTo({349.127, 104.139}, {349.185, 105.931}, {347.56, 106.771})
180  .Close()
181  .TakePath();
182 }
183 
184 Path CreateQuadratic() {
185  return PathBuilder{}
186  .MoveTo({359.934, 96.6335})
187  .QuadraticCurveTo({358.189, 96.7055}, {354.673, 96.8895})
188  .QuadraticCurveTo({354.571, 96.8953}, {354.367, 96.9075})
189  .QuadraticCurveTo({352.672, 97.0038}, {349.259, 97.2355})
190  .QuadraticCurveTo({349.048, 97.2506}, {348.625, 97.2834})
191  .QuadraticCurveTo({347.019, 97.4014}, {343.789, 97.6722})
192  .QuadraticCurveTo({343.428, 97.704}, {342.703, 97.7734})
193  .QuadraticCurveTo({341.221, 97.9086}, {338.246, 98.207})
194  .QuadraticCurveTo({337.702, 98.2642}, {336.612, 98.3894})
195  .QuadraticCurveTo({335.284, 98.5356}, {332.623, 98.8476})
196  .QuadraticCurveTo({332.495, 98.8635}, {332.237, 98.8982})
197  .LineTo({332.237, 102.601})
198  .LineTo({321.778, 102.601})
199  .LineTo({321.778, 100.382})
200  .QuadraticCurveTo({321.572, 100.413}, {321.161, 100.476})
201  .QuadraticCurveTo({319.22, 100.79}, {315.332, 101.479})
202  .QuadraticCurveTo({315.322, 101.481}, {315.301, 101.484})
203  .LineTo({310.017, 105.94})
204  .LineTo({309.779, 105.427})
205  .LineTo({314.403, 101.651})
206  .QuadraticCurveTo({314.391, 101.653}, {314.368, 101.658})
207  .QuadraticCurveTo({312.528, 102.001}, {308.846, 102.748})
208  .QuadraticCurveTo({307.85, 102.955}, {305.859, 103.4})
209  .QuadraticCurveTo({305.048, 103.579}, {303.425, 103.936})
210  .LineTo({299.105, 107.578})
211  .LineTo({298.867, 107.065})
212  .LineTo({302.394, 104.185})
213  .LineTo({302.412, 104.171})
214  .QuadraticCurveTo({301.388, 104.409}, {299.344, 104.921})
215  .QuadraticCurveTo({298.618, 105.1}, {297.165, 105.455})
216  .QuadraticCurveTo({295.262, 105.94}, {291.462, 106.979})
217  .QuadraticCurveTo({291.132, 107.072}, {290.471, 107.257})
218  .QuadraticCurveTo({289.463, 107.544}, {287.449, 108.139})
219  .QuadraticCurveTo({286.476, 108.431}, {284.536, 109.035})
220  .QuadraticCurveTo({283.674, 109.304}, {281.952, 109.859})
221  .QuadraticCurveTo({281.177, 110.112}, {279.633, 110.638})
222  .QuadraticCurveTo({278.458, 111.037}, {276.803, 111.607})
223  .QuadraticCurveTo({276.76, 111.622}, {276.672, 111.653})
224  .QuadraticCurveTo({275.017, 112.239}, {271.721, 113.463})
225  .LineTo({271.717, 113.449})
226  .QuadraticCurveTo({271.496, 113.496}, {270.963, 113.628})
227  .QuadraticCurveTo({270.893, 113.645}, {270.748, 113.682})
228  .QuadraticCurveTo({270.468, 113.755}, {269.839, 113.926})
229  .QuadraticCurveTo({269.789, 113.94}, {269.681, 113.972})
230  .QuadraticCurveTo({269.391, 114.053}, {268.756, 114.239})
231  .QuadraticCurveTo({268.628, 114.276}, {268.367, 114.354})
232  .QuadraticCurveTo({268.172, 114.412}, {267.752, 114.54})
233  .QuadraticCurveTo({263.349, 115.964}, {253.564, 119.252})
234  .QuadraticCurveTo({253.556, 119.255}, {253.538, 119.261})
235  .QuadraticCurveTo({251.844, 119.849}, {248.189, 121.131})
236  .QuadraticCurveTo({248, 121.197}, {247.621, 121.331})
237  .QuadraticCurveTo({247.079, 121.522}, {245.975, 121.912})
238  .QuadraticCurveTo({245.554, 122.06}, {244.698, 122.364})
239  .QuadraticCurveTo({244.071, 122.586}, {242.794, 123.04})
240  .QuadraticCurveTo({242.189, 123.255}, {240.961, 123.693})
241  .QuadraticCurveTo({240.659, 123.801}, {240.052, 124.018})
242  .QuadraticCurveTo({239.12, 124.351}, {237.22, 125.032})
243  .LineTo({237.164, 125.003})
244  .QuadraticCurveTo({236.709, 125.184}, {235.81, 125.538})
245  .QuadraticCurveTo({235.413, 125.68}, {234.592, 125.977})
246  .QuadraticCurveTo({234.592, 125.977}, {234.59, 125.977})
247  .QuadraticCurveTo({222.206, 130.435}, {192.381, 141.429})
248  .QuadraticCurveTo({162.77, 151.336}, {84.1123, 160})
249  .LineTo({360, 160})
250  .LineTo({360, 119.256})
251  .LineTo({360, 106.332})
252  .LineTo({360, 96.6307})
253  .QuadraticCurveTo({359.978, 96.6317}, {359.934, 96.6335})
254  .Close()
255  .MoveTo({337.336, 124.143})
256  .QuadraticCurveTo({337.274, 122.359}, {338.903, 121.511})
257  .QuadraticCurveTo({338.903, 121.511}, {337.336, 124.143})
258  .Close()
259  .MoveTo({340.082, 121.849})
260  .QuadraticCurveTo({340.074, 121.917}, {340.046, 122.075})
261  .QuadraticCurveTo({340.039, 122.109}, {340.023, 122.177})
262  .QuadraticCurveTo({340.005, 122.26}, {339.952, 122.437})
263  .QuadraticCurveTo({339.941, 122.473}, {339.918, 122.544})
264  .QuadraticCurveTo({339.873, 122.672}, {339.75, 122.938})
265  .QuadraticCurveTo({339.747, 122.944}, {339.74, 122.955})
266  .QuadraticCurveTo({339.674, 123.08}, {339.501, 123.328})
267  .QuadraticCurveTo({339.473, 123.366}, {339.41, 123.438})
268  .QuadraticCurveTo({339.332, 123.534}, {339.145, 123.714})
269  .QuadraticCurveTo({339.105, 123.75}, {339.025, 123.821})
270  .QuadraticCurveTo({338.881, 123.937}, {338.539, 124.143})
271  .QuadraticCurveTo({338.532, 123.959}, {338.58, 123.626})
272  .QuadraticCurveTo({338.58, 123.625}, {338.58, 123.625})
273  .QuadraticCurveTo({338.607, 123.455}, {338.704, 123.151})
274  .QuadraticCurveTo({338.708, 123.14}, {338.714, 123.117})
275  .QuadraticCurveTo({338.769, 122.971}, {338.905, 122.712})
276  .QuadraticCurveTo({338.911, 122.702}, {338.922, 122.682})
277  .QuadraticCurveTo({338.996, 122.557}, {339.155, 122.34})
278  .QuadraticCurveTo({339.161, 122.333}, {339.172, 122.319})
279  .QuadraticCurveTo({339.256, 122.215}, {339.425, 122.037})
280  .QuadraticCurveTo({339.428, 122.033}, {339.435, 122.027})
281  .QuadraticCurveTo({339.785, 121.687}, {340.106, 121.511})
282  .QuadraticCurveTo({340.106, 121.511}, {340.082, 121.849})
283  .Close()
284  .MoveTo({340.678, 113.245})
285  .QuadraticCurveTo({340.594, 113.488}, {340.135, 113.775})
286  .QuadraticCurveTo({339.817, 113.948}, {339.115, 114.151})
287  .QuadraticCurveTo({338.251, 114.379}, {336.448, 114.516})
288  .QuadraticCurveTo({335.761, 114.516}, {334.384, 114.513})
289  .QuadraticCurveTo({334.125, 114.508}, {333.605, 114.424})
290  .QuadraticCurveTo({332.865, 114.318}, {331.41, 113.883})
291  .QuadraticCurveTo({330.979, 113.695}, {330.672, 112.813})
292  .QuadraticCurveTo({331.135, 111.755}, {334.526, 113.833})
293  .QuadraticCurveTo({334.54, 113.816}, {334.569, 113.784})
294  .QuadraticCurveTo({333.38, 112.708}, {332.76, 110.402})
295  .QuadraticCurveTo({333.769, 109.82}, {335.228, 113.395})
296  .QuadraticCurveTo({334.915, 111.889}, {335.661, 109.592})
297  .QuadraticCurveTo({336.733, 109.636}, {336.07, 113.389})
298  .QuadraticCurveTo({336.609, 111.93}, {338.563, 110.402})
299  .QuadraticCurveTo({339.574, 110.984}, {336.753, 113.784})
300  .QuadraticCurveTo({336.768, 113.8}, {336.796, 113.833})
301  .QuadraticCurveTo({338.104, 112.946}, {340.65, 112.813})
302  .QuadraticCurveTo({340.71, 112.95}, {340.678, 113.245})
303  .Close()
304  .MoveTo({346.357, 106.771})
305  .QuadraticCurveTo({346.295, 104.987}, {347.924, 104.139})
306  .QuadraticCurveTo({347.924, 104.139}, {346.357, 106.771})
307  .Close()
308  .MoveTo({347.56, 106.771})
309  .QuadraticCurveTo({347.498, 104.987}, {349.127, 104.139})
310  .QuadraticCurveTo({349.127, 104.139}, {347.56, 106.771})
311  .Close()
312  .TakePath();
313 }
314 
315 } // namespace
316 } // namespace impeller
impeller::BM_Polyline
static void BM_Polyline(benchmark::State &state, Args &&... args)
Definition: geometry_benchmarks.cc:24
path.h
impeller::BENCHMARK_CAPTURE
BENCHMARK_CAPTURE(BM_Polyline, cubic_polyline, CreateCubic(), false)
impeller::Tessellator
A utility that generates triangles of the specified fill type given a polyline. This happens on the C...
Definition: tessellator.h:35
impeller::tess
static Tessellator tess
Definition: geometry_benchmarks.cc:21
tessellator.h
path_builder.h
impeller::FillType::kNonZero
@ kNonZero
impeller::Close
void Close(PathBuilder *builder)
Definition: tessellator.cc:36
impeller::Tessellator::Tessellate
Tessellator::Result Tessellate(FillType fill_type, const Path::Polyline &polyline, const BuilderCallback &callback) const
Generates filled triangles from the polyline. A callback is invoked once for the entire tessellation.
Definition: tessellator.cc:61
impeller::LineTo
void LineTo(PathBuilder *builder, Scalar x, Scalar y)
Definition: tessellator.cc:22
impeller
Definition: aiks_context.cc:10