1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2015 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #include "bench/Benchmark.h" 9*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkString.h" 10*c8dee2aaSAndroid Build Coastguard Worker #include "src/base/SkRandom.h" 11*c8dee2aaSAndroid Build Coastguard Worker #include "src/gpu/ganesh/GrTTopoSort.h" 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker #include "tools/ToolUtils.h" 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker using namespace skia_private; 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker class TopoSortBench : public Benchmark { 18*c8dee2aaSAndroid Build Coastguard Worker public: TopoSortBench()19*c8dee2aaSAndroid Build Coastguard Worker TopoSortBench() { } 20*c8dee2aaSAndroid Build Coastguard Worker ~TopoSortBench()21*c8dee2aaSAndroid Build Coastguard Worker ~TopoSortBench() override { 22*c8dee2aaSAndroid Build Coastguard Worker } 23*c8dee2aaSAndroid Build Coastguard Worker isSuitableFor(Backend backend)24*c8dee2aaSAndroid Build Coastguard Worker bool isSuitableFor(Backend backend) override { 25*c8dee2aaSAndroid Build Coastguard Worker return Backend::kNonRendering == backend; 26*c8dee2aaSAndroid Build Coastguard Worker } 27*c8dee2aaSAndroid Build Coastguard Worker 28*c8dee2aaSAndroid Build Coastguard Worker protected: onGetName()29*c8dee2aaSAndroid Build Coastguard Worker const char* onGetName() override { 30*c8dee2aaSAndroid Build Coastguard Worker return "sort_topo_rand"; 31*c8dee2aaSAndroid Build Coastguard Worker } 32*c8dee2aaSAndroid Build Coastguard Worker 33*c8dee2aaSAndroid Build Coastguard Worker // Delayed initialization only done if onDraw will be called. onDelayedSetup()34*c8dee2aaSAndroid Build Coastguard Worker void onDelayedSetup() override { 35*c8dee2aaSAndroid Build Coastguard Worker ToolUtils::TopoTestNode::AllocNodes(&fGraph, kNumElements); 36*c8dee2aaSAndroid Build Coastguard Worker 37*c8dee2aaSAndroid Build Coastguard Worker for (int i = kNumElements-1; i > 0; --i) { 38*c8dee2aaSAndroid Build Coastguard Worker int numEdges = fRand.nextU() % (kMaxEdges+1); 39*c8dee2aaSAndroid Build Coastguard Worker 40*c8dee2aaSAndroid Build Coastguard Worker for (int j = 0; j < numEdges; ++j) { 41*c8dee2aaSAndroid Build Coastguard Worker int dep = fRand.nextU() % i; 42*c8dee2aaSAndroid Build Coastguard Worker 43*c8dee2aaSAndroid Build Coastguard Worker fGraph[i]->dependsOn(fGraph[dep].get()); 44*c8dee2aaSAndroid Build Coastguard Worker } 45*c8dee2aaSAndroid Build Coastguard Worker } 46*c8dee2aaSAndroid Build Coastguard Worker } 47*c8dee2aaSAndroid Build Coastguard Worker onDraw(int loops,SkCanvas *)48*c8dee2aaSAndroid Build Coastguard Worker void onDraw(int loops, SkCanvas*) override { 49*c8dee2aaSAndroid Build Coastguard Worker for (int i = 0; i < loops; ++i) { 50*c8dee2aaSAndroid Build Coastguard Worker for (int j = 0; j < fGraph.size(); ++j) { 51*c8dee2aaSAndroid Build Coastguard Worker fGraph[j]->reset(); 52*c8dee2aaSAndroid Build Coastguard Worker } 53*c8dee2aaSAndroid Build Coastguard Worker 54*c8dee2aaSAndroid Build Coastguard Worker ToolUtils::TopoTestNode::Shuffle(fGraph, &fRand); 55*c8dee2aaSAndroid Build Coastguard Worker 56*c8dee2aaSAndroid Build Coastguard Worker SkDEBUGCODE(bool actualResult =) GrTTopoSort<ToolUtils::TopoTestNode>(fGraph); 57*c8dee2aaSAndroid Build Coastguard Worker SkASSERT(actualResult); 58*c8dee2aaSAndroid Build Coastguard Worker 59*c8dee2aaSAndroid Build Coastguard Worker #ifdef SK_DEBUG 60*c8dee2aaSAndroid Build Coastguard Worker for (int j = 0; j < fGraph.size(); ++j) { 61*c8dee2aaSAndroid Build Coastguard Worker SkASSERT(fGraph[j]->check()); 62*c8dee2aaSAndroid Build Coastguard Worker } 63*c8dee2aaSAndroid Build Coastguard Worker #endif 64*c8dee2aaSAndroid Build Coastguard Worker } 65*c8dee2aaSAndroid Build Coastguard Worker } 66*c8dee2aaSAndroid Build Coastguard Worker 67*c8dee2aaSAndroid Build Coastguard Worker private: 68*c8dee2aaSAndroid Build Coastguard Worker static const int kNumElements = 1000; 69*c8dee2aaSAndroid Build Coastguard Worker static const int kMaxEdges = 5; 70*c8dee2aaSAndroid Build Coastguard Worker 71*c8dee2aaSAndroid Build Coastguard Worker TArray<sk_sp<ToolUtils::TopoTestNode>> fGraph; 72*c8dee2aaSAndroid Build Coastguard Worker SkRandom fRand; 73*c8dee2aaSAndroid Build Coastguard Worker 74*c8dee2aaSAndroid Build Coastguard Worker using INHERITED = Benchmark; 75*c8dee2aaSAndroid Build Coastguard Worker }; 76*c8dee2aaSAndroid Build Coastguard Worker 77*c8dee2aaSAndroid Build Coastguard Worker /////////////////////////////////////////////////////////////////////////////// 78*c8dee2aaSAndroid Build Coastguard Worker 79*c8dee2aaSAndroid Build Coastguard Worker DEF_BENCH( return new TopoSortBench(); ) 80