Index: bench/TopoSortBench.cpp |
diff --git a/bench/TopoSortBench.cpp b/bench/TopoSortBench.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3fa1c0ff972bc6382434929e47000650e107bd97 |
--- /dev/null |
+++ b/bench/TopoSortBench.cpp |
@@ -0,0 +1,79 @@ |
+/* |
+ * Copyright 2015 Google Inc. |
+ * |
+ * Use of this source code is governed by a BSD-style license that can be |
+ * found in the LICENSE file. |
+ */ |
+ |
+#include "Benchmark.h" |
+#include "SkRandom.h" |
+#include "SkString.h" |
+#include "SkTTopoSort.h" |
+ |
+#include "sk_tool_utils.h" |
+ |
+class TopoSortBench : public Benchmark { |
+public: |
+ TopoSortBench() { } |
+ |
+ ~TopoSortBench() override { |
+ sk_tool_utils::TopoTestNode::DeallocNodes(&fGraph); |
+ } |
+ |
+ bool isSuitableFor(Backend backend) override { |
+ return kNonRendering_Backend == backend; |
+ } |
+ |
+protected: |
+ const char* onGetName() override { |
+ return "sort_topo_rand"; |
+ } |
+ |
+ // Delayed initialization only done if onDraw will be called. |
+ void onDelayedSetup() override { |
+ sk_tool_utils::TopoTestNode::AllocNodes(&fGraph, kNumElements); |
+ |
+ for (int i = kNumElements-1; i > 0; --i) { |
+ int numEdges = fRand.nextU() % (kMaxEdges+1); |
+ |
+ for (int j = 0; j < numEdges; ++j) { |
+ int dep = fRand.nextU() % i; |
+ |
+ fGraph[i]->dependsOn(fGraph[dep]); |
+ } |
+ } |
+ } |
+ |
+ void onDraw(int loops, SkCanvas*) override { |
+ for (int i = 0; i < loops; ++i) { |
+ for (int j = 0; j < fGraph.count(); ++j) { |
+ fGraph[j]->reset(); |
+ } |
+ |
+ sk_tool_utils::TopoTestNode::Shuffle(&fGraph, &fRand); |
+ |
+ SkDEBUGCODE(bool actualResult =) SkTTopoSort<sk_tool_utils::TopoTestNode>(&fGraph); |
+ SkASSERT(actualResult); |
+ |
+#ifdef SK_DEBUG |
+ for (int j = 0; j < fGraph.count(); ++j) { |
+ SkASSERT(fGraph[j]->check()); |
+ } |
+#endif |
+ } |
+ } |
+ |
+private: |
+ static const int kNumElements = 1000; |
+ static const int kMaxEdges = 5; |
+ |
+ SkTDArray<sk_tool_utils::TopoTestNode*> fGraph; |
+ SkRandom fRand; |
+ |
+ typedef Benchmark INHERITED; |
+}; |
+ |
+/////////////////////////////////////////////////////////////////////////////// |
+ |
+DEF_BENCH( return new TopoSortBench(); ) |
+ |