From 35b0c1d3910595875de67a34f6b993047470fd55 Mon Sep 17 00:00:00 2001 From: Nathan Binkert Date: Thu, 12 May 2011 11:19:32 -0700 Subject: [PATCH] stats: better expose statistics to python. Build a python list and dict of all stats and expose flags properly. --HG-- rename : src/python/m5/stats.py => src/python/m5/stats/__init__.py --- src/python/SConscript | 2 +- src/python/m5/{stats.py => stats/__init__.py} | 52 +++++++++++++++++-- src/python/swig/stats.i | 48 +++++++++++++++++ 3 files changed, 97 insertions(+), 5 deletions(-) rename src/python/m5/{stats.py => stats/__init__.py} (63%) diff --git a/src/python/SConscript b/src/python/SConscript index 3c410b531..cbb37d0c5 100644 --- a/src/python/SConscript +++ b/src/python/SConscript @@ -46,10 +46,10 @@ PySource('m5', 'm5/options.py') PySource('m5', 'm5/params.py') PySource('m5', 'm5/proxy.py') PySource('m5', 'm5/simulate.py') -PySource('m5', 'm5/stats.py') PySource('m5', 'm5/ticks.py') PySource('m5', 'm5/trace.py') PySource('m5.objects', 'm5/objects/__init__.py') +PySource('m5.stats', 'm5/stats/__init__.py') PySource('m5.util', 'm5/util/__init__.py') PySource('m5.util', 'm5/util/attrdict.py') PySource('m5.util', 'm5/util/code_formatter.py') diff --git a/src/python/m5/stats.py b/src/python/m5/stats/__init__.py similarity index 63% rename from src/python/m5/stats.py rename to src/python/m5/stats/__init__.py index 24072aeb0..612dbdfb5 100644 --- a/src/python/m5/stats.py +++ b/src/python/m5/stats/__init__.py @@ -1,4 +1,5 @@ # Copyright (c) 2007 The Regents of The University of Michigan +# Copyright (c) 2010 The Hewlett-Packard Development Company # All rights reserved. # # Redistribution and use in source and binary forms, with or without @@ -26,10 +27,10 @@ # # Authors: Nathan Binkert -import internal - -from internal.stats import schedStatEvent as schedEvent -from objects import Root +from m5 import internal +from m5.internal.stats import schedStatEvent as schedEvent +from m5.objects import Root +from m5.util import attrdict def initText(filename, desc=True): internal.stats.initText(filename, desc) @@ -46,7 +47,38 @@ def initMySQL(host, database, user='', passwd='', project='test', name='test', def initSimStats(): internal.stats.initSimStats() +names = [] +stats_dict = {} +stats_list = [] +raw_stats_list = [] def enable(): + '''Enable the statistics package. Before the statistics package is + enabled, all statistics must be created and initialized and once + the package is enabled, no more statistics can be created.''' + __dynamic_cast = [] + for k, v in internal.stats.__dict__.iteritems(): + if k.startswith('dynamic_'): + __dynamic_cast.append(v) + + for stat in internal.stats.statsList(): + for cast in __dynamic_cast: + val = cast(stat) + if val is not None: + stats_list.append(val) + raw_stats_list.append(val) + break + else: + fatal("unknown stat type %s", stat) + + def less(stat1, stat2): + v1 = stat1.name.split('.') + v2 = stat2.name.split('.') + return v1 < v2 + + stats_list.sort(less) + for stat in stats_list: + stats_dict[stat.name] = stat + internal.stats.enable() def dump(): @@ -64,3 +96,15 @@ def reset(): # call any other registered stats reset callbacks internal.stats.reset() + +flags = attrdict({ + 'none' : 0x0000, + 'init' : 0x0001, + 'display' : 0x0002, + 'total' : 0x0010, + 'pdf' : 0x0020, + 'cdf' : 0x0040, + 'dist' : 0x0080, + 'nozero' : 0x0100, + 'nonan' : 0x0200, +}) diff --git a/src/python/swig/stats.i b/src/python/swig/stats.i index 72172ae94..63539ca83 100644 --- a/src/python/swig/stats.i +++ b/src/python/swig/stats.i @@ -32,20 +32,68 @@ %include %include +%include +%include %{ #include "base/stats/mysql.hh" #include "base/stats/text.hh" +#include "base/stats/types.hh" #include "base/statistics.hh" #include "sim/core.hh" #include "sim/stat_control.hh" + +namespace Stats { +template +inline T +cast_info(Info *info) +{ + return dynamic_cast(info); +} + +inline FlagsType +Stats_Info_flags_get(Info *info) +{ + return info->flags; +} + +inline void +Stats_Info_flags_set(Info *info, FlagsType flags) +{ + info->flags = flags; +} + +} // namespace Stats %} +%extend Stats::Info { + short flags; +} + +%ignore Stats::Info::flags; + %import "base/stats/types.hh" %include "base/stats/info.hh" +namespace std { +%template(list_info) list; +%template(vector_double) vector; +%template(vector_string) vector; +%template(vector_DistData) vector; +} + namespace Stats { + +template T cast_info(Info *info); + +%template(dynamic_ScalarInfo) cast_info; +%template(dynamic_VectorInfo) cast_info; +%template(dynamic_DistInfo) cast_info; +%template(dynamic_VectorDistInfo) cast_info; +%template(dynamic_Vector2dInfo) cast_info; +%template(dynamic_FormulaInfo) cast_info; + void initSimStats(); void initText(const std::string &filename, bool desc); void initMySQL(std::string host, std::string database, std::string user, -- 2.30.2