aboutsummaryrefslogtreecommitdiffhomepage
path: root/bench/ImageFilterDAGBench.cpp
diff options
context:
space:
mode:
authorGravatar senorblanco@chromium.org <senorblanco@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2014-04-10 16:16:13 +0000
committerGravatar senorblanco@chromium.org <senorblanco@chromium.org@2bbb7eff-a529-9590-31e7-b0007b416f81>2014-04-10 16:16:13 +0000
commit0d64356efd8a3ca40d39729f62e0fa9a5bc3a365 (patch)
tree91f62631bb0b2d746d354cdc4e5fd8c65ea0676c /bench/ImageFilterDAGBench.cpp
parent7f43493ae68e9d14e8a4134f2e394c9c995fb8ef (diff)
Add a new bench that tests a simple image filter DAG.
This bench exercises a blur filter connected to 5 inputs of the same merge filter. R=junov@chromium.org Review URL: https://codereview.chromium.org/233383002 git-svn-id: http://skia.googlecode.com/svn/trunk@14135 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'bench/ImageFilterDAGBench.cpp')
-rw-r--r--bench/ImageFilterDAGBench.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/bench/ImageFilterDAGBench.cpp b/bench/ImageFilterDAGBench.cpp
new file mode 100644
index 0000000000..e6a3169507
--- /dev/null
+++ b/bench/ImageFilterDAGBench.cpp
@@ -0,0 +1,46 @@
+/*
+ * Copyright 2014 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "SkBenchmark.h"
+#include "SkBlurImageFilter.h"
+#include "SkMergeImageFilter.h"
+#include "SkCanvas.h"
+
+enum { kNumInputs = 5 };
+
+// Exercise a blur filter connected to 5 inputs of the same merge filter.
+// This bench shows an improvement in performance once cacheing of re-used
+// nodes is implemented, since the DAG is no longer flattened to a tree.
+
+class ImageFilterDAGBench : public SkBenchmark {
+public:
+ ImageFilterDAGBench() {
+ }
+
+protected:
+ virtual const char* onGetName() SK_OVERRIDE {
+ return "image_filter_dag";
+ }
+
+ virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
+ SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(20.0f, 20.0f));
+ SkImageFilter* inputs[kNumInputs];
+ for (int i = 0; i < kNumInputs; ++i) {
+ inputs[i] = blur.get();
+ }
+ SkAutoTUnref<SkImageFilter> merge(SkMergeImageFilter::Create(inputs, kNumInputs));
+ SkPaint paint;
+ paint.setImageFilter(merge);
+ SkRect rect = SkRect::Make(SkIRect::MakeWH(400, 400));
+ canvas->drawRect(rect, paint);
+ }
+
+private:
+ typedef SkBenchmark INHERITED;
+};
+
+DEF_BENCH(return new ImageFilterDAGBench;)