xref: /aosp_15_r20/external/skia/bench/TopoSortBench.cpp (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
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