Unverified Commit f6eec91f authored by Yixing Lao's avatar Yixing Lao Committed by GitHub

Clean up is_constant is_input is_output in Tensor (#943)

* remove in tensor.hpp and cpp

* remove in constructors

* more clean up at tv_wrapper and set_is_output()

* fix liveness

* fix liveness.cpp

* finally fixed liveness

* fix PrimaryTensorView constructor in node.cpp

* fix PrimaryTensorView constructor in cpu_tensor_view

* clang-format

* update tensor print

* clean comments

* rename
parent b88fa59d
...@@ -50,8 +50,6 @@ namespace ngraph ...@@ -50,8 +50,6 @@ namespace ngraph
const std::set<Input*>& get_inputs() const { return m_inputs; } const std::set<Input*>& get_inputs() const { return m_inputs; }
Tensor& get_tensor() const; Tensor& get_tensor() const;
void set_is_output() { get_tensor().set_is_output(); }
bool is_output() { return get_tensor().is_output(); }
protected: protected:
/// @return the tensor view type for the output /// @return the tensor view type for the output
std::shared_ptr<const TensorViewType> get_tensor_view_type() const; std::shared_ptr<const TensorViewType> get_tensor_view_type() const;
......
...@@ -20,12 +20,9 @@ using namespace ngraph; ...@@ -20,12 +20,9 @@ using namespace ngraph;
using namespace descriptor; using namespace descriptor;
PrimaryTensorView::PrimaryTensorView(const std::shared_ptr<const TensorViewType>& tensor_view_type, PrimaryTensorView::PrimaryTensorView(const std::shared_ptr<const TensorViewType>& tensor_view_type,
const std::string& name, const std::string& name)
bool is_output,
bool is_input,
bool is_constant)
: TensorView(tensor_view_type) : TensorView(tensor_view_type)
, m_tensor(tensor_view_type->get_element_type(), this, name, is_output, is_input, is_constant) , m_tensor(tensor_view_type->get_element_type(), this, name)
{ {
// Set the name in the parent TensorView. // Set the name in the parent TensorView.
// This can't be done until after the m_tensor is constructed. // This can't be done until after the m_tensor is constructed.
......
...@@ -34,13 +34,8 @@ namespace ngraph ...@@ -34,13 +34,8 @@ namespace ngraph
public: public:
/// @param tensor_view_type The type for this view. /// @param tensor_view_type The type for this view.
/// @param name Description of the tensor, for debugging. /// @param name Description of the tensor, for debugging.
/// @param is_output The view can be read from the host at the end of a computation.
/// @param is_input The view can be written from the host at the beginning of a computation.
PrimaryTensorView(const std::shared_ptr<const TensorViewType>& tensor_view_type, PrimaryTensorView(const std::shared_ptr<const TensorViewType>& tensor_view_type,
const std::string& name, const std::string& name);
bool is_output,
bool is_input,
bool is_constant);
virtual const Tensor& get_tensor() const override; virtual const Tensor& get_tensor() const override;
virtual Tensor& get_tensor() override; virtual Tensor& get_tensor() override;
......
...@@ -23,16 +23,9 @@ using namespace std; ...@@ -23,16 +23,9 @@ using namespace std;
descriptor::Tensor::Tensor(const element::Type& element_type, descriptor::Tensor::Tensor(const element::Type& element_type,
PrimaryTensorView* primary_tensor_view, PrimaryTensorView* primary_tensor_view,
const string& name, const string& name)
bool is_output,
bool is_input,
bool is_constant)
: m_element_type(element_type) : m_element_type(element_type)
, m_primary_tensor_view(primary_tensor_view) , m_primary_tensor_view(primary_tensor_view)
, m_is_output{is_output}
, m_is_input{is_input}
, m_is_persistent{false}
, m_is_constant{is_constant}
, m_name{name} , m_name{name}
, m_next_view_id{0} , m_next_view_id{0}
{ {
...@@ -71,18 +64,6 @@ size_t descriptor::Tensor::get_pool_offset() const ...@@ -71,18 +64,6 @@ size_t descriptor::Tensor::get_pool_offset() const
ostream& operator<<(ostream& out, const descriptor::Tensor& tensor) ostream& operator<<(ostream& out, const descriptor::Tensor& tensor)
{ {
out << "Tensor(" << tensor.get_name() << ", "; out << "Tensor(" << tensor.get_name() << ")";
out << (tensor.is_persistent() ? "P" : "");
out << (tensor.is_constant() ? "C" : "");
out << (tensor.is_input() ? "I" : "");
out << (tensor.is_output() ? "O" : "");
if (!tensor.is_persistent() && !tensor.is_constant() && !tensor.is_input() &&
!tensor.is_output())
{
out << "T";
}
out << ")";
return out; return out;
} }
...@@ -48,32 +48,21 @@ private: ...@@ -48,32 +48,21 @@ private:
Tensor(const element::Type& element_type, Tensor(const element::Type& element_type,
PrimaryTensorView* tensor_view, PrimaryTensorView* tensor_view,
const std::string& name, const std::string& name);
bool is_output,
bool is_input,
bool is_constant);
std::string get_next_view_name(); std::string get_next_view_name();
public: public:
bool is_output() const { return m_is_output; }
bool is_input() const { return m_is_input; }
bool is_persistent() const { return m_is_persistent; }
bool is_constant() const { return m_is_constant; }
const std::string& get_name() const { return m_name; } const std::string& get_name() const { return m_name; }
size_t size() const; size_t size() const;
void set_pool_offset(size_t); void set_pool_offset(size_t);
size_t get_pool_offset() const; size_t get_pool_offset() const;
const element::Type& get_element_type() const { return m_element_type; } const element::Type& get_element_type() const { return m_element_type; }
static std::string make_tensor_name(const Node* node, size_t value_index); static std::string make_tensor_name(const Node* node, size_t value_index);
void set_is_output() { m_is_output = true; }
protected: protected:
const element::Type m_element_type; const element::Type m_element_type;
PrimaryTensorView* m_primary_tensor_view; PrimaryTensorView* m_primary_tensor_view;
bool m_is_output;
bool m_is_input;
bool m_is_persistent;
bool m_is_constant;
std::string m_name; std::string m_name;
size_t m_next_view_id; size_t m_next_view_id;
size_t m_size; size_t m_size;
......
...@@ -74,14 +74,6 @@ Function::Function(const std::shared_ptr<Node>& result, ...@@ -74,14 +74,6 @@ Function::Function(const std::shared_ptr<Node>& result,
void Function::init() void Function::init()
{ {
for (auto r : m_results)
{
for (descriptor::Output& output : r->get_outputs())
{
output.get_tensor().set_is_output();
}
}
traverse_nodes(this, [&](shared_ptr<Node> node) { traverse_nodes(this, [&](shared_ptr<Node> node) {
std::shared_ptr<op::Parameter> p = std::dynamic_pointer_cast<op::Parameter>(node); std::shared_ptr<op::Parameter> p = std::dynamic_pointer_cast<op::Parameter>(node);
if (nullptr != p) if (nullptr != p)
......
...@@ -68,11 +68,7 @@ void Node::add_output(const element::Type& element_type, const Shape& shape) ...@@ -68,11 +68,7 @@ void Node::add_output(const element::Type& element_type, const Shape& shape)
shared_ptr<TensorViewType> tensor_view_type = make_shared<TensorViewType>(element_type, shape); shared_ptr<TensorViewType> tensor_view_type = make_shared<TensorViewType>(element_type, shape);
size_t i = m_outputs.size(); size_t i = m_outputs.size();
auto tensor_view_descriptor = make_shared<descriptor::PrimaryTensorView>( auto tensor_view_descriptor = make_shared<descriptor::PrimaryTensorView>(
tensor_view_type, tensor_view_type, ngraph::descriptor::Tensor::make_tensor_name(this, i));
ngraph::descriptor::Tensor::make_tensor_name(this, i),
false,
is_parameter(),
is_constant());
m_outputs.emplace_back(this, i, tensor_view_descriptor); m_outputs.emplace_back(this, i, tensor_view_descriptor);
} }
......
...@@ -20,19 +20,55 @@ ...@@ -20,19 +20,55 @@
#include "ngraph/descriptor/input.hpp" #include "ngraph/descriptor/input.hpp"
#include "ngraph/descriptor/output.hpp" #include "ngraph/descriptor/output.hpp"
#include "ngraph/function.hpp"
#include "ngraph/graph_util.hpp" #include "ngraph/graph_util.hpp"
#include "ngraph/log.hpp" #include "ngraph/log.hpp"
#include "ngraph/node.hpp" #include "ngraph/node.hpp"
#include "ngraph/op/constant.hpp"
#include "ngraph/op/parameter.hpp"
#include "ngraph/op/result.hpp"
#include "ngraph/pass/liveness.hpp" #include "ngraph/pass/liveness.hpp"
#include "ngraph/util.hpp" #include "ngraph/util.hpp"
using namespace std; using namespace std;
using namespace ngraph; using namespace ngraph;
bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops) bool pass::Liveness::run_on_function(shared_ptr<ngraph::Function> function)
{ {
unordered_set<descriptor::Tensor*> currently_live; list<shared_ptr<Node>> ops = function->get_ordered_ops();
unordered_set<descriptor::Tensor*> persistent_tensors;
unordered_set<descriptor::Tensor*> output_tensors;
for (shared_ptr<op::Parameter> node : function->get_parameters())
{
for (size_t i = 0; i < node->get_output_size(); ++i)
{
descriptor::Tensor& tensor = node->get_output_tensor(i);
persistent_tensors.insert(&tensor);
}
}
for (shared_ptr<op::Result> node : function->get_results())
{
for (size_t i = 0; i < node->get_output_size(); ++i)
{
descriptor::Tensor& tensor = node->get_output_tensor(i);
persistent_tensors.insert(&tensor);
output_tensors.insert(&tensor);
}
}
for (shared_ptr<Node> node : function->get_ordered_ops())
{
if (auto constant_node = dynamic_pointer_cast<op::Constant>(node))
{
for (size_t i = 0; i < constant_node->get_output_size(); ++i)
{
descriptor::Tensor& tensor = constant_node->get_output_tensor(i);
persistent_tensors.insert(&tensor);
}
}
}
unordered_set<descriptor::Tensor*> currently_live;
for (auto it = ops.rbegin(); it != ops.rend(); it++) for (auto it = ops.rbegin(); it != ops.rend(); it++)
{ {
shared_ptr<Node> node = *it; shared_ptr<Node> node = *it;
...@@ -43,7 +79,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops) ...@@ -43,7 +79,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops)
for (descriptor::Input& input_decl : node->get_inputs()) for (descriptor::Input& input_decl : node->get_inputs())
{ {
descriptor::Tensor& tensor = input_decl.get_tensor(); descriptor::Tensor& tensor = input_decl.get_tensor();
if (is_temporary(tensor)) if (!contains(persistent_tensors, &tensor))
{ {
input_tensor_decls.insert(&tensor); input_tensor_decls.insert(&tensor);
} }
...@@ -53,7 +89,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops) ...@@ -53,7 +89,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops)
for (size_t i = 0; i < node->get_output_size(); ++i) for (size_t i = 0; i < node->get_output_size(); ++i)
{ {
descriptor::Tensor& tensor = node->get_output_tensor(i); descriptor::Tensor& tensor = node->get_output_tensor(i);
if (is_temporary(tensor)) if (!contains(persistent_tensors, &tensor))
{ {
output_tensor_decls.insert(&tensor); output_tensor_decls.insert(&tensor);
} }
...@@ -96,7 +132,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops) ...@@ -96,7 +132,7 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops)
{ {
for (descriptor::Tensor* tensor : node->liveness_live_list) for (descriptor::Tensor* tensor : node->liveness_live_list)
{ {
if (tensor->is_output()) if (contains(output_tensors, tensor))
{ {
outputs.insert(tensor); outputs.insert(tensor);
} }
...@@ -124,13 +160,6 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops) ...@@ -124,13 +160,6 @@ bool pass::Liveness::run_on_call_graph(const list<shared_ptr<Node>>& ops)
return false; return false;
} }
bool pass::Liveness::is_temporary(const descriptor::Tensor& tensor)
{
return tensor.is_persistent() == false && tensor.is_input() == false &&
tensor.is_output() == false && tensor.is_constant() == false;
// && tensor.is_compile_only() == false;
}
void pass::Liveness::validate_liveness(const list<Node*>& ops) void pass::Liveness::validate_liveness(const list<Node*>& ops)
{ {
unordered_set<descriptor::Tensor*> dead_tensors; unordered_set<descriptor::Tensor*> dead_tensors;
......
...@@ -27,12 +27,11 @@ namespace ngraph ...@@ -27,12 +27,11 @@ namespace ngraph
} }
} }
class ngraph::pass::Liveness : public CallGraphPass class ngraph::pass::Liveness : public FunctionPass
{ {
public: public:
virtual bool run_on_call_graph(const std::list<std::shared_ptr<Node>>&) override; bool run_on_function(std::shared_ptr<ngraph::Function>) override;
private: private:
bool is_temporary(const descriptor::Tensor&);
void validate_liveness(const std::list<Node*>& ops); void validate_liveness(const std::list<Node*>& ops);
}; };
...@@ -39,10 +39,6 @@ ngraph::pass::Manager::Manager() ...@@ -39,10 +39,6 @@ ngraph::pass::Manager::Manager()
} }
} }
ngraph::pass::Manager::Manager(bool to_set_is_output)
{
}
ngraph::pass::Manager::~Manager() ngraph::pass::Manager::~Manager()
{ {
} }
......
...@@ -37,7 +37,6 @@ class ngraph::pass::Manager ...@@ -37,7 +37,6 @@ class ngraph::pass::Manager
{ {
public: public:
Manager(); Manager();
Manager(bool to_set_is_output);
~Manager(); ~Manager();
void initialize_default_passes(); void initialize_default_passes();
......
...@@ -69,12 +69,9 @@ bool pass::MemoryVisualize::run_on_module(vector<shared_ptr<ngraph::Function>>& ...@@ -69,12 +69,9 @@ bool pass::MemoryVisualize::run_on_module(vector<shared_ptr<ngraph::Function>>&
tensors.insert(node->liveness_live_list.begin(), node->liveness_live_list.end()); tensors.insert(node->liveness_live_list.begin(), node->liveness_live_list.end());
} }
for (descriptor::Tensor* tensor : tensors) for (descriptor::Tensor* tensor : tensors)
{
if (tensor->is_persistent() == false)
{ {
temp_max_size += tensor->size(); temp_max_size += tensor->size();
} }
}
// file << "<table>\n"; // file << "<table>\n";
// file << "<tr><td>Persistent Memory Footprint</td><td align=\"right\">"; // file << "<tr><td>Persistent Memory Footprint</td><td align=\"right\">";
...@@ -244,28 +241,14 @@ void pass::MemoryVisualize::draw_op_influence(ostream& file, const list<shared_p ...@@ -244,28 +241,14 @@ void pass::MemoryVisualize::draw_op_influence(ostream& file, const list<shared_p
int pass::MemoryVisualize::compute_op_weight(const shared_ptr<Node> exop) int pass::MemoryVisualize::compute_op_weight(const shared_ptr<Node> exop)
{ {
int mass = 0; int mass = 0;
// for input_decl in exop.input_decls:
// tensor = input_decl.source_output_decl.tensor
// if tensor.is_persistent is False:
// mass += tensor->size()
// for output_decl in exop.output_decls:
// tensor = output_decl.tensor
// if tensor.is_persistent is False:
// mass -= tensor->size()
for (const descriptor::Tensor* tensor : exop->liveness_new_list) for (const descriptor::Tensor* tensor : exop->liveness_new_list)
{
if (tensor->is_persistent() == false)
{ {
mass += tensor->size(); mass += tensor->size();
} }
}
for (const descriptor::Tensor* tensor : exop->liveness_free_list) for (const descriptor::Tensor* tensor : exop->liveness_free_list)
{
if (tensor->is_persistent() == false)
{ {
mass -= tensor->size(); mass -= tensor->size();
} }
}
return mass; return mass;
} }
......
...@@ -39,7 +39,7 @@ runtime::cpu::CPUTensorView::CPUTensorView(const ngraph::element::Type& element_ ...@@ -39,7 +39,7 @@ runtime::cpu::CPUTensorView::CPUTensorView(const ngraph::element::Type& element_
void* memory_pointer, void* memory_pointer,
const string& name) const string& name)
: runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>( : runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>(
std::make_shared<ngraph::TensorViewType>(element_type, shape), name, true, true, false)) std::make_shared<ngraph::TensorViewType>(element_type, shape), name))
, buffer(nullptr) , buffer(nullptr)
, aligned_buffer(nullptr) , aligned_buffer(nullptr)
{ {
......
...@@ -65,11 +65,6 @@ const std::string& runtime::cpu::TensorViewWrapper::get_type() const ...@@ -65,11 +65,6 @@ const std::string& runtime::cpu::TensorViewWrapper::get_type() const
return get_element_type().c_type_string(); return get_element_type().c_type_string();
} }
bool runtime::cpu::TensorViewWrapper::is_output() const
{
return m_tensor_view->get_tensor().is_output();
}
const std::shared_ptr<descriptor::TensorView> const std::shared_ptr<descriptor::TensorView>
runtime::cpu::TensorViewWrapper::get_tensor_view() const runtime::cpu::TensorViewWrapper::get_tensor_view() const
{ {
......
...@@ -44,7 +44,6 @@ public: ...@@ -44,7 +44,6 @@ public:
const element::Type& get_element_type() const; const element::Type& get_element_type() const;
const std::string& get_name() const; const std::string& get_name() const;
const std::string& get_type() const; const std::string& get_type() const;
bool is_output() const;
const std::shared_ptr<descriptor::TensorView> get_tensor_view() const; const std::shared_ptr<descriptor::TensorView> get_tensor_view() const;
private: private:
......
...@@ -30,11 +30,7 @@ runtime::gpu::GPU_TensorView::GPU_TensorView(const ngraph::element::Type& elemen ...@@ -30,11 +30,7 @@ runtime::gpu::GPU_TensorView::GPU_TensorView(const ngraph::element::Type& elemen
const Shape& shape, const Shape& shape,
void* memory_pointer) void* memory_pointer)
: runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>( : runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>(
std::make_shared<ngraph::TensorViewType>(element_type, shape), std::make_shared<ngraph::TensorViewType>(element_type, shape), "external"))
"external",
true,
true,
false))
, m_custom_memory(false) , m_custom_memory(false)
{ {
m_descriptor->set_tensor_view_layout( m_descriptor->set_tensor_view_layout(
......
...@@ -64,8 +64,3 @@ const std::string& runtime::gpu::GPU_TensorViewWrapper::get_type() const ...@@ -64,8 +64,3 @@ const std::string& runtime::gpu::GPU_TensorViewWrapper::get_type() const
{ {
return get_element_type().c_type_string(); return get_element_type().c_type_string();
} }
bool runtime::gpu::GPU_TensorViewWrapper::is_output() const
{
return m_tensor_view->get_tensor().is_output();
}
...@@ -44,7 +44,6 @@ public: ...@@ -44,7 +44,6 @@ public:
const element::Type& get_element_type() const; const element::Type& get_element_type() const;
const std::string& get_name() const; const std::string& get_name() const;
const std::string& get_type() const; const std::string& get_type() const;
bool is_output() const;
private: private:
std::shared_ptr<descriptor::TensorView> m_tensor_view; std::shared_ptr<descriptor::TensorView> m_tensor_view;
......
...@@ -29,7 +29,7 @@ runtime::HostTensorView::HostTensorView(const ngraph::element::Type& element_typ ...@@ -29,7 +29,7 @@ runtime::HostTensorView::HostTensorView(const ngraph::element::Type& element_typ
void* memory_pointer, void* memory_pointer,
const string& name) const string& name)
: runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>( : runtime::TensorView(std::make_shared<ngraph::descriptor::PrimaryTensorView>(
std::make_shared<ngraph::TensorViewType>(element_type, shape), name, true, true, false)) std::make_shared<ngraph::TensorViewType>(element_type, shape), name))
, m_allocated_buffer_pool(nullptr) , m_allocated_buffer_pool(nullptr)
, m_aligned_buffer_pool(nullptr) , m_aligned_buffer_pool(nullptr)
......
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