blob: 37b47dd2250cb2a35660cc925617ff941bba5003 [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
2/*
3 * Copyright 2011 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
reed@google.comd34658a2011-04-11 13:12:51 +00008#include "SkBenchmark.h"
9#include "SkBitmap.h"
10#include "SkCanvas.h"
11#include "SkColorPriv.h"
12#include "SkPaint.h"
tomhudson@google.com6e8d3352011-06-22 17:16:35 +000013#include "SkRandom.h"
reed@google.comd34658a2011-04-11 13:12:51 +000014#include "SkShader.h"
15#include "SkString.h"
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +000016#include "SkTArray.h"
17
reed@google.comd34658a2011-04-11 13:12:51 +000018enum Flags {
19 kStroke_Flag = 1 << 0,
20 kBig_Flag = 1 << 1
21};
22
23#define FLAGS00 Flags(0)
24#define FLAGS01 Flags(kStroke_Flag)
25#define FLAGS10 Flags(kBig_Flag)
26#define FLAGS11 Flags(kStroke_Flag | kBig_Flag)
27
28class PathBench : public SkBenchmark {
29 SkPaint fPaint;
30 SkString fName;
31 Flags fFlags;
reed@google.comd34658a2011-04-11 13:12:51 +000032public:
33 PathBench(void* param, Flags flags) : INHERITED(param), fFlags(flags) {
34 fPaint.setStyle(flags & kStroke_Flag ? SkPaint::kStroke_Style :
35 SkPaint::kFill_Style);
36 fPaint.setStrokeWidth(SkIntToScalar(5));
37 fPaint.setStrokeJoin(SkPaint::kBevel_Join);
38 }
39
40 virtual void appendName(SkString*) = 0;
41 virtual void makePath(SkPath*) = 0;
tomhudson@google.com6e8d3352011-06-22 17:16:35 +000042 virtual int complexity() { return 0; }
reed@google.comd34658a2011-04-11 13:12:51 +000043
44protected:
bsalomon@google.com1647a192012-04-11 15:34:46 +000045 virtual const char* onGetName() SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +000046 fName.printf("path_%s_%s_",
47 fFlags & kStroke_Flag ? "stroke" : "fill",
48 fFlags & kBig_Flag ? "big" : "small");
49 this->appendName(&fName);
50 return fName.c_str();
51 }
52
bsalomon@google.com1647a192012-04-11 15:34:46 +000053 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +000054 SkPaint paint(fPaint);
55 this->setupPaint(&paint);
56
57 SkPath path;
58 this->makePath(&path);
59 if (fFlags & kBig_Flag) {
60 SkMatrix m;
61 m.setScale(SkIntToScalar(10), SkIntToScalar(10));
62 path.transform(m);
63 }
64
mtklein@google.comc2897432013-09-10 19:23:38 +000065 int count = this->getLoops();
reed@google.comd34658a2011-04-11 13:12:51 +000066 if (fFlags & kBig_Flag) {
67 count >>= 2;
68 }
tomhudson@google.com6e8d3352011-06-22 17:16:35 +000069 count >>= (3 * complexity());
reed@google.comd34658a2011-04-11 13:12:51 +000070
71 for (int i = 0; i < count; i++) {
72 canvas->drawPath(path, paint);
73 }
74 }
75
76private:
77 typedef SkBenchmark INHERITED;
78};
79
80class TrianglePathBench : public PathBench {
81public:
82 TrianglePathBench(void* param, Flags flags) : INHERITED(param, flags) {}
rmistry@google.comfbfcd562012-08-23 18:09:54 +000083
bsalomon@google.com1647a192012-04-11 15:34:46 +000084 virtual void appendName(SkString* name) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +000085 name->append("triangle");
86 }
bsalomon@google.com1647a192012-04-11 15:34:46 +000087 virtual void makePath(SkPath* path) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +000088 static const int gCoord[] = {
89 10, 10, 15, 5, 20, 20
90 };
91 path->moveTo(SkIntToScalar(gCoord[0]), SkIntToScalar(gCoord[1]));
92 path->lineTo(SkIntToScalar(gCoord[2]), SkIntToScalar(gCoord[3]));
93 path->lineTo(SkIntToScalar(gCoord[4]), SkIntToScalar(gCoord[5]));
94 path->close();
95 }
96private:
97 typedef PathBench INHERITED;
98};
99
100class RectPathBench : public PathBench {
101public:
102 RectPathBench(void* param, Flags flags) : INHERITED(param, flags) {}
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000103
bsalomon@google.com1647a192012-04-11 15:34:46 +0000104 virtual void appendName(SkString* name) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +0000105 name->append("rect");
106 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000107 virtual void makePath(SkPath* path) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +0000108 SkRect r = { 10, 10, 20, 20 };
109 path->addRect(r);
110 }
111private:
112 typedef PathBench INHERITED;
113};
114
115class OvalPathBench : public PathBench {
116public:
117 OvalPathBench(void* param, Flags flags) : INHERITED(param, flags) {}
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000118
bsalomon@google.com1647a192012-04-11 15:34:46 +0000119 virtual void appendName(SkString* name) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +0000120 name->append("oval");
121 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000122 virtual void makePath(SkPath* path) SK_OVERRIDE {
jvanverth@google.come2bfd8b2013-01-24 15:45:35 +0000123 SkRect r = { 10, 10, 23, 20 };
reed@google.comd34658a2011-04-11 13:12:51 +0000124 path->addOval(r);
125 }
126private:
127 typedef PathBench INHERITED;
128};
129
bsalomon@google.com1647a192012-04-11 15:34:46 +0000130class CirclePathBench: public PathBench {
131public:
132 CirclePathBench(void* param, Flags flags) : INHERITED(param, flags) {}
133
134 virtual void appendName(SkString* name) SK_OVERRIDE {
135 name->append("circle");
136 }
137 virtual void makePath(SkPath* path) SK_OVERRIDE {
138 path->addCircle(SkIntToScalar(20), SkIntToScalar(20),
139 SkIntToScalar(10));
140 }
141private:
142 typedef PathBench INHERITED;
143};
144
reed@google.comd34658a2011-04-11 13:12:51 +0000145class SawToothPathBench : public PathBench {
146public:
147 SawToothPathBench(void* param, Flags flags) : INHERITED(param, flags) {}
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000148
bsalomon@google.com1647a192012-04-11 15:34:46 +0000149 virtual void appendName(SkString* name) SK_OVERRIDE {
reed@google.comd34658a2011-04-11 13:12:51 +0000150 name->append("sawtooth");
151 }
152 virtual void makePath(SkPath* path) {
153 SkScalar x = SkIntToScalar(20);
154 SkScalar y = SkIntToScalar(20);
155 const SkScalar x0 = x;
156 const SkScalar dx = SK_Scalar1 * 5;
157 const SkScalar dy = SK_Scalar1 * 10;
158
159 path->moveTo(x, y);
160 for (int i = 0; i < 32; i++) {
161 x += dx;
162 path->lineTo(x, y - dy);
163 x += dx;
164 path->lineTo(x, y + dy);
165 }
166 path->lineTo(x, y + 2 * dy);
167 path->lineTo(x0, y + 2 * dy);
168 path->close();
169 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000170 virtual int complexity() SK_OVERRIDE { return 1; }
reed@google.comd34658a2011-04-11 13:12:51 +0000171private:
172 typedef PathBench INHERITED;
173};
174
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000175class LongCurvedPathBench : public PathBench {
176public:
177 LongCurvedPathBench(void * param, Flags flags)
178 : INHERITED(param, flags) {
179 }
180
bsalomon@google.com1647a192012-04-11 15:34:46 +0000181 virtual void appendName(SkString* name) SK_OVERRIDE {
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000182 name->append("long_curved");
183 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000184 virtual void makePath(SkPath* path) SK_OVERRIDE {
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000185 SkRandom rand (12);
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000186 int i;
187 for (i = 0; i < 100; i++) {
188 path->quadTo(SkScalarMul(rand.nextUScalar1(), SkIntToScalar(640)),
189 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(480)),
190 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(640)),
191 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(480)));
192 }
193 path->close();
194 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000195 virtual int complexity() SK_OVERRIDE { return 2; }
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000196private:
197 typedef PathBench INHERITED;
198};
199
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +0000200class LongLinePathBench : public PathBench {
201public:
202 LongLinePathBench(void * param, Flags flags)
203 : INHERITED(param, flags) {
204 }
205
bsalomon@google.com1647a192012-04-11 15:34:46 +0000206 virtual void appendName(SkString* name) SK_OVERRIDE {
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +0000207 name->append("long_line");
208 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000209 virtual void makePath(SkPath* path) SK_OVERRIDE {
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000210 SkRandom rand;
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +0000211 path->moveTo(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480);
212 for (size_t i = 1; i < 100; i++) {
213 path->lineTo(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480);
214 }
215 }
bsalomon@google.com1647a192012-04-11 15:34:46 +0000216 virtual int complexity() SK_OVERRIDE { return 2; }
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +0000217private:
218 typedef PathBench INHERITED;
219};
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000220
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000221class RandomPathBench : public SkBenchmark {
222public:
223 RandomPathBench(void* param) : INHERITED(param) {
robertphillips@google.com83187a22012-09-13 16:39:08 +0000224 fIsRendering = false;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000225 }
226
227protected:
228 void createData(int minVerbs,
229 int maxVerbs,
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000230 bool allowMoves = true,
231 SkRect* bounds = NULL) {
232 SkRect tempBounds;
233 if (NULL == bounds) {
234 tempBounds.setXYWH(0, 0, SK_Scalar1, SK_Scalar1);
235 bounds = &tempBounds;
236 }
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000237 fVerbCnts.reset(kNumVerbCnts);
238 for (int i = 0; i < kNumVerbCnts; ++i) {
239 fVerbCnts[i] = fRandom.nextRangeU(minVerbs, maxVerbs + 1);
240 }
241 fVerbs.reset(kNumVerbs);
242 for (int i = 0; i < kNumVerbs; ++i) {
243 do {
244 fVerbs[i] = static_cast<SkPath::Verb>(fRandom.nextULessThan(SkPath::kDone_Verb));
245 } while (!allowMoves && SkPath::kMove_Verb == fVerbs[i]);
246 }
247 fPoints.reset(kNumPoints);
248 for (int i = 0; i < kNumPoints; ++i) {
249 fPoints[i].set(fRandom.nextRangeScalar(bounds->fLeft, bounds->fRight),
250 fRandom.nextRangeScalar(bounds->fTop, bounds->fBottom));
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000251 }
252 this->restartMakingPaths();
253 }
254
255 void restartMakingPaths() {
256 fCurrPath = 0;
257 fCurrVerb = 0;
258 fCurrPoint = 0;
259 }
260
261 void makePath(SkPath* path) {
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000262 int vCount = fVerbCnts[(fCurrPath++) & (kNumVerbCnts - 1)];
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000263 for (int v = 0; v < vCount; ++v) {
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000264 int verb = fVerbs[(fCurrVerb++) & (kNumVerbs - 1)];
265 switch (verb) {
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000266 case SkPath::kMove_Verb:
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000267 path->moveTo(fPoints[(fCurrPoint++) & (kNumPoints - 1)]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000268 break;
269 case SkPath::kLine_Verb:
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000270 path->lineTo(fPoints[(fCurrPoint++) & (kNumPoints - 1)]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000271 break;
272 case SkPath::kQuad_Verb:
bsalomon@google.com373ebc62012-09-26 13:08:56 +0000273 path->quadTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
274 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)]);
275 fCurrPoint += 2;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000276 break;
reed@google.com277c3f82013-05-31 15:17:50 +0000277 case SkPath::kConic_Verb:
278 path->conicTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
279 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)],
280 SK_ScalarHalf);
281 fCurrPoint += 2;
282 break;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000283 case SkPath::kCubic_Verb:
bsalomon@google.com373ebc62012-09-26 13:08:56 +0000284 path->cubicTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
285 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)],
286 fPoints[(fCurrPoint + 2) & (kNumPoints - 1)]);
287 fCurrPoint += 3;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000288 break;
289 case SkPath::kClose_Verb:
290 path->close();
291 break;
292 default:
293 SkDEBUGFAIL("Unexpected path verb");
294 break;
295 }
296 }
297 }
298
299 void finishedMakingPaths() {
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000300 fVerbCnts.reset(0);
301 fVerbs.reset(0);
302 fPoints.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000303 }
304
305private:
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000306 enum {
307 // these should all be pow 2
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000308 kNumVerbCnts = 1 << 5,
309 kNumVerbs = 1 << 5,
310 kNumPoints = 1 << 5,
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000311 };
312 SkAutoTArray<int> fVerbCnts;
313 SkAutoTArray<SkPath::Verb> fVerbs;
314 SkAutoTArray<SkPoint> fPoints;
315 int fCurrPath;
316 int fCurrVerb;
317 int fCurrPoint;
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000318 SkRandom fRandom;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000319 typedef SkBenchmark INHERITED;
320};
321
322class PathCreateBench : public RandomPathBench {
323public:
324 PathCreateBench(void* param) : INHERITED(param) {
325 }
326
327protected:
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000328 virtual const char* onGetName() SK_OVERRIDE {
329 return "path_create";
330 }
331
332 virtual void onPreDraw() SK_OVERRIDE {
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000333 this->createData(10, 100);
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000334 fPaths.reset(kPathCnt);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000335 }
336
337 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000338 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000339 this->makePath(&fPaths[i & (kPathCnt - 1)]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000340 }
341 this->restartMakingPaths();
342 }
343
344 virtual void onPostDraw() SK_OVERRIDE {
345 this->finishedMakingPaths();
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000346 fPaths.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000347 }
348
349private:
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000350 enum {
351 // must be a pow 2
352 kPathCnt = 1 << 5,
353 };
354 SkAutoTArray<SkPath> fPaths;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000355
356 typedef RandomPathBench INHERITED;
357};
358
359class PathCopyBench : public RandomPathBench {
360public:
361 PathCopyBench(void* param) : INHERITED(param) {
362 }
363
364protected:
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000365 virtual const char* onGetName() SK_OVERRIDE {
366 return "path_copy";
367 }
368 virtual void onPreDraw() SK_OVERRIDE {
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000369 this->createData(10, 100);
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000370 fPaths.reset(kPathCnt);
371 fCopies.reset(kPathCnt);
372 for (int i = 0; i < kPathCnt; ++i) {
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000373 this->makePath(&fPaths[i]);
374 }
375 this->finishedMakingPaths();
376 }
377 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000378 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000379 int idx = i & (kPathCnt - 1);
380 fCopies[idx] = fPaths[idx];
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000381 }
382 }
383 virtual void onPostDraw() SK_OVERRIDE {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000384 fPaths.reset(0);
385 fCopies.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000386 }
387
388private:
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000389 enum {
390 // must be a pow 2
391 kPathCnt = 1 << 5,
392 };
393 SkAutoTArray<SkPath> fPaths;
394 SkAutoTArray<SkPath> fCopies;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000395
396 typedef RandomPathBench INHERITED;
397};
398
399class PathTransformBench : public RandomPathBench {
400public:
401 PathTransformBench(bool inPlace, void* param)
402 : INHERITED(param)
403 , fInPlace(inPlace) {
404 }
405
406protected:
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000407 virtual const char* onGetName() SK_OVERRIDE {
408 return fInPlace ? "path_transform_in_place" : "path_transform_copy";
409 }
410
411 virtual void onPreDraw() SK_OVERRIDE {
412 fMatrix.setScale(5 * SK_Scalar1, 6 * SK_Scalar1);
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000413 this->createData(10, 100);
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000414 fPaths.reset(kPathCnt);
415 for (int i = 0; i < kPathCnt; ++i) {
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000416 this->makePath(&fPaths[i]);
417 }
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000418 this->finishedMakingPaths();
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000419 if (!fInPlace) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000420 fTransformed.reset(kPathCnt);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000421 }
422 }
423
424 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
425 if (fInPlace) {
mtklein@google.comc2897432013-09-10 19:23:38 +0000426 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000427 fPaths[i & (kPathCnt - 1)].transform(fMatrix);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000428 }
429 } else {
mtklein@google.comc2897432013-09-10 19:23:38 +0000430 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000431 int idx = i & (kPathCnt - 1);
432 fPaths[idx].transform(fMatrix, &fTransformed[idx]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000433 }
434 }
435 }
436
437 virtual void onPostDraw() SK_OVERRIDE {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000438 fPaths.reset(0);
439 fTransformed.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000440 }
441
442private:
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000443 enum {
444 // must be a pow 2
445 kPathCnt = 1 << 5,
446 };
447 SkAutoTArray<SkPath> fPaths;
448 SkAutoTArray<SkPath> fTransformed;
449
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000450 SkMatrix fMatrix;
451 bool fInPlace;
452 typedef RandomPathBench INHERITED;
453};
454
455class PathEqualityBench : public RandomPathBench {
456public:
457 PathEqualityBench(void* param)
458 : INHERITED(param) {
459 }
460
461protected:
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000462 virtual const char* onGetName() SK_OVERRIDE {
463 return "path_equality_50%";
464 }
465
466 virtual void onPreDraw() SK_OVERRIDE {
467 fParity = 0;
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000468 this->createData(10, 100);
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000469 fPaths.reset(kPathCnt);
470 fCopies.reset(kPathCnt);
471 for (int i = 0; i < kPathCnt; ++i) {
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000472 this->makePath(&fPaths[i]);
473 fCopies[i] = fPaths[i];
474 }
475 this->finishedMakingPaths();
476 }
477
478 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000479 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000480 int idx = i & (kPathCnt - 1);
481 fParity ^= (fPaths[idx] == fCopies[idx & ~0x1]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000482 }
483 }
484
485 virtual void onPostDraw() SK_OVERRIDE {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000486 fPaths.reset(0);
487 fCopies.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000488 }
489
490private:
491 bool fParity; // attempt to keep compiler from optimizing out the ==
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000492 enum {
493 // must be a pow 2
494 kPathCnt = 1 << 5,
495 };
496 SkAutoTArray<SkPath> fPaths;
497 SkAutoTArray<SkPath> fCopies;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000498 typedef RandomPathBench INHERITED;
499};
500
501class SkBench_AddPathTest : public RandomPathBench {
502public:
503 enum AddType {
504 kAdd_AddType,
505 kAddTrans_AddType,
506 kAddMatrix_AddType,
507 kPathTo_AddType,
508 kReverseAdd_AddType,
509 kReversePathTo_AddType,
510 };
511
512 SkBench_AddPathTest(AddType type, void* param)
513 : INHERITED(param)
514 , fType(type) {
515 fMatrix.setRotate(60 * SK_Scalar1);
516 }
517
518protected:
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000519 virtual const char* onGetName() SK_OVERRIDE {
520 switch (fType) {
521 case kAdd_AddType:
522 return "path_add_path";
523 case kAddTrans_AddType:
524 return "path_add_path_trans";
525 case kAddMatrix_AddType:
526 return "path_add_path_matrix";
527 case kPathTo_AddType:
528 return "path_path_to";
529 case kReverseAdd_AddType:
530 return "path_reverse_add_path";
531 case kReversePathTo_AddType:
532 return "path_reverse_path_to";
533 default:
534 SkDEBUGFAIL("Bad add type");
535 return "";
536 }
537 }
538
539 virtual void onPreDraw() SK_OVERRIDE {
540 // pathTo and reversePathTo assume a single contour path.
541 bool allowMoves = kPathTo_AddType != fType &&
542 kReversePathTo_AddType != fType;
bsalomon@google.com6d552ee2012-08-14 15:10:09 +0000543 this->createData(10, 100, allowMoves);
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000544 fPaths0.reset(kPathCnt);
545 fPaths1.reset(kPathCnt);
546 for (int i = 0; i < kPathCnt; ++i) {
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000547 this->makePath(&fPaths0[i]);
548 this->makePath(&fPaths1[i]);
549 }
550 this->finishedMakingPaths();
551 }
552
553 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
554 switch (fType) {
555 case kAdd_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000556 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000557 int idx = i & (kPathCnt - 1);
558 SkPath result = fPaths0[idx];
559 result.addPath(fPaths1[idx]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000560 }
561 break;
562 case kAddTrans_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000563 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000564 int idx = i & (kPathCnt - 1);
565 SkPath result = fPaths0[idx];
566 result.addPath(fPaths1[idx], 2 * SK_Scalar1, 5 * SK_Scalar1);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000567 }
568 break;
569 case kAddMatrix_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000570 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000571 int idx = i & (kPathCnt - 1);
572 SkPath result = fPaths0[idx];
573 result.addPath(fPaths1[idx], fMatrix);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000574 }
575 break;
576 case kPathTo_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000577 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000578 int idx = i & (kPathCnt - 1);
579 SkPath result = fPaths0[idx];
580 result.pathTo(fPaths1[idx]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000581 }
582 break;
583 case kReverseAdd_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000584 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000585 int idx = i & (kPathCnt - 1);
586 SkPath result = fPaths0[idx];
587 result.reverseAddPath(fPaths1[idx]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000588 }
589 break;
590 case kReversePathTo_AddType:
mtklein@google.comc2897432013-09-10 19:23:38 +0000591 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000592 int idx = i & (kPathCnt - 1);
593 SkPath result = fPaths0[idx];
594 result.reversePathTo(fPaths1[idx]);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000595 }
596 break;
597 }
598 }
599
600 virtual void onPostDraw() SK_OVERRIDE {
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000601 fPaths0.reset(0);
602 fPaths1.reset(0);
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000603 }
604
605private:
606 AddType fType; // or reverseAddPath
bsalomon@google.comb5e47032012-08-14 17:49:46 +0000607 enum {
608 // must be a pow 2
609 kPathCnt = 1 << 5,
610 };
611 SkAutoTArray<SkPath> fPaths0;
612 SkAutoTArray<SkPath> fPaths1;
bsalomon@google.com30e6d2c2012-08-13 14:03:31 +0000613 SkMatrix fMatrix;
614 typedef RandomPathBench INHERITED;
615};
tomhudson@google.com6e8d3352011-06-22 17:16:35 +0000616
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000617
618class CirclesBench : public SkBenchmark {
619protected:
620 SkString fName;
jvanverth@google.com46d3d392013-01-22 13:34:01 +0000621 Flags fFlags;
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000622
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000623public:
jvanverth@google.com46d3d392013-01-22 13:34:01 +0000624 CirclesBench(void* param, Flags flags) : INHERITED(param), fFlags(flags) {
625 fName.printf("circles_%s", fFlags & kStroke_Flag ? "stroke" : "fill");
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000626 }
627
628protected:
629 virtual const char* onGetName() SK_OVERRIDE {
630 return fName.c_str();
631 }
632
633 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
634 SkPaint paint;
635
636 paint.setColor(SK_ColorBLACK);
637 paint.setAntiAlias(true);
jvanverth@google.com46d3d392013-01-22 13:34:01 +0000638 if (fFlags & kStroke_Flag) {
639 paint.setStyle(SkPaint::kStroke_Style);
640 }
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000641
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000642 SkRandom rand;
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000643
644 SkRect r;
645
mtklein@google.comc2897432013-09-10 19:23:38 +0000646 for (int i = 0; i < this->getLoops(); ++i) {
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000647 SkScalar radius = rand.nextUScalar1() * 3;
648 r.fLeft = rand.nextUScalar1() * 300;
649 r.fTop = rand.nextUScalar1() * 300;
650 r.fRight = r.fLeft + 2 * radius;
651 r.fBottom = r.fTop + 2 * radius;
652
jvanverth@google.com46d3d392013-01-22 13:34:01 +0000653 if (fFlags & kStroke_Flag) {
654 paint.setStrokeWidth(rand.nextUScalar1() * 5.0f);
655 }
656
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000657 SkPath temp;
658
659 // mimic how Chrome does circles
660 temp.arcTo(r, 0, 0, false);
661 temp.addOval(r, SkPath::kCCW_Direction);
662 temp.arcTo(r, 360, 0, true);
663 temp.close();
rmistry@google.comfbfcd562012-08-23 18:09:54 +0000664
robertphillips@google.com17bb4582012-08-20 17:24:16 +0000665 canvas->drawPath(temp, paint);
666 }
667 }
668
669private:
670 typedef SkBenchmark INHERITED;
671};
672
jvanverth@google.com46d3d392013-01-22 13:34:01 +0000673
robertphillips@google.com158618e2012-10-23 16:56:56 +0000674// Chrome creates its own round rects with each corner possibly being different.
675// In its "zero radius" incarnation it creates degenerate round rects.
skia.committer@gmail.com1e34ff72012-10-24 02:01:24 +0000676// Note: PathTest::test_arb_round_rect_is_convex and
robertphillips@google.com158618e2012-10-23 16:56:56 +0000677// test_arb_zero_rad_round_rect_is_rect perform almost exactly
robertphillips@google.comb95eaa82012-10-18 15:26:12 +0000678// the same test (but with no drawing)
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000679class ArbRoundRectBench : public SkBenchmark {
680protected:
681 SkString fName;
682
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000683public:
robertphillips@google.com158618e2012-10-23 16:56:56 +0000684 ArbRoundRectBench(void* param, bool zeroRad) : INHERITED(param), fZeroRad(zeroRad) {
685 if (zeroRad) {
686 fName.printf("zeroradroundrect");
687 } else {
688 fName.printf("arbroundrect");
689 }
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000690 }
691
692protected:
693 virtual const char* onGetName() SK_OVERRIDE {
694 return fName.c_str();
695 }
696
skia.committer@gmail.com989a95e2012-10-18 02:01:23 +0000697 static void add_corner_arc(SkPath* path, const SkRect& rect,
698 SkScalar xIn, SkScalar yIn,
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000699 int startAngle)
700 {
701
702 SkScalar rx = SkMinScalar(rect.width(), xIn);
703 SkScalar ry = SkMinScalar(rect.height(), yIn);
704
705 SkRect arcRect;
706 arcRect.set(-rx, -ry, rx, ry);
707 switch (startAngle) {
708 case 0:
709 arcRect.offset(rect.fRight - arcRect.fRight, rect.fBottom - arcRect.fBottom);
710 break;
711 case 90:
712 arcRect.offset(rect.fLeft - arcRect.fLeft, rect.fBottom - arcRect.fBottom);
713 break;
714 case 180:
715 arcRect.offset(rect.fLeft - arcRect.fLeft, rect.fTop - arcRect.fTop);
716 break;
717 case 270:
718 arcRect.offset(rect.fRight - arcRect.fRight, rect.fTop - arcRect.fTop);
719 break;
720 default:
721 break;
722 }
723
724 path->arcTo(arcRect, SkIntToScalar(startAngle), SkIntToScalar(90), false);
725 }
726
skia.committer@gmail.com989a95e2012-10-18 02:01:23 +0000727 static void make_arb_round_rect(SkPath* path, const SkRect& r,
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000728 SkScalar xCorner, SkScalar yCorner) {
729 // we are lazy here and use the same x & y for each corner
730 add_corner_arc(path, r, xCorner, yCorner, 270);
731 add_corner_arc(path, r, xCorner, yCorner, 0);
732 add_corner_arc(path, r, xCorner, yCorner, 90);
733 add_corner_arc(path, r, xCorner, yCorner, 180);
robertphillips@google.com158618e2012-10-23 16:56:56 +0000734 path->close();
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000735
robertphillips@google.comb95eaa82012-10-18 15:26:12 +0000736 SkASSERT(path->isConvex());
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000737 }
738
739 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000740 SkRandom rand;
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000741 SkRect r;
742
mtklein@google.comc2897432013-09-10 19:23:38 +0000743 for (int i = 0; i < this->getLoops(); ++i) {
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000744 SkPaint paint;
745 paint.setColor(0xff000000 | rand.nextU());
746 paint.setAntiAlias(true);
747
robertphillips@google.com158618e2012-10-23 16:56:56 +0000748 SkScalar size = rand.nextUScalar1() * 30;
749 if (size < SK_Scalar1) {
robertphillips@google.comb95eaa82012-10-18 15:26:12 +0000750 continue;
751 }
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000752 r.fLeft = rand.nextUScalar1() * 300;
753 r.fTop = rand.nextUScalar1() * 300;
robertphillips@google.com158618e2012-10-23 16:56:56 +0000754 r.fRight = r.fLeft + 2 * size;
755 r.fBottom = r.fTop + 2 * size;
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000756
757 SkPath temp;
758
robertphillips@google.com158618e2012-10-23 16:56:56 +0000759 if (fZeroRad) {
760 make_arb_round_rect(&temp, r, 0, 0);
761
762 SkASSERT(temp.isRect(NULL));
763 } else {
764 make_arb_round_rect(&temp, r, r.width() / 10, r.height() / 15);
765 }
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000766
767 canvas->drawPath(temp, paint);
768 }
769 }
770
771private:
robertphillips@google.com158618e2012-10-23 16:56:56 +0000772 bool fZeroRad; // should 0 radius rounds rects be tested?
773
robertphillips@google.comf6fc3fc2012-10-17 15:23:21 +0000774 typedef SkBenchmark INHERITED;
775};
776
bsalomon@google.com9bee33a2012-11-13 21:51:38 +0000777class ConservativelyContainsBench : public SkBenchmark {
778public:
779 enum Type {
780 kRect_Type,
781 kRoundRect_Type,
782 kOval_Type,
783 };
784
785 ConservativelyContainsBench(void* param, Type type) : INHERITED(param) {
786 fIsRendering = false;
787 fParity = false;
788 fName = "conservatively_contains_";
789 switch (type) {
790 case kRect_Type:
791 fName.append("rect");
792 fPath.addRect(kBaseRect);
793 break;
794 case kRoundRect_Type:
795 fName.append("round_rect");
796 fPath.addRoundRect(kBaseRect, kRRRadii[0], kRRRadii[1]);
797 break;
798 case kOval_Type:
799 fName.append("oval");
800 fPath.addOval(kBaseRect);
801 break;
802 }
803 }
804
805private:
806 virtual const char* onGetName() SK_OVERRIDE {
807 return fName.c_str();
808 }
809
sugoi@google.com77472f02013-03-05 18:50:01 +0000810 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000811 for (int i = 0; i < this->getLoops(); ++i) {
bsalomon@google.com9bee33a2012-11-13 21:51:38 +0000812 const SkRect& rect = fQueryRects[i % kQueryRectCnt];
813 fParity = fParity != fPath.conservativelyContainsRect(rect);
814 }
815 }
816
817 virtual void onPreDraw() SK_OVERRIDE {
818 fQueryRects.setCount(kQueryRectCnt);
819
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000820 SkRandom rand;
bsalomon@google.com9bee33a2012-11-13 21:51:38 +0000821 for (int i = 0; i < kQueryRectCnt; ++i) {
822 SkSize size;
823 SkPoint xy;
824 size.fWidth = rand.nextRangeScalar(kQueryMin.fWidth, kQueryMax.fWidth);
825 size.fHeight = rand.nextRangeScalar(kQueryMin.fHeight, kQueryMax.fHeight);
826 xy.fX = rand.nextRangeScalar(kBounds.fLeft, kBounds.fRight - size.fWidth);
827 xy.fY = rand.nextRangeScalar(kBounds.fTop, kBounds.fBottom - size.fHeight);
828
829 fQueryRects[i] = SkRect::MakeXYWH(xy.fX, xy.fY, size.fWidth, size.fHeight);
830 }
831 }
832
833 virtual void onPostDraw() SK_OVERRIDE {
834 fQueryRects.setCount(0);
835 }
836
837 enum {
bsalomon@google.com9bee33a2012-11-13 21:51:38 +0000838 kQueryRectCnt = 400,
839 };
840 static const SkRect kBounds; // bounds for all random query rects
841 static const SkSize kQueryMin; // minimum query rect size, should be <= kQueryMax
842 static const SkSize kQueryMax; // max query rect size, should < kBounds
843 static const SkRect kBaseRect; // rect that is used to construct the path
844 static const SkScalar kRRRadii[2]; // x and y radii for round rect
845
846 SkString fName;
847 SkPath fPath;
848 bool fParity;
849 SkTDArray<SkRect> fQueryRects;
850
851 typedef SkBenchmark INHERITED;
852};
853
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000854///////////////////////////////////////////////////////////////////////////////
855
856#include "SkGeometry.h"
857
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000858class ConicBench_Chop5 : public SkBenchmark {
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000859 SkConic fRQ;
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000860public:
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000861 ConicBench_Chop5(void* param) : INHERITED(param) {
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000862 fRQ.fPts[0].set(0, 0);
863 fRQ.fPts[1].set(100, 0);
864 fRQ.fPts[2].set(100, 100);
865 fRQ.fW = SkScalarCos(SK_ScalarPI/4);
866 }
skia.committer@gmail.comab38e562013-04-14 07:01:08 +0000867
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000868private:
869 virtual const char* onGetName() SK_OVERRIDE {
870 return "ratquad-chop-0.5";
871 }
skia.committer@gmail.comab38e562013-04-14 07:01:08 +0000872
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000873 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000874 SkConic dst[2];
mtklein@google.comc2897432013-09-10 19:23:38 +0000875 for (int i = 0; i < this->getLoops(); ++i) {
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000876 fRQ.chopAt(0.5f, dst);
877 }
878 }
skia.committer@gmail.comab38e562013-04-14 07:01:08 +0000879
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000880 typedef SkBenchmark INHERITED;
881};
882
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000883class ConicBench_ChopHalf : public SkBenchmark {
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000884 SkConic fRQ;
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000885public:
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000886 ConicBench_ChopHalf(void* param) : INHERITED(param) {
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000887 fRQ.fPts[0].set(0, 0);
888 fRQ.fPts[1].set(100, 0);
889 fRQ.fPts[2].set(100, 100);
890 fRQ.fW = SkScalarCos(SK_ScalarPI/4);
891 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000892
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000893private:
894 virtual const char* onGetName() SK_OVERRIDE {
895 return "ratquad-chop-half";
896 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000897
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000898 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mike@reedtribe.org28552e12013-04-26 00:58:29 +0000899 SkConic dst[2];
mtklein@google.comc2897432013-09-10 19:23:38 +0000900 for (int i = 0; i < this->getLoops(); ++i) {
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000901 fRQ.chop(dst);
902 }
903 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000904
mike@reedtribe.org8d551012013-04-14 02:40:50 +0000905 typedef SkBenchmark INHERITED;
906};
907
908///////////////////////////////////////////////////////////////////////////////
909
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000910static void rand_conic(SkConic* conic, SkRandom& rand) {
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000911 for (int i = 0; i < 3; ++i) {
912 conic->fPts[i].set(rand.nextUScalar1() * 100, rand.nextUScalar1() * 100);
913 }
914 if (rand.nextUScalar1() > 0.5f) {
915 conic->fW = rand.nextUScalar1();
916 } else {
917 conic->fW = 1 + rand.nextUScalar1() * 4;
918 }
919}
920
921class ConicBench : public SkBenchmark {
922public:
923 ConicBench(void* param) : INHERITED(param) {
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +0000924 SkRandom rand;
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000925 for (int i = 0; i < CONICS; ++i) {
926 rand_conic(&fConics[i], rand);
927 }
928 fIsRendering = false;
929 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000930
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000931protected:
932 enum {
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000933 CONICS = 100
934 };
935 SkConic fConics[CONICS];
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000936
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000937private:
938 typedef SkBenchmark INHERITED;
939};
940
941class ConicBench_ComputeError : public ConicBench {
942public:
943 ConicBench_ComputeError(void* param) : INHERITED(param) {}
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000944
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000945protected:
946 virtual const char* onGetName() SK_OVERRIDE {
947 return "conic-compute-error";
948 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000949
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000950 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
951 SkVector err;
mtklein@google.comc2897432013-09-10 19:23:38 +0000952 for (int i = 0; i < this->getLoops(); ++i) {
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000953 for (int j = 0; j < CONICS; ++j) {
954 fConics[j].computeAsQuadError(&err);
955 }
956 }
957 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000958
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000959private:
960 typedef ConicBench INHERITED;
961};
962
963class ConicBench_asQuadTol : public ConicBench {
964public:
965 ConicBench_asQuadTol(void* param) : INHERITED(param) {}
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000966
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000967protected:
968 virtual const char* onGetName() SK_OVERRIDE {
969 return "conic-asQuadTol";
970 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000971
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000972 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000973 for (int i = 0; i < this->getLoops(); ++i) {
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000974 for (int j = 0; j < CONICS; ++j) {
975 fConics[j].asQuadTol(SK_ScalarHalf);
976 }
977 }
978 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000979
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000980private:
981 typedef ConicBench INHERITED;
982};
983
984class ConicBench_quadPow2 : public ConicBench {
985public:
986 ConicBench_quadPow2(void* param) : INHERITED(param) {}
987
988protected:
989 virtual const char* onGetName() SK_OVERRIDE {
990 return "conic-quadPow2";
991 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +0000992
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000993 virtual void onDraw(SkCanvas*) SK_OVERRIDE {
mtklein@google.comc2897432013-09-10 19:23:38 +0000994 for (int i = 0; i < this->getLoops(); ++i) {
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +0000995 for (int j = 0; j < CONICS; ++j) {
996 fConics[j].computeQuadPOW2(SK_ScalarHalf);
997 }
998 }
999 }
skia.committer@gmail.com81521132013-04-30 07:01:03 +00001000
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +00001001private:
1002 typedef ConicBench INHERITED;
1003};
1004
1005///////////////////////////////////////////////////////////////////////////////
1006
bsalomon@google.com9bee33a2012-11-13 21:51:38 +00001007const SkRect ConservativelyContainsBench::kBounds = SkRect::MakeWH(SkIntToScalar(100), SkIntToScalar(100));
1008const SkSize ConservativelyContainsBench::kQueryMin = SkSize::Make(SkIntToScalar(1), SkIntToScalar(1));
1009const SkSize ConservativelyContainsBench::kQueryMax = SkSize::Make(SkIntToScalar(40), SkIntToScalar(40));
1010const SkRect ConservativelyContainsBench::kBaseRect = SkRect::MakeXYWH(SkIntToScalar(25), SkIntToScalar(25), SkIntToScalar(50), SkIntToScalar(50));
1011const SkScalar ConservativelyContainsBench::kRRRadii[2] = {SkIntToScalar(5), SkIntToScalar(10)};
1012
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001013DEF_BENCH( return new TrianglePathBench(p, FLAGS00); )
1014DEF_BENCH( return new TrianglePathBench(p, FLAGS01); )
1015DEF_BENCH( return new TrianglePathBench(p, FLAGS10); )
1016DEF_BENCH( return new TrianglePathBench(p, FLAGS11); )
reed@google.comd34658a2011-04-11 13:12:51 +00001017
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001018DEF_BENCH( return new RectPathBench(p, FLAGS00); )
1019DEF_BENCH( return new RectPathBench(p, FLAGS01); )
1020DEF_BENCH( return new RectPathBench(p, FLAGS10); )
1021DEF_BENCH( return new RectPathBench(p, FLAGS11); )
reed@google.comd34658a2011-04-11 13:12:51 +00001022
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001023DEF_BENCH( return new OvalPathBench(p, FLAGS00); )
1024DEF_BENCH( return new OvalPathBench(p, FLAGS01); )
1025DEF_BENCH( return new OvalPathBench(p, FLAGS10); )
1026DEF_BENCH( return new OvalPathBench(p, FLAGS11); )
reed@google.comd34658a2011-04-11 13:12:51 +00001027
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001028DEF_BENCH( return new CirclePathBench(p, FLAGS00); )
1029DEF_BENCH( return new CirclePathBench(p, FLAGS01); )
1030DEF_BENCH( return new CirclePathBench(p, FLAGS10); )
1031DEF_BENCH( return new CirclePathBench(p, FLAGS11); )
bsalomon@google.com1647a192012-04-11 15:34:46 +00001032
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001033DEF_BENCH( return new SawToothPathBench(p, FLAGS00); )
1034DEF_BENCH( return new SawToothPathBench(p, FLAGS01); )
reed@google.comd34658a2011-04-11 13:12:51 +00001035
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001036DEF_BENCH( return new LongCurvedPathBench(p, FLAGS00); )
1037DEF_BENCH( return new LongCurvedPathBench(p, FLAGS01); )
1038DEF_BENCH( return new LongLinePathBench(p, FLAGS00); )
1039DEF_BENCH( return new LongLinePathBench(p, FLAGS01); )
tomhudson@google.com6e8d3352011-06-22 17:16:35 +00001040
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001041DEF_BENCH( return new PathCreateBench(p); )
1042DEF_BENCH( return new PathCopyBench(p); )
1043DEF_BENCH( return new PathTransformBench(true, p); )
1044DEF_BENCH( return new PathTransformBench(false, p); )
1045DEF_BENCH( return new PathEqualityBench(p); )
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +00001046
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001047DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAdd_AddType, p); )
1048DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAddTrans_AddType, p); )
1049DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAddMatrix_AddType, p); )
1050DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kPathTo_AddType, p); )
1051DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kReverseAdd_AddType, p); )
1052DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kReversePathTo_AddType, p); )
senorblanco@chromium.orge50f7362012-01-12 19:10:35 +00001053
mike@reedtribe.org0cf7b822013-02-04 05:05:36 +00001054DEF_BENCH( return new CirclesBench(p, FLAGS00); )
1055DEF_BENCH( return new CirclesBench(p, FLAGS01); )
1056DEF_BENCH( return new ArbRoundRectBench(p, false); )
1057DEF_BENCH( return new ArbRoundRectBench(p, true); )
1058DEF_BENCH( return new ConservativelyContainsBench(p, ConservativelyContainsBench::kRect_Type); )
1059DEF_BENCH( return new ConservativelyContainsBench(p, ConservativelyContainsBench::kRoundRect_Type); )
1060DEF_BENCH( return new ConservativelyContainsBench(p, ConservativelyContainsBench::kOval_Type); )
mike@reedtribe.org8d551012013-04-14 02:40:50 +00001061
mike@reedtribe.org28552e12013-04-26 00:58:29 +00001062DEF_BENCH( return new ConicBench_Chop5(p) )
1063DEF_BENCH( return new ConicBench_ChopHalf(p) )
mike@reedtribe.orgaf5c5062013-04-30 02:14:58 +00001064DEF_BENCH( return new ConicBench_ComputeError(p) )
1065DEF_BENCH( return new ConicBench_asQuadTol(p) )
1066DEF_BENCH( return new ConicBench_quadPow2(p) )