Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
N
ngraph
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
ngraph
Commits
36cc0317
Commit
36cc0317
authored
Sep 14, 2017
by
Scott Cyphers
Committed by
GitHub
Sep 14, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #110 from NervanaSystems/bob/iodecl
Change Input/Output to instances in node rather than shared_ptr
parents
13c281ae
931d92f5
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
62 additions
and
51 deletions
+62
-51
input.cpp
src/ngraph/descriptor/input.cpp
+2
-2
input.hpp
src/ngraph/descriptor/input.hpp
+26
-19
output.hpp
src/ngraph/descriptor/output.hpp
+5
-3
node.cpp
src/ngraph/node.cpp
+7
-5
node.hpp
src/ngraph/node.hpp
+11
-11
input_output_assign.cpp
test/input_output_assign.cpp
+11
-11
No files found.
src/ngraph/descriptor/input.cpp
View file @
36cc0317
...
@@ -19,14 +19,14 @@ using namespace ngraph;
...
@@ -19,14 +19,14 @@ using namespace ngraph;
using
namespace
descriptor
;
using
namespace
descriptor
;
Input
::
Input
(
Input
::
Input
(
Node
*
node
,
size_t
index
,
size_t
argno
,
size_t
arg_index
,
const
shared_ptr
<
Output
>
&
output
)
Node
*
node
,
size_t
index
,
size_t
argno
,
size_t
arg_index
,
Output
&
output
)
:
m_node
(
node
)
:
m_node
(
node
)
,
m_index
(
index
)
,
m_index
(
index
)
,
m_argno
(
argno
)
,
m_argno
(
argno
)
,
m_arg_index
(
arg_index
)
,
m_arg_index
(
arg_index
)
,
m_output
(
output
)
,
m_output
(
output
)
{
{
output
->
add_input
(
this
);
output
.
add_input
(
this
);
}
}
std
::
shared_ptr
<
Node
>
Input
::
get_node
()
std
::
shared_ptr
<
Node
>
Input
::
get_node
()
...
...
src/ngraph/descriptor/input.hpp
View file @
36cc0317
...
@@ -18,15 +18,16 @@
...
@@ -18,15 +18,16 @@
namespace
ngraph
namespace
ngraph
{
{
class
Node
;
namespace
descriptor
namespace
descriptor
{
{
class
Output
;
class
Output
;
// Describes a tensor that is an input to an op, directly or indirectly via a tuple
// Describes a tensor that is an input to an op, directly or indirectly via a tuple
class
Input
:
public
std
::
enable_shared_from_this
<
Input
>
class
Input
{
{
Input
(
const
Input
&
)
=
delete
;
friend
class
Node
;
Input
&
operator
=
(
const
Input
&
)
=
delete
;
public
:
public
:
/// @param node The node that owns this input; not shared to prevent owner loop
/// @param node The node that owns this input; not shared to prevent owner loop
...
@@ -34,24 +35,30 @@ namespace ngraph
...
@@ -34,24 +35,30 @@ namespace ngraph
/// @param argno The position of the argument with this tensor
/// @param argno The position of the argument with this tensor
/// @param arg_index The position of the tensor within the argument's tensors
/// @param arg_index The position of the tensor within the argument's tensors
/// @param output The output that supplies a value for this input
/// @param output The output that supplies a value for this input
Input
(
Node
*
node
,
Input
(
Node
*
node
,
size_t
index
,
size_t
index
,
size_t
argno
,
size_t
argno
,
size_t
arg_index
,
size_t
arg_index
,
const
std
::
shared_ptr
<
Output
>&
output
);
Output
&
output
);
std
::
shared_ptr
<
Node
>
get_node
();
std
::
shared_ptr
<
Node
>
get_node
();
size_t
get_argno
()
const
{
return
m_argno
;
}
size_t
get_argno
()
const
{
return
m_argno
;
}
size_t
get_arg_index
()
const
{
return
m_arg_index
;
}
size_t
get_arg_index
()
const
{
return
m_arg_index
;
}
size_t
get_index
()
const
{
return
m_index
;
}
size_t
get_index
()
const
{
return
m_index
;
}
std
::
shared_ptr
<
Output
>
get_output
()
const
{
return
m_output
;
}
const
Output
&
get_output
()
const
{
return
m_output
;
}
Output
&
get_output
()
{
return
m_output
;
}
protected
:
protected
:
Node
*
m_node
;
// The node we are an input for
Node
*
m_node
;
// The node we are an input for
size_t
m_index
;
// Index into all input tensors
size_t
m_index
;
// Index into all input tensors
size_t
m_argno
;
// Arg number for this input
size_t
m_argno
;
// Arg number for this input
size_t
m_arg_index
;
// Index into arg's tensors
size_t
m_arg_index
;
// Index into arg's tensors
std
::
shared_ptr
<
Output
>
m_output
;
Output
&
m_output
;
private
:
// Input(const Input&) = default;
// Input(Input&&) = default;
// Input& operator=(const Input&) = delete;
};
};
}
}
}
}
src/ngraph/descriptor/output.hpp
View file @
36cc0317
...
@@ -24,10 +24,12 @@ namespace ngraph
...
@@ -24,10 +24,12 @@ namespace ngraph
namespace
descriptor
namespace
descriptor
{
{
// Describes an output tensor of an op
// Describes an output tensor of an op
class
Output
:
public
std
::
enable_shared_from_this
<
Output
>
class
Output
{
{
Output
(
const
Output
&
)
=
delete
;
// For some odd reason emplace_back is requiring a copy constructor
Output
&
operator
=
(
const
Output
&
)
=
delete
;
// it should not. See issue #111 for details
// Output(const Output&) = delete;
// Output& operator=(const Output&) = delete;
public
:
public
:
/// @param node Node that owns this output. Not shared to prevent owner loop.
/// @param node Node that owns this output. Not shared to prevent owner loop.
...
...
src/ngraph/node.cpp
View file @
36cc0317
...
@@ -31,6 +31,10 @@ Node::Node(const std::vector<shared_ptr<Node>>& arguments, shared_ptr<ValueType>
...
@@ -31,6 +31,10 @@ Node::Node(const std::vector<shared_ptr<Node>>& arguments, shared_ptr<ValueType>
}
}
}
}
Node
::~
Node
()
{
}
void
Node
::
set_value_type_checked
(
const
shared_ptr
<
ValueType
>&
value_type
)
void
Node
::
set_value_type_checked
(
const
shared_ptr
<
ValueType
>&
value_type
)
{
{
if
(
nullptr
==
m_value_type
)
if
(
nullptr
==
m_value_type
)
...
@@ -54,8 +58,7 @@ void Node::assign_tensors()
...
@@ -54,8 +58,7 @@ void Node::assign_tensors()
for
(
auto
tvt
:
tensor_view_types
)
for
(
auto
tvt
:
tensor_view_types
)
{
{
auto
tensor_view_descriptor
=
make_shared
<
descriptor
::
PrimaryTensorView
>
(
tvt
);
auto
tensor_view_descriptor
=
make_shared
<
descriptor
::
PrimaryTensorView
>
(
tvt
);
auto
output
=
make_shared
<
descriptor
::
Output
>
(
this
,
i
++
,
tensor_view_descriptor
);
m_outputs
.
emplace_back
(
this
,
i
++
,
tensor_view_descriptor
);
m_outputs
.
push_back
(
output
);
}
}
i
=
0
;
i
=
0
;
...
@@ -63,10 +66,9 @@ void Node::assign_tensors()
...
@@ -63,10 +66,9 @@ void Node::assign_tensors()
for
(
auto
arg
:
get_arguments
())
for
(
auto
arg
:
get_arguments
())
{
{
size_t
arg_index
=
0
;
size_t
arg_index
=
0
;
for
(
auto
output
:
arg
->
get_outputs
())
for
(
descriptor
::
Output
&
output
:
arg
->
get_outputs
())
{
{
auto
input
=
make_shared
<
descriptor
::
Input
>
(
this
,
i
++
,
argno
,
arg_index
++
,
output
);
m_inputs
.
emplace_back
(
this
,
i
++
,
argno
,
arg_index
++
,
output
);
m_inputs
.
push_back
(
input
);
}
}
argno
++
;
argno
++
;
}
}
...
...
src/ngraph/node.hpp
View file @
36cc0317
...
@@ -50,7 +50,7 @@ namespace ngraph
...
@@ -50,7 +50,7 @@ namespace ngraph
{
{
}
}
virtual
~
Node
()
{}
virtual
~
Node
()
;
public
:
public
:
/// A "one-liner" describing this node.
/// A "one-liner" describing this node.
...
@@ -106,17 +106,17 @@ namespace ngraph
...
@@ -106,17 +106,17 @@ namespace ngraph
size_t
get_instance_id
()
const
{
return
m_instance_id
;
}
size_t
get_instance_id
()
const
{
return
m_instance_id
;
}
friend
std
::
ostream
&
operator
<<
(
std
::
ostream
&
,
const
Node
&
);
friend
std
::
ostream
&
operator
<<
(
std
::
ostream
&
,
const
Node
&
);
const
std
::
vector
<
std
::
shared_ptr
<
descriptor
::
Input
>
>&
get_inputs
()
{
return
m_inputs
;
}
std
::
vector
<
descriptor
::
Input
>&
get_inputs
()
{
return
m_inputs
;
}
const
std
::
vector
<
std
::
shared_ptr
<
descriptor
::
Output
>
>&
get_outputs
()
{
return
m_outputs
;
}
std
::
vector
<
descriptor
::
Output
>&
get_outputs
()
{
return
m_outputs
;
}
protected
:
protected
:
Nodes
m_arguments
;
Nodes
m_arguments
;
std
::
shared_ptr
<
ValueType
>
m_value_type
;
std
::
shared_ptr
<
ValueType
>
m_value_type
;
std
::
multiset
<
Node
*>
m_users
;
std
::
multiset
<
Node
*>
m_users
;
std
::
string
m_name
;
std
::
string
m_name
;
size_t
m_instance_id
;
size_t
m_instance_id
;
static
size_t
m_next_instance_id
;
static
size_t
m_next_instance_id
;
std
::
vector
<
std
::
shared_ptr
<
descriptor
::
Input
>
>
m_inputs
;
std
::
vector
<
descriptor
::
Input
>
m_inputs
;
std
::
vector
<
std
::
shared_ptr
<
descriptor
::
Output
>
>
m_outputs
;
std
::
vector
<
descriptor
::
Output
>
m_outputs
;
};
};
}
}
test/input_output_assign.cpp
View file @
36cc0317
...
@@ -32,11 +32,11 @@ TEST(input_output, param_tensor)
...
@@ -32,11 +32,11 @@ TEST(input_output, param_tensor)
for
(
size_t
i
=
0
;
i
<
param
->
get_outputs
().
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
param
->
get_outputs
().
size
();
i
++
)
{
{
auto
output
=
param
->
get_outputs
()[
i
];
auto
output
=
param
->
get_outputs
()[
i
];
ASSERT_EQ
(
i
,
output
->
get_index
());
ASSERT_EQ
(
i
,
output
.
get_index
());
ASSERT_EQ
(
param
,
output
->
get_node
());
ASSERT_EQ
(
param
,
output
.
get_node
());
}
}
ASSERT_EQ
(
*
tv_tp
,
*
param
->
get_outputs
()[
0
]
->
get_tensor_view
()
->
get_tensor_view_type
());
ASSERT_EQ
(
*
tv_tp
,
*
param
->
get_outputs
()[
0
]
.
get_tensor_view
()
->
get_tensor_view_type
());
}
}
TEST
(
input_output
,
param_tuple
)
TEST
(
input_output
,
param_tuple
)
...
@@ -53,12 +53,12 @@ TEST(input_output, param_tuple)
...
@@ -53,12 +53,12 @@ TEST(input_output, param_tuple)
for
(
size_t
i
=
0
;
i
<
param
->
get_outputs
().
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
param
->
get_outputs
().
size
();
i
++
)
{
{
auto
output
=
param
->
get_outputs
()[
i
];
auto
output
=
param
->
get_outputs
()[
i
];
ASSERT_EQ
(
i
,
output
->
get_index
());
ASSERT_EQ
(
i
,
output
.
get_index
());
ASSERT_EQ
(
param
,
output
->
get_node
());
ASSERT_EQ
(
param
,
output
.
get_node
());
}
}
ASSERT_EQ
(
*
tv_tp_0
,
*
param
->
get_outputs
()[
0
]
->
get_tensor_view
()
->
get_tensor_view_type
());
ASSERT_EQ
(
*
tv_tp_0
,
*
param
->
get_outputs
()[
0
]
.
get_tensor_view
()
->
get_tensor_view_type
());
ASSERT_EQ
(
*
tv_tp_1
,
*
param
->
get_outputs
()[
1
]
->
get_tensor_view
()
->
get_tensor_view_type
());
ASSERT_EQ
(
*
tv_tp_1
,
*
param
->
get_outputs
()[
1
]
.
get_tensor_view
()
->
get_tensor_view_type
());
}
}
TEST
(
input_output
,
simple_output
)
TEST
(
input_output
,
simple_output
)
...
@@ -92,9 +92,9 @@ TEST(input_output, simple_output)
...
@@ -92,9 +92,9 @@ TEST(input_output, simple_output)
for
(
size_t
i
=
0
;
i
<
inputs
.
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
inputs
.
size
();
i
++
)
{
{
auto
input
=
inputs
[
i
];
auto
input
=
inputs
[
i
];
ASSERT_EQ
(
i
,
input
->
get_index
());
ASSERT_EQ
(
i
,
input
.
get_index
());
ASSERT_EQ
(
i
,
input
->
get_argno
());
ASSERT_EQ
(
i
,
input
.
get_argno
());
ASSERT_EQ
(
0
,
input
->
get_arg_index
());
ASSERT_EQ
(
0
,
input
.
get_arg_index
());
ASSERT_EQ
(
input
->
get_output
()
->
get_node
(),
add
->
get_arguments
()[
i
]);
ASSERT_EQ
(
input
.
get_output
().
get_node
(),
add
->
get_arguments
()[
i
]);
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment