Path: blob/master/thirdparty/embree/kernels/common/stat.cpp
9905 views
// Copyright 2009-2021 Intel Corporation1// SPDX-License-Identifier: Apache-2.023#include "stat.h"45namespace embree6{7Stat Stat::instance;89Stat::Stat () {10}1112Stat::~Stat ()13{14#ifdef EMBREE_STAT_COUNTERS15Stat::print(std::cout);16#endif17}1819void Stat::print(embree_ostream cout)20{21Counters& cntrs = instance.cntrs;22Counters::Data& data = instance.cntrs.code;23//Counters::Data& data = instance.cntrs.active;2425/* print absolute numbers */26cout << "--------- ABSOLUTE ---------" << std::endl;27cout << " #normal_travs = " << float(data.normal.travs )*1E-6 << "M" << std::endl;28cout << " #nodes = " << float(data.normal.trav_nodes )*1E-6 << "M" << std::endl;29cout << " #nodes_xfm = " << float(data.normal.trav_xfm_nodes )*1E-6 << "M" << std::endl;30cout << " #leaves = " << float(data.normal.trav_leaves )*1E-6 << "M" << std::endl;31cout << " #prims = " << float(data.normal.trav_prims )*1E-6 << "M" << std::endl;32cout << " #prim_hits = " << float(data.normal.trav_prim_hits )*1E-6 << "M" << std::endl;3334cout << " #stack nodes = " << float(data.normal.trav_stack_nodes )*1E-6 << "M" << std::endl;35cout << " #stack pop = " << float(data.normal.trav_stack_pop )*1E-6 << "M" << std::endl;3637size_t normal_box_hits = 0;38size_t weighted_box_hits = 0;39for (size_t i=0;i<SIZE_HISTOGRAM;i++) {40normal_box_hits += data.normal.trav_hit_boxes[i];41weighted_box_hits += data.normal.trav_hit_boxes[i]*i;42}43cout << " #hit_boxes = " << normal_box_hits << " (total) distribution: ";44float average = 0.0f;45for (size_t i=0;i<SIZE_HISTOGRAM;i++)46{47float value = 100.0f * data.normal.trav_hit_boxes[i] / normal_box_hits;48cout << "[" << i << "] " << value << " ";49average += (float)i*data.normal.trav_hit_boxes[i] / normal_box_hits;50}51cout << " average = " << average << std::endl;52for (size_t i=0;i<SIZE_HISTOGRAM;i++) cout << "[" << i << "] " << 100.0f * data.normal.trav_hit_boxes[i]*i / weighted_box_hits << " ";53cout << std::endl;5455if (data.shadow.travs) {56cout << " #shadow_travs = " << float(data.shadow.travs )*1E-6 << "M" << std::endl;57cout << " #nodes = " << float(data.shadow.trav_nodes )*1E-6 << "M" << std::endl;58cout << " #nodes_xfm = " << float(data.shadow.trav_xfm_nodes)*1E-6 << "M" << std::endl;59cout << " #leaves = " << float(data.shadow.trav_leaves )*1E-6 << "M" << std::endl;60cout << " #prims = " << float(data.shadow.trav_prims )*1E-6 << "M" << std::endl;61cout << " #prim_hits = " << float(data.shadow.trav_prim_hits)*1E-6 << "M" << std::endl;6263cout << " #stack nodes = " << float(data.shadow.trav_stack_nodes )*1E-6 << "M" << std::endl;64cout << " #stack pop = " << float(data.shadow.trav_stack_pop )*1E-6 << "M" << std::endl;6566size_t shadow_box_hits = 0;67size_t weighted_shadow_box_hits = 0;6869for (size_t i=0;i<SIZE_HISTOGRAM;i++) {70shadow_box_hits += data.shadow.trav_hit_boxes[i];71weighted_shadow_box_hits += data.shadow.trav_hit_boxes[i]*i;72}73cout << " #hit_boxes = ";74for (size_t i=0;i<SIZE_HISTOGRAM;i++) cout << "[" << i << "] " << 100.0f * data.shadow.trav_hit_boxes[i] / shadow_box_hits << " ";75cout << std::endl;76for (size_t i=0;i<SIZE_HISTOGRAM;i++) cout << "[" << i << "] " << 100.0f * data.shadow.trav_hit_boxes[i]*i / weighted_shadow_box_hits << " ";77cout << std::endl;78}79cout << std::endl;8081/* print per traversal numbers */82cout << "--------- PER TRAVERSAL ---------" << std::endl;83float active_normal_travs = float(cntrs.active.normal.travs )/float(cntrs.all.normal.travs );84float active_normal_trav_nodes = float(cntrs.active.normal.trav_nodes )/float(cntrs.all.normal.trav_nodes );85float active_normal_trav_xfm_nodes = float(cntrs.active.normal.trav_xfm_nodes )/float(cntrs.all.normal.trav_xfm_nodes );86float active_normal_trav_leaves = float(cntrs.active.normal.trav_leaves)/float(cntrs.all.normal.trav_leaves);87float active_normal_trav_prims = float(cntrs.active.normal.trav_prims )/float(cntrs.all.normal.trav_prims );88float active_normal_trav_prim_hits = float(cntrs.active.normal.trav_prim_hits )/float(cntrs.all.normal.trav_prim_hits );89float active_normal_trav_stack_pop = float(cntrs.active.normal.trav_stack_pop )/float(cntrs.all.normal.trav_stack_pop );9091cout << " #normal_travs = " << float(cntrs.code.normal.travs )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_travs << "% active" << std::endl;92cout << " #nodes = " << float(cntrs.code.normal.trav_nodes )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_nodes << "% active" << std::endl;93cout << " #node_xfm = " << float(cntrs.code.normal.trav_xfm_nodes )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_xfm_nodes << "% active" << std::endl;94cout << " #leaves = " << float(cntrs.code.normal.trav_leaves)/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_leaves << "% active" << std::endl;95cout << " #prims = " << float(cntrs.code.normal.trav_prims )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_prims << "% active" << std::endl;96cout << " #prim_hits = " << float(cntrs.code.normal.trav_prim_hits )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_prim_hits << "% active" << std::endl;97cout << " #stack_pop = " << float(cntrs.code.normal.trav_stack_pop )/float(cntrs.code.normal.travs) << ", " << 100.0f*active_normal_trav_stack_pop << "% active" << std::endl;9899if (cntrs.all.shadow.travs) {100float active_shadow_travs = float(cntrs.active.shadow.travs )/float(cntrs.all.shadow.travs );101float active_shadow_trav_nodes = float(cntrs.active.shadow.trav_nodes )/float(cntrs.all.shadow.trav_nodes );102float active_shadow_trav_xfm_nodes = float(cntrs.active.shadow.trav_xfm_nodes )/float(cntrs.all.shadow.trav_xfm_nodes );103float active_shadow_trav_leaves = float(cntrs.active.shadow.trav_leaves)/float(cntrs.all.shadow.trav_leaves);104float active_shadow_trav_prims = float(cntrs.active.shadow.trav_prims )/float(cntrs.all.shadow.trav_prims );105float active_shadow_trav_prim_hits = float(cntrs.active.shadow.trav_prim_hits )/float(cntrs.all.shadow.trav_prim_hits );106107cout << " #shadow_travs = " << float(cntrs.code.shadow.travs )/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_travs << "% active" << std::endl;108cout << " #nodes = " << float(cntrs.code.shadow.trav_nodes )/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_trav_nodes << "% active" << std::endl;109cout << " #nodes_xfm = " << float(cntrs.code.shadow.trav_xfm_nodes )/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_trav_xfm_nodes << "% active" << std::endl;110cout << " #leaves = " << float(cntrs.code.shadow.trav_leaves)/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_trav_leaves << "% active" << std::endl;111cout << " #prims = " << float(cntrs.code.shadow.trav_prims )/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_trav_prims << "% active" << std::endl;112cout << " #prim_hits = " << float(cntrs.code.shadow.trav_prim_hits )/float(cntrs.code.shadow.travs) << ", " << 100.0f*active_shadow_trav_prim_hits << "% active" << std::endl;113114}115cout << std::endl;116117/* print user counters for performance tuning */118cout << "--------- USER ---------" << std::endl;119for (size_t i=0; i<10; i++)120cout << "#user" << i << " = " << float(cntrs.user[i])/float(cntrs.all.normal.travs+cntrs.all.shadow.travs) << " per traversal" << std::endl;121122cout << "#user5/user3 " << 100.0f*float(cntrs.user[5])/float(cntrs.user[3]) << "%" << std::endl;123cout << "#user6/user3 " << 100.0f*float(cntrs.user[6])/float(cntrs.user[3]) << "%" << std::endl;124cout << "#user7/user3 " << 100.0f*float(cntrs.user[7])/float(cntrs.user[3]) << "%" << std::endl;125cout << std::endl;126}127}128129130