3 * Copyright 2011 Google Inc.
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
11 #include "SkColorPriv.h"
19 kStroke_Flag = 1 << 0,
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)
28 class PathBench : public Benchmark {
33 PathBench(Flags flags) : 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);
40 virtual void appendName(SkString*) = 0;
41 virtual void makePath(SkPath*) = 0;
42 virtual int complexity() { return 0; }
45 virtual const char* onGetName() SK_OVERRIDE {
46 fName.printf("path_%s_%s_",
47 fFlags & kStroke_Flag ? "stroke" : "fill",
48 fFlags & kBig_Flag ? "big" : "small");
49 this->appendName(&fName);
53 virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
54 SkPaint paint(fPaint);
55 this->setupPaint(&paint);
58 this->makePath(&path);
59 if (fFlags & kBig_Flag) {
61 m.setScale(SkIntToScalar(10), SkIntToScalar(10));
66 if (fFlags & kBig_Flag) {
69 count >>= (3 * complexity());
71 for (int i = 0; i < count; i++) {
72 canvas->drawPath(path, paint);
77 typedef Benchmark INHERITED;
80 class TrianglePathBench : public PathBench {
82 TrianglePathBench(Flags flags) : INHERITED(flags) {}
84 virtual void appendName(SkString* name) SK_OVERRIDE {
85 name->append("triangle");
87 virtual void makePath(SkPath* path) SK_OVERRIDE {
88 static const int gCoord[] = {
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]));
97 typedef PathBench INHERITED;
100 class RectPathBench : public PathBench {
102 RectPathBench(Flags flags) : INHERITED(flags) {}
104 virtual void appendName(SkString* name) SK_OVERRIDE {
105 name->append("rect");
107 virtual void makePath(SkPath* path) SK_OVERRIDE {
108 SkRect r = { 10, 10, 20, 20 };
112 typedef PathBench INHERITED;
115 class OvalPathBench : public PathBench {
117 OvalPathBench(Flags flags) : INHERITED(flags) {}
119 virtual void appendName(SkString* name) SK_OVERRIDE {
120 name->append("oval");
122 virtual void makePath(SkPath* path) SK_OVERRIDE {
123 SkRect r = { 10, 10, 23, 20 };
127 typedef PathBench INHERITED;
130 class CirclePathBench: public PathBench {
132 CirclePathBench(Flags flags) : INHERITED(flags) {}
134 virtual void appendName(SkString* name) SK_OVERRIDE {
135 name->append("circle");
137 virtual void makePath(SkPath* path) SK_OVERRIDE {
138 path->addCircle(SkIntToScalar(20), SkIntToScalar(20),
142 typedef PathBench INHERITED;
145 class SawToothPathBench : public PathBench {
147 SawToothPathBench(Flags flags) : INHERITED(flags) {}
149 virtual void appendName(SkString* name) SK_OVERRIDE {
150 name->append("sawtooth");
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;
160 for (int i = 0; i < 32; i++) {
162 path->lineTo(x, y - dy);
164 path->lineTo(x, y + dy);
166 path->lineTo(x, y + 2 * dy);
167 path->lineTo(x0, y + 2 * dy);
170 virtual int complexity() SK_OVERRIDE { return 1; }
172 typedef PathBench INHERITED;
175 class LongCurvedPathBench : public PathBench {
177 LongCurvedPathBench(Flags flags) : INHERITED(flags) {}
179 virtual void appendName(SkString* name) SK_OVERRIDE {
180 name->append("long_curved");
182 virtual void makePath(SkPath* path) SK_OVERRIDE {
185 for (i = 0; i < 100; i++) {
186 path->quadTo(SkScalarMul(rand.nextUScalar1(), SkIntToScalar(640)),
187 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(480)),
188 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(640)),
189 SkScalarMul(rand.nextUScalar1(), SkIntToScalar(480)));
193 virtual int complexity() SK_OVERRIDE { return 2; }
195 typedef PathBench INHERITED;
198 class LongLinePathBench : public PathBench {
200 LongLinePathBench(Flags flags) : INHERITED(flags) {}
202 virtual void appendName(SkString* name) SK_OVERRIDE {
203 name->append("long_line");
205 virtual void makePath(SkPath* path) SK_OVERRIDE {
207 path->moveTo(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480);
208 for (size_t i = 1; i < 100; i++) {
209 path->lineTo(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480);
212 virtual int complexity() SK_OVERRIDE { return 2; }
214 typedef PathBench INHERITED;
217 class RandomPathBench : public Benchmark {
219 virtual bool isSuitableFor(Backend backend) SK_OVERRIDE {
220 return backend == kNonRendering_Backend;
224 void createData(int minVerbs,
226 bool allowMoves = true,
227 SkRect* bounds = NULL) {
229 if (NULL == bounds) {
230 tempBounds.setXYWH(0, 0, SK_Scalar1, SK_Scalar1);
231 bounds = &tempBounds;
233 fVerbCnts.reset(kNumVerbCnts);
234 for (int i = 0; i < kNumVerbCnts; ++i) {
235 fVerbCnts[i] = fRandom.nextRangeU(minVerbs, maxVerbs + 1);
237 fVerbs.reset(kNumVerbs);
238 for (int i = 0; i < kNumVerbs; ++i) {
240 fVerbs[i] = static_cast<SkPath::Verb>(fRandom.nextULessThan(SkPath::kDone_Verb));
241 } while (!allowMoves && SkPath::kMove_Verb == fVerbs[i]);
243 fPoints.reset(kNumPoints);
244 for (int i = 0; i < kNumPoints; ++i) {
245 fPoints[i].set(fRandom.nextRangeScalar(bounds->fLeft, bounds->fRight),
246 fRandom.nextRangeScalar(bounds->fTop, bounds->fBottom));
248 this->restartMakingPaths();
251 void restartMakingPaths() {
257 void makePath(SkPath* path) {
258 int vCount = fVerbCnts[(fCurrPath++) & (kNumVerbCnts - 1)];
259 for (int v = 0; v < vCount; ++v) {
260 int verb = fVerbs[(fCurrVerb++) & (kNumVerbs - 1)];
262 case SkPath::kMove_Verb:
263 path->moveTo(fPoints[(fCurrPoint++) & (kNumPoints - 1)]);
265 case SkPath::kLine_Verb:
266 path->lineTo(fPoints[(fCurrPoint++) & (kNumPoints - 1)]);
268 case SkPath::kQuad_Verb:
269 path->quadTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
270 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)]);
273 case SkPath::kConic_Verb:
274 path->conicTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
275 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)],
279 case SkPath::kCubic_Verb:
280 path->cubicTo(fPoints[(fCurrPoint + 0) & (kNumPoints - 1)],
281 fPoints[(fCurrPoint + 1) & (kNumPoints - 1)],
282 fPoints[(fCurrPoint + 2) & (kNumPoints - 1)]);
285 case SkPath::kClose_Verb:
289 SkDEBUGFAIL("Unexpected path verb");
295 void finishedMakingPaths() {
303 // these should all be pow 2
304 kNumVerbCnts = 1 << 5,
308 SkAutoTArray<int> fVerbCnts;
309 SkAutoTArray<SkPath::Verb> fVerbs;
310 SkAutoTArray<SkPoint> fPoints;
315 typedef Benchmark INHERITED;
318 class PathCreateBench : public RandomPathBench {
324 virtual const char* onGetName() SK_OVERRIDE {
325 return "path_create";
328 virtual void onPreDraw() SK_OVERRIDE {
329 this->createData(10, 100);
332 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
333 for (int i = 0; i < loops; ++i) {
335 fPath.reset(); // PathRef memory can grow without bound otherwise.
337 this->makePath(&fPath);
339 this->restartMakingPaths();
345 typedef RandomPathBench INHERITED;
348 class PathCopyBench : public RandomPathBench {
354 virtual const char* onGetName() SK_OVERRIDE {
357 virtual void onPreDraw() SK_OVERRIDE {
358 this->createData(10, 100);
359 fPaths.reset(kPathCnt);
360 fCopies.reset(kPathCnt);
361 for (int i = 0; i < kPathCnt; ++i) {
362 this->makePath(&fPaths[i]);
364 this->finishedMakingPaths();
366 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
367 for (int i = 0; i < loops; ++i) {
368 int idx = i & (kPathCnt - 1);
369 fCopies[idx] = fPaths[idx];
378 SkAutoTArray<SkPath> fPaths;
379 SkAutoTArray<SkPath> fCopies;
381 typedef RandomPathBench INHERITED;
384 class PathTransformBench : public RandomPathBench {
386 PathTransformBench(bool inPlace) : fInPlace(inPlace) {}
389 virtual const char* onGetName() SK_OVERRIDE {
390 return fInPlace ? "path_transform_in_place" : "path_transform_copy";
393 virtual void onPreDraw() SK_OVERRIDE {
394 fMatrix.setScale(5 * SK_Scalar1, 6 * SK_Scalar1);
395 this->createData(10, 100);
396 fPaths.reset(kPathCnt);
397 for (int i = 0; i < kPathCnt; ++i) {
398 this->makePath(&fPaths[i]);
400 this->finishedMakingPaths();
402 fTransformed.reset(kPathCnt);
406 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
408 for (int i = 0; i < loops; ++i) {
409 fPaths[i & (kPathCnt - 1)].transform(fMatrix);
412 for (int i = 0; i < loops; ++i) {
413 int idx = i & (kPathCnt - 1);
414 fPaths[idx].transform(fMatrix, &fTransformed[idx]);
424 SkAutoTArray<SkPath> fPaths;
425 SkAutoTArray<SkPath> fTransformed;
429 typedef RandomPathBench INHERITED;
432 class PathEqualityBench : public RandomPathBench {
434 PathEqualityBench() { }
437 virtual const char* onGetName() SK_OVERRIDE {
438 return "path_equality_50%";
441 virtual void onPreDraw() SK_OVERRIDE {
443 this->createData(10, 100);
444 fPaths.reset(kPathCnt);
445 fCopies.reset(kPathCnt);
446 for (int i = 0; i < kPathCnt; ++i) {
447 this->makePath(&fPaths[i]);
448 fCopies[i] = fPaths[i];
450 this->finishedMakingPaths();
453 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
454 for (int i = 0; i < loops; ++i) {
455 int idx = i & (kPathCnt - 1);
456 fParity ^= (fPaths[idx] == fCopies[idx & ~0x1]);
461 bool fParity; // attempt to keep compiler from optimizing out the ==
466 SkAutoTArray<SkPath> fPaths;
467 SkAutoTArray<SkPath> fCopies;
468 typedef RandomPathBench INHERITED;
471 class SkBench_AddPathTest : public RandomPathBench {
478 kReversePathTo_AddType,
481 SkBench_AddPathTest(AddType type) : fType(type) {
482 fMatrix.setRotate(60 * SK_Scalar1);
486 virtual const char* onGetName() SK_OVERRIDE {
489 return "path_add_path";
490 case kAddTrans_AddType:
491 return "path_add_path_trans";
492 case kAddMatrix_AddType:
493 return "path_add_path_matrix";
494 case kReverseAdd_AddType:
495 return "path_reverse_add_path";
496 case kReversePathTo_AddType:
497 return "path_reverse_path_to";
499 SkDEBUGFAIL("Bad add type");
504 virtual void onPreDraw() SK_OVERRIDE {
505 // reversePathTo assumes a single contour path.
506 bool allowMoves = kReversePathTo_AddType != fType;
507 this->createData(10, 100, allowMoves);
508 fPaths0.reset(kPathCnt);
509 fPaths1.reset(kPathCnt);
510 for (int i = 0; i < kPathCnt; ++i) {
511 this->makePath(&fPaths0[i]);
512 this->makePath(&fPaths1[i]);
514 this->finishedMakingPaths();
517 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
520 for (int i = 0; i < loops; ++i) {
521 int idx = i & (kPathCnt - 1);
522 SkPath result = fPaths0[idx];
523 result.addPath(fPaths1[idx]);
526 case kAddTrans_AddType:
527 for (int i = 0; i < loops; ++i) {
528 int idx = i & (kPathCnt - 1);
529 SkPath result = fPaths0[idx];
530 result.addPath(fPaths1[idx], 2 * SK_Scalar1, 5 * SK_Scalar1);
533 case kAddMatrix_AddType:
534 for (int i = 0; i < loops; ++i) {
535 int idx = i & (kPathCnt - 1);
536 SkPath result = fPaths0[idx];
537 result.addPath(fPaths1[idx], fMatrix);
540 case kReverseAdd_AddType:
541 for (int i = 0; i < loops; ++i) {
542 int idx = i & (kPathCnt - 1);
543 SkPath result = fPaths0[idx];
544 result.reverseAddPath(fPaths1[idx]);
547 case kReversePathTo_AddType:
548 for (int i = 0; i < loops; ++i) {
549 int idx = i & (kPathCnt - 1);
550 SkPath result = fPaths0[idx];
551 result.reversePathTo(fPaths1[idx]);
558 AddType fType; // or reverseAddPath
563 SkAutoTArray<SkPath> fPaths0;
564 SkAutoTArray<SkPath> fPaths1;
566 typedef RandomPathBench INHERITED;
570 class CirclesBench : public Benchmark {
576 CirclesBench(Flags flags) : fFlags(flags) {
577 fName.printf("circles_%s", fFlags & kStroke_Flag ? "stroke" : "fill");
581 virtual const char* onGetName() SK_OVERRIDE {
582 return fName.c_str();
585 virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
588 paint.setColor(SK_ColorBLACK);
589 paint.setAntiAlias(true);
590 if (fFlags & kStroke_Flag) {
591 paint.setStyle(SkPaint::kStroke_Style);
598 for (int i = 0; i < loops; ++i) {
599 SkScalar radius = rand.nextUScalar1() * 3;
600 r.fLeft = rand.nextUScalar1() * 300;
601 r.fTop = rand.nextUScalar1() * 300;
602 r.fRight = r.fLeft + 2 * radius;
603 r.fBottom = r.fTop + 2 * radius;
605 if (fFlags & kStroke_Flag) {
606 paint.setStrokeWidth(rand.nextUScalar1() * 5.0f);
611 // mimic how Chrome does circles
612 temp.arcTo(r, 0, 0, false);
613 temp.addOval(r, SkPath::kCCW_Direction);
614 temp.arcTo(r, 360, 0, true);
617 canvas->drawPath(temp, paint);
622 typedef Benchmark INHERITED;
626 // Chrome creates its own round rects with each corner possibly being different.
627 // In its "zero radius" incarnation it creates degenerate round rects.
628 // Note: PathTest::test_arb_round_rect_is_convex and
629 // test_arb_zero_rad_round_rect_is_rect perform almost exactly
630 // the same test (but with no drawing)
631 class ArbRoundRectBench : public Benchmark {
636 ArbRoundRectBench(bool zeroRad) : fZeroRad(zeroRad) {
638 fName.printf("zeroradroundrect");
640 fName.printf("arbroundrect");
645 virtual const char* onGetName() SK_OVERRIDE {
646 return fName.c_str();
649 static void add_corner_arc(SkPath* path, const SkRect& rect,
650 SkScalar xIn, SkScalar yIn,
654 SkScalar rx = SkMinScalar(rect.width(), xIn);
655 SkScalar ry = SkMinScalar(rect.height(), yIn);
658 arcRect.set(-rx, -ry, rx, ry);
659 switch (startAngle) {
661 arcRect.offset(rect.fRight - arcRect.fRight, rect.fBottom - arcRect.fBottom);
664 arcRect.offset(rect.fLeft - arcRect.fLeft, rect.fBottom - arcRect.fBottom);
667 arcRect.offset(rect.fLeft - arcRect.fLeft, rect.fTop - arcRect.fTop);
670 arcRect.offset(rect.fRight - arcRect.fRight, rect.fTop - arcRect.fTop);
676 path->arcTo(arcRect, SkIntToScalar(startAngle), SkIntToScalar(90), false);
679 static void make_arb_round_rect(SkPath* path, const SkRect& r,
680 SkScalar xCorner, SkScalar yCorner) {
681 // we are lazy here and use the same x & y for each corner
682 add_corner_arc(path, r, xCorner, yCorner, 270);
683 add_corner_arc(path, r, xCorner, yCorner, 0);
684 add_corner_arc(path, r, xCorner, yCorner, 90);
685 add_corner_arc(path, r, xCorner, yCorner, 180);
688 SkASSERT(path->isConvex());
691 virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
695 for (int i = 0; i < loops; ++i) {
697 paint.setColor(0xff000000 | rand.nextU());
698 paint.setAntiAlias(true);
700 SkScalar size = rand.nextUScalar1() * 30;
701 if (size < SK_Scalar1) {
704 r.fLeft = rand.nextUScalar1() * 300;
705 r.fTop = rand.nextUScalar1() * 300;
706 r.fRight = r.fLeft + 2 * size;
707 r.fBottom = r.fTop + 2 * size;
712 make_arb_round_rect(&temp, r, 0, 0);
714 SkASSERT(temp.isRect(NULL));
716 make_arb_round_rect(&temp, r, r.width() / 10, r.height() / 15);
719 canvas->drawPath(temp, paint);
724 bool fZeroRad; // should 0 radius rounds rects be tested?
726 typedef Benchmark INHERITED;
729 class ConservativelyContainsBench : public Benchmark {
737 ConservativelyContainsBench(Type type) {
739 fName = "conservatively_contains_";
742 fName.append("rect");
743 fPath.addRect(kBaseRect);
745 case kRoundRect_Type:
746 fName.append("round_rect");
747 fPath.addRoundRect(kBaseRect, kRRRadii[0], kRRRadii[1]);
750 fName.append("oval");
751 fPath.addOval(kBaseRect);
756 virtual bool isSuitableFor(Backend backend) SK_OVERRIDE {
757 return backend == kNonRendering_Backend;
761 virtual const char* onGetName() SK_OVERRIDE {
762 return fName.c_str();
765 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
766 for (int i = 0; i < loops; ++i) {
767 const SkRect& rect = fQueryRects[i % kQueryRectCnt];
768 fParity = fParity != fPath.conservativelyContainsRect(rect);
772 virtual void onPreDraw() SK_OVERRIDE {
773 fQueryRects.setCount(kQueryRectCnt);
776 for (int i = 0; i < kQueryRectCnt; ++i) {
779 size.fWidth = rand.nextRangeScalar(kQueryMin.fWidth, kQueryMax.fWidth);
780 size.fHeight = rand.nextRangeScalar(kQueryMin.fHeight, kQueryMax.fHeight);
781 xy.fX = rand.nextRangeScalar(kBounds.fLeft, kBounds.fRight - size.fWidth);
782 xy.fY = rand.nextRangeScalar(kBounds.fTop, kBounds.fBottom - size.fHeight);
784 fQueryRects[i] = SkRect::MakeXYWH(xy.fX, xy.fY, size.fWidth, size.fHeight);
791 static const SkRect kBounds; // bounds for all random query rects
792 static const SkSize kQueryMin; // minimum query rect size, should be <= kQueryMax
793 static const SkSize kQueryMax; // max query rect size, should < kBounds
794 static const SkRect kBaseRect; // rect that is used to construct the path
795 static const SkScalar kRRRadii[2]; // x and y radii for round rect
800 SkTDArray<SkRect> fQueryRects;
802 typedef Benchmark INHERITED;
805 ///////////////////////////////////////////////////////////////////////////////
807 #include "SkGeometry.h"
809 class ConicBench_Chop5 : public Benchmark {
813 fRQ.fPts[0].set(0, 0);
814 fRQ.fPts[1].set(100, 0);
815 fRQ.fPts[2].set(100, 100);
816 fRQ.fW = SkScalarCos(SK_ScalarPI/4);
820 virtual const char* onGetName() SK_OVERRIDE {
821 return "ratquad-chop-0.5";
824 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
826 for (int i = 0; i < loops; ++i) {
827 fRQ.chopAt(0.5f, dst);
831 typedef Benchmark INHERITED;
834 class ConicBench_ChopHalf : public Benchmark {
837 ConicBench_ChopHalf() {
838 fRQ.fPts[0].set(0, 0);
839 fRQ.fPts[1].set(100, 0);
840 fRQ.fPts[2].set(100, 100);
841 fRQ.fW = SkScalarCos(SK_ScalarPI/4);
845 virtual const char* onGetName() SK_OVERRIDE {
846 return "ratquad-chop-half";
849 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
851 for (int i = 0; i < loops; ++i) {
856 typedef Benchmark INHERITED;
859 ///////////////////////////////////////////////////////////////////////////////
861 static void rand_conic(SkConic* conic, SkRandom& rand) {
862 for (int i = 0; i < 3; ++i) {
863 conic->fPts[i].set(rand.nextUScalar1() * 100, rand.nextUScalar1() * 100);
865 if (rand.nextUScalar1() > 0.5f) {
866 conic->fW = rand.nextUScalar1();
868 conic->fW = 1 + rand.nextUScalar1() * 4;
872 class ConicBench : public Benchmark {
876 for (int i = 0; i < CONICS; ++i) {
877 rand_conic(&fConics[i], rand);
881 virtual bool isSuitableFor(Backend backend) SK_OVERRIDE {
882 return backend == kNonRendering_Backend;
889 SkConic fConics[CONICS];
892 typedef Benchmark INHERITED;
895 class ConicBench_ComputeError : public ConicBench {
897 ConicBench_ComputeError() {}
900 virtual const char* onGetName() SK_OVERRIDE {
901 return "conic-compute-error";
904 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
906 for (int i = 0; i < loops; ++i) {
907 for (int j = 0; j < CONICS; ++j) {
908 fConics[j].computeAsQuadError(&err);
914 typedef ConicBench INHERITED;
917 class ConicBench_asQuadTol : public ConicBench {
919 ConicBench_asQuadTol() {}
922 virtual const char* onGetName() SK_OVERRIDE {
923 return "conic-asQuadTol";
926 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
927 for (int i = 0; i < loops; ++i) {
928 for (int j = 0; j < CONICS; ++j) {
929 fConics[j].asQuadTol(SK_ScalarHalf);
935 typedef ConicBench INHERITED;
938 class ConicBench_quadPow2 : public ConicBench {
940 ConicBench_quadPow2() {}
943 virtual const char* onGetName() SK_OVERRIDE {
944 return "conic-quadPow2";
947 virtual void onDraw(const int loops, SkCanvas*) SK_OVERRIDE {
948 for (int i = 0; i < loops; ++i) {
949 for (int j = 0; j < CONICS; ++j) {
950 fConics[j].computeQuadPOW2(SK_ScalarHalf);
956 typedef ConicBench INHERITED;
959 ///////////////////////////////////////////////////////////////////////////////
961 const SkRect ConservativelyContainsBench::kBounds = SkRect::MakeWH(SkIntToScalar(100), SkIntToScalar(100));
962 const SkSize ConservativelyContainsBench::kQueryMin = SkSize::Make(SkIntToScalar(1), SkIntToScalar(1));
963 const SkSize ConservativelyContainsBench::kQueryMax = SkSize::Make(SkIntToScalar(40), SkIntToScalar(40));
964 const SkRect ConservativelyContainsBench::kBaseRect = SkRect::MakeXYWH(SkIntToScalar(25), SkIntToScalar(25), SkIntToScalar(50), SkIntToScalar(50));
965 const SkScalar ConservativelyContainsBench::kRRRadii[2] = {SkIntToScalar(5), SkIntToScalar(10)};
967 DEF_BENCH( return new TrianglePathBench(FLAGS00); )
968 DEF_BENCH( return new TrianglePathBench(FLAGS01); )
969 DEF_BENCH( return new TrianglePathBench(FLAGS10); )
970 DEF_BENCH( return new TrianglePathBench(FLAGS11); )
972 DEF_BENCH( return new RectPathBench(FLAGS00); )
973 DEF_BENCH( return new RectPathBench(FLAGS01); )
974 DEF_BENCH( return new RectPathBench(FLAGS10); )
975 DEF_BENCH( return new RectPathBench(FLAGS11); )
977 DEF_BENCH( return new OvalPathBench(FLAGS00); )
978 DEF_BENCH( return new OvalPathBench(FLAGS01); )
979 DEF_BENCH( return new OvalPathBench(FLAGS10); )
980 DEF_BENCH( return new OvalPathBench(FLAGS11); )
982 DEF_BENCH( return new CirclePathBench(FLAGS00); )
983 DEF_BENCH( return new CirclePathBench(FLAGS01); )
984 DEF_BENCH( return new CirclePathBench(FLAGS10); )
985 DEF_BENCH( return new CirclePathBench(FLAGS11); )
987 DEF_BENCH( return new SawToothPathBench(FLAGS00); )
988 DEF_BENCH( return new SawToothPathBench(FLAGS01); )
990 DEF_BENCH( return new LongCurvedPathBench(FLAGS00); )
991 DEF_BENCH( return new LongCurvedPathBench(FLAGS01); )
992 DEF_BENCH( return new LongLinePathBench(FLAGS00); )
993 DEF_BENCH( return new LongLinePathBench(FLAGS01); )
995 DEF_BENCH( return new PathCreateBench(); )
996 DEF_BENCH( return new PathCopyBench(); )
997 DEF_BENCH( return new PathTransformBench(true); )
998 DEF_BENCH( return new PathTransformBench(false); )
999 DEF_BENCH( return new PathEqualityBench(); )
1001 DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAdd_AddType); )
1002 DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAddTrans_AddType); )
1003 DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kAddMatrix_AddType); )
1004 DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kReverseAdd_AddType); )
1005 DEF_BENCH( return new SkBench_AddPathTest(SkBench_AddPathTest::kReversePathTo_AddType); )
1007 DEF_BENCH( return new CirclesBench(FLAGS00); )
1008 DEF_BENCH( return new CirclesBench(FLAGS01); )
1009 DEF_BENCH( return new ArbRoundRectBench(false); )
1010 DEF_BENCH( return new ArbRoundRectBench(true); )
1011 DEF_BENCH( return new ConservativelyContainsBench(ConservativelyContainsBench::kRect_Type); )
1012 DEF_BENCH( return new ConservativelyContainsBench(ConservativelyContainsBench::kRoundRect_Type); )
1013 DEF_BENCH( return new ConservativelyContainsBench(ConservativelyContainsBench::kOval_Type); )
1015 // These seem to be optimized away, which is troublesome for timing.
1017 DEF_BENCH( return new ConicBench_Chop5() )
1018 DEF_BENCH( return new ConicBench_ChopHalf() )
1019 DEF_BENCH( return new ConicBench_ComputeError() )
1020 DEF_BENCH( return new ConicBench_asQuadTol() )
1021 DEF_BENCH( return new ConicBench_quadPow2() )