Commit 2fa3e1a8 authored by Robert Kimball's avatar Robert Kimball Committed by Adam Procter

remove static vector when finding known nodes (#789)

parent 324efb18
...@@ -30,32 +30,25 @@ ...@@ -30,32 +30,25 @@
using namespace std; using namespace std;
using namespace ngraph; using namespace ngraph;
shared_ptr<Node> find_node(const string& name, shared_ptr<Function> func) multimap<size_t, string>
aggregate_timing_details(const vector<runtime::PerformanceCounter>& perf_data,
shared_ptr<Function> func)
{ {
static unordered_map<string, shared_ptr<Node>> node_map; unordered_map<string, shared_ptr<Node>> node_map;
if (node_map.empty()) vector<shared_ptr<Function>> fs;
traverse_functions(func, [&](shared_ptr<Function> f) { fs.push_back(f); });
for (shared_ptr<Function> f : fs)
{ {
vector<shared_ptr<Function>> fs; for (shared_ptr<Node> node : f->get_ops())
traverse_functions(func, [&](shared_ptr<Function> f) { fs.push_back(f); });
for (shared_ptr<Function> f : fs)
{ {
for (shared_ptr<Node> node : f->get_ops()) node_map.insert({node->get_name(), node});
{
node_map.insert({node->get_name(), node});
}
} }
} }
return node_map[name];
}
multimap<size_t, string>
aggregate_timing_details(const vector<runtime::PerformanceCounter>& perf_data,
shared_ptr<Function> f)
{
unordered_map<string, size_t> timing; unordered_map<string, size_t> timing;
for (const runtime::PerformanceCounter& p : perf_data) for (const runtime::PerformanceCounter& p : perf_data)
{ {
shared_ptr<Node> node = find_node(p.name(), f); shared_ptr<Node> node = node_map.at(p.name());
string op = p.name().substr(0, p.name().find('_')); string op = p.name().substr(0, p.name().find('_'));
string shape_name = "{" + join(node->get_outputs()[0].get_shape()) + "}"; string shape_name = "{" + join(node->get_outputs()[0].get_shape()) + "}";
timing[op + shape_name] += p.microseconds(); timing[op + shape_name] += p.microseconds();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment