1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2013 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 * Classes for writing out bench results in various formats. 8*c8dee2aaSAndroid Build Coastguard Worker */ 9*c8dee2aaSAndroid Build Coastguard Worker 10*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkResultsWriter_DEFINED 11*c8dee2aaSAndroid Build Coastguard Worker #define SkResultsWriter_DEFINED 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkString.h" 14*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkTypes.h" 15*c8dee2aaSAndroid Build Coastguard Worker #include "src/utils/SkJSONWriter.h" 16*c8dee2aaSAndroid Build Coastguard Worker #include <cmath> 17*c8dee2aaSAndroid Build Coastguard Worker 18*c8dee2aaSAndroid Build Coastguard Worker /** 19*c8dee2aaSAndroid Build Coastguard Worker NanoJSONResultsWriter helps nanobench writes the test results out in the following format: 20*c8dee2aaSAndroid Build Coastguard Worker 21*c8dee2aaSAndroid Build Coastguard Worker { 22*c8dee2aaSAndroid Build Coastguard Worker "key": { 23*c8dee2aaSAndroid Build Coastguard Worker "arch": "Arm7", 24*c8dee2aaSAndroid Build Coastguard Worker "gpu": "SGX540", 25*c8dee2aaSAndroid Build Coastguard Worker "os": "Android", 26*c8dee2aaSAndroid Build Coastguard Worker "model": "GalaxyNexus", 27*c8dee2aaSAndroid Build Coastguard Worker } 28*c8dee2aaSAndroid Build Coastguard Worker "gitHash": "d1830323662ae8ae06908b97f15180fd25808894", 29*c8dee2aaSAndroid Build Coastguard Worker "build_number": "1234", 30*c8dee2aaSAndroid Build Coastguard Worker "results" : { 31*c8dee2aaSAndroid Build Coastguard Worker "Xfermode_Luminosity_640_480" : { 32*c8dee2aaSAndroid Build Coastguard Worker "8888" : { 33*c8dee2aaSAndroid Build Coastguard Worker "median_ms" : 143.188128906250, 34*c8dee2aaSAndroid Build Coastguard Worker "min_ms" : 143.835957031250, 35*c8dee2aaSAndroid Build Coastguard Worker ... 36*c8dee2aaSAndroid Build Coastguard Worker }, 37*c8dee2aaSAndroid Build Coastguard Worker ... 38*c8dee2aaSAndroid Build Coastguard Worker */ 39*c8dee2aaSAndroid Build Coastguard Worker class NanoJSONResultsWriter : public SkJSONWriter { 40*c8dee2aaSAndroid Build Coastguard Worker public: NanoJSONResultsWriter(SkWStream * stream,Mode mode)41*c8dee2aaSAndroid Build Coastguard Worker NanoJSONResultsWriter(SkWStream* stream, Mode mode) : SkJSONWriter(stream, mode) {} 42*c8dee2aaSAndroid Build Coastguard Worker beginBench(const char * name,int32_t x,int32_t y)43*c8dee2aaSAndroid Build Coastguard Worker void beginBench(const char* name, int32_t x, int32_t y) { 44*c8dee2aaSAndroid Build Coastguard Worker SkString id = SkStringPrintf("%s_%d_%d", name, x, y); 45*c8dee2aaSAndroid Build Coastguard Worker this->beginObject(id.c_str()); 46*c8dee2aaSAndroid Build Coastguard Worker } 47*c8dee2aaSAndroid Build Coastguard Worker endBench()48*c8dee2aaSAndroid Build Coastguard Worker void endBench() { this->endObject(); } 49*c8dee2aaSAndroid Build Coastguard Worker appendMetric(const char * name,double value)50*c8dee2aaSAndroid Build Coastguard Worker void appendMetric(const char* name, double value) { 51*c8dee2aaSAndroid Build Coastguard Worker // Don't record if NaN or Inf. 52*c8dee2aaSAndroid Build Coastguard Worker if (std::isfinite(value)) { 53*c8dee2aaSAndroid Build Coastguard Worker this->appendDoubleDigits(name, value, 16); 54*c8dee2aaSAndroid Build Coastguard Worker } 55*c8dee2aaSAndroid Build Coastguard Worker } 56*c8dee2aaSAndroid Build Coastguard Worker }; 57*c8dee2aaSAndroid Build Coastguard Worker 58*c8dee2aaSAndroid Build Coastguard Worker #endif 59