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
03e6962d
Unverified
Commit
03e6962d
authored
Jul 02, 2019
by
Scott Cyphers
Committed by
GitHub
Jul 02, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' into bob/spelling
parents
ef287b37
f8ff66ca
Hide whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
339 additions
and
23 deletions
+339
-23
CMakeLists.txt
src/ngraph/CMakeLists.txt
+2
-0
group_conv_transpose.cpp
src/ngraph/op/fused/group_conv_transpose.cpp
+2
-1
aligned_buffer.cpp
src/ngraph/runtime/aligned_buffer.cpp
+28
-5
aligned_buffer.hpp
src/ngraph/runtime/aligned_buffer.hpp
+8
-1
allocator.cpp
src/ngraph/runtime/allocator.cpp
+55
-0
allocator.hpp
src/ngraph/runtime/allocator.hpp
+50
-0
backend.cpp
src/ngraph/runtime/backend.cpp
+7
-0
backend.hpp
src/ngraph/runtime/backend.hpp
+19
-0
cpu_backend.cpp
src/ngraph/runtime/cpu/cpu_backend.cpp
+35
-4
cpu_backend.hpp
src/ngraph/runtime/cpu/cpu_backend.hpp
+10
-1
cpu_call_frame.cpp
src/ngraph/runtime/cpu/cpu_call_frame.cpp
+5
-4
cpu_call_frame.hpp
src/ngraph/runtime/cpu/cpu_call_frame.hpp
+4
-2
cpu_external_function.cpp
src/ngraph/runtime/cpu/cpu_external_function.cpp
+4
-2
cpu_external_function.hpp
src/ngraph/runtime/cpu/cpu_external_function.hpp
+1
-2
cpu_runtime_context.hpp
src/ngraph/runtime/cpu/cpu_runtime_context.hpp
+0
-1
w.bin
test/files/onnx/convtranspose_output_shape/w.bin
+0
-0
x.bin
test/files/onnx/convtranspose_output_shape/x.bin
+0
-0
y.bin
test/files/onnx/convtranspose_output_shape/y.bin
+0
-0
convtranspose_output_shape.prototxt
test/models/onnx/convtranspose_output_shape.prototxt
+92
-0
onnx_import_convpool.in.cpp
test/onnx/onnx_import_convpool.in.cpp
+17
-0
No files found.
src/ngraph/CMakeLists.txt
View file @
03e6962d
...
@@ -458,6 +458,8 @@ set (SRC
...
@@ -458,6 +458,8 @@ set (SRC
rank.hpp
rank.hpp
runtime/aligned_buffer.cpp
runtime/aligned_buffer.cpp
runtime/aligned_buffer.hpp
runtime/aligned_buffer.hpp
runtime/allocator.cpp
runtime/allocator.hpp
runtime/backend.cpp
runtime/backend.cpp
runtime/backend.hpp
runtime/backend.hpp
runtime/backend_manager.cpp
runtime/backend_manager.cpp
...
...
src/ngraph/op/fused/group_conv_transpose.cpp
View file @
03e6962d
...
@@ -203,7 +203,8 @@ shared_ptr<Node> op::GroupConvolutionTranspose::copy_with_new_args(const NodeVec
...
@@ -203,7 +203,8 @@ shared_ptr<Node> op::GroupConvolutionTranspose::copy_with_new_args(const NodeVec
get_padding_end
(),
get_padding_end
(),
get_output_padding
(),
get_output_padding
(),
get_groups
(),
get_groups
(),
get_pad_type
());
get_pad_type
(),
get_output_shape
());
}
}
Shape
op
::
GroupConvolutionTranspose
::
get_data_batch_shape
()
const
Shape
op
::
GroupConvolutionTranspose
::
get_data_batch_shape
()
const
...
...
src/ngraph/runtime/aligned_buffer.cpp
View file @
03e6962d
...
@@ -18,22 +18,34 @@
...
@@ -18,22 +18,34 @@
#include <memory>
#include <memory>
#include "ngraph/runtime/aligned_buffer.hpp"
#include "ngraph/runtime/aligned_buffer.hpp"
#include "ngraph/runtime/allocator.hpp"
#include "ngraph/util.hpp"
#include "ngraph/util.hpp"
using
namespace
ngraph
;
using
namespace
ngraph
;
using
namespace
std
;
runtime
::
AlignedBuffer
::
AlignedBuffer
()
runtime
::
AlignedBuffer
::
AlignedBuffer
()
:
m_allocated_buffer
(
nullptr
)
:
m_allocator
(
nullptr
)
,
m_allocated_buffer
(
nullptr
)
,
m_aligned_buffer
(
nullptr
)
,
m_aligned_buffer
(
nullptr
)
,
m_byte_size
(
0
)
,
m_byte_size
(
0
)
{
{
}
}
runtime
::
AlignedBuffer
::
AlignedBuffer
(
size_t
byte_size
,
size_t
alignment
)
runtime
::
AlignedBuffer
::
AlignedBuffer
(
size_t
byte_size
,
size_t
alignment
,
Allocator
*
allocator
)
:
m_allocator
(
allocator
)
,
m_byte_size
(
byte_size
)
{
{
m_byte_size
=
std
::
max
<
size_t
>
(
1
,
byte_size
);
m_byte_size
=
std
::
max
<
size_t
>
(
1
,
byte_size
);
size_t
allocation_size
=
m_byte_size
+
alignment
;
size_t
allocation_size
=
m_byte_size
+
alignment
;
m_allocated_buffer
=
static_cast
<
char
*>
(
ngraph_malloc
(
allocation_size
));
if
(
allocator
)
{
m_allocated_buffer
=
static_cast
<
char
*>
(
m_allocator
->
malloc
(
allocation_size
,
alignment
));
}
else
{
m_allocated_buffer
=
static_cast
<
char
*>
(
malloc
(
allocation_size
));
}
m_aligned_buffer
=
m_allocated_buffer
;
m_aligned_buffer
=
m_allocated_buffer
;
size_t
mod
=
size_t
(
m_aligned_buffer
)
%
alignment
;
size_t
mod
=
size_t
(
m_aligned_buffer
)
%
alignment
;
...
@@ -44,10 +56,12 @@ runtime::AlignedBuffer::AlignedBuffer(size_t byte_size, size_t alignment)
...
@@ -44,10 +56,12 @@ runtime::AlignedBuffer::AlignedBuffer(size_t byte_size, size_t alignment)
}
}
runtime
::
AlignedBuffer
::
AlignedBuffer
(
AlignedBuffer
&&
other
)
runtime
::
AlignedBuffer
::
AlignedBuffer
(
AlignedBuffer
&&
other
)
:
m_allocated_buffer
(
other
.
m_allocated_buffer
)
:
m_allocator
(
other
.
m_allocator
)
,
m_allocated_buffer
(
other
.
m_allocated_buffer
)
,
m_aligned_buffer
(
other
.
m_aligned_buffer
)
,
m_aligned_buffer
(
other
.
m_aligned_buffer
)
,
m_byte_size
(
other
.
m_byte_size
)
,
m_byte_size
(
other
.
m_byte_size
)
{
{
other
.
m_allocator
=
nullptr
;
other
.
m_allocated_buffer
=
nullptr
;
other
.
m_allocated_buffer
=
nullptr
;
other
.
m_aligned_buffer
=
nullptr
;
other
.
m_aligned_buffer
=
nullptr
;
other
.
m_byte_size
=
0
;
other
.
m_byte_size
=
0
;
...
@@ -57,7 +71,14 @@ runtime::AlignedBuffer::~AlignedBuffer()
...
@@ -57,7 +71,14 @@ runtime::AlignedBuffer::~AlignedBuffer()
{
{
if
(
m_allocated_buffer
!=
nullptr
)
if
(
m_allocated_buffer
!=
nullptr
)
{
{
ngraph_free
(
m_allocated_buffer
);
if
(
m_allocator
)
{
m_allocator
->
free
(
m_allocated_buffer
);
}
else
{
free
(
m_allocated_buffer
);
}
}
}
}
}
...
@@ -65,9 +86,11 @@ runtime::AlignedBuffer& runtime::AlignedBuffer::operator=(AlignedBuffer&& other)
...
@@ -65,9 +86,11 @@ runtime::AlignedBuffer& runtime::AlignedBuffer::operator=(AlignedBuffer&& other)
{
{
if
(
this
!=
&
other
)
if
(
this
!=
&
other
)
{
{
m_allocator
=
other
.
m_allocator
;
m_allocated_buffer
=
other
.
m_allocated_buffer
;
m_allocated_buffer
=
other
.
m_allocated_buffer
;
m_aligned_buffer
=
other
.
m_aligned_buffer
;
m_aligned_buffer
=
other
.
m_aligned_buffer
;
m_byte_size
=
other
.
m_byte_size
;
m_byte_size
=
other
.
m_byte_size
;
other
.
m_allocator
=
nullptr
;
other
.
m_allocated_buffer
=
nullptr
;
other
.
m_allocated_buffer
=
nullptr
;
other
.
m_aligned_buffer
=
nullptr
;
other
.
m_aligned_buffer
=
nullptr
;
other
.
m_byte_size
=
0
;
other
.
m_byte_size
=
0
;
...
...
src/ngraph/runtime/aligned_buffer.hpp
View file @
03e6962d
...
@@ -18,6 +18,8 @@
...
@@ -18,6 +18,8 @@
#include <cstddef>
#include <cstddef>
#include "ngraph/runtime/allocator.hpp"
namespace
ngraph
namespace
ngraph
{
{
namespace
runtime
namespace
runtime
...
@@ -32,7 +34,11 @@ namespace ngraph
...
@@ -32,7 +34,11 @@ namespace ngraph
class
ngraph
::
runtime
::
AlignedBuffer
class
ngraph
::
runtime
::
AlignedBuffer
{
{
public
:
public
:
AlignedBuffer
(
size_t
byte_size
,
size_t
alignment
);
// Allocator objects and the allocation interfaces are owned by the
// creators of AlignedBuffers. They need to ensure that the lifetime of
// allocator exceeds the lifetime of this AlignedBuffer.
AlignedBuffer
(
size_t
byte_size
,
size_t
alignment
,
Allocator
*
allocator
=
nullptr
);
AlignedBuffer
();
AlignedBuffer
();
~
AlignedBuffer
();
~
AlignedBuffer
();
...
@@ -46,6 +52,7 @@ private:
...
@@ -46,6 +52,7 @@ private:
AlignedBuffer
(
const
AlignedBuffer
&
)
=
delete
;
AlignedBuffer
(
const
AlignedBuffer
&
)
=
delete
;
AlignedBuffer
&
operator
=
(
const
AlignedBuffer
&
)
=
delete
;
AlignedBuffer
&
operator
=
(
const
AlignedBuffer
&
)
=
delete
;
Allocator
*
m_allocator
;
char
*
m_allocated_buffer
;
char
*
m_allocated_buffer
;
char
*
m_aligned_buffer
;
char
*
m_aligned_buffer
;
size_t
m_byte_size
;
size_t
m_byte_size
;
...
...
src/ngraph/runtime/allocator.cpp
0 → 100644
View file @
03e6962d
//*****************************************************************************
// Copyright 2017-2019 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//*****************************************************************************
#include "ngraph/runtime/allocator.hpp"
ngraph
::
runtime
::
Allocator
::~
Allocator
()
{
}
class
ngraph
::
runtime
::
DefaultAllocator
:
public
ngraph
::
runtime
::
Allocator
{
public
:
void
*
malloc
(
size_t
size
,
size_t
alignment
)
{
// If allocation succeeds, returns a pointer to the lowest (first) byte in the
// allocated memory block that is suitably aligned for any scalar type.
// TODO(pruthvi): replace std::malloc with custom aligned_alloc implementation
// which is portable and work on all alignment requirement.
void
*
ptr
=
std
::
malloc
(
size
);
// check for exception
if
(
!
ptr
)
{
throw
ngraph
::
ngraph_error
(
"malloc failed to allocate memory of size "
+
std
::
to_string
(
size
));
}
return
ptr
;
}
void
free
(
void
*
ptr
)
{
if
(
ptr
)
{
std
::
free
(
ptr
);
}
}
};
std
::
unique_ptr
<
ngraph
::
runtime
::
Allocator
>
ngraph
::
runtime
::
create_default_allocator
()
{
return
std
::
unique_ptr
<
DefaultAllocator
>
(
new
DefaultAllocator
());
}
src/ngraph/runtime/allocator.hpp
0 → 100644
View file @
03e6962d
//*****************************************************************************
// Copyright 2017-2019 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//*****************************************************************************
#pragma once
#include <cstddef>
#include <cstdint>
#include <cstdlib>
#include "ngraph/except.hpp"
#include "ngraph/util.hpp"
namespace
ngraph
{
namespace
runtime
{
class
Allocator
;
class
DefaultAllocator
;
/// \brief Create a default allocator that calls into system
/// allocation libraries
std
::
unique_ptr
<
Allocator
>
create_default_allocator
();
}
}
/// \brief Abstract class for the allocator
class
ngraph
::
runtime
::
Allocator
{
public
:
virtual
~
Allocator
()
=
0
;
/// \brief allocates memory with the given size and alignment requirement
/// \param size exact size of bytes to allocate
/// \param alignment specifies the alignment. Must be a valid alignment supported by the implementation.
virtual
void
*
malloc
(
size_t
size
,
size_t
alignment
)
=
0
;
/// \brief deallocates the memory pointed by ptr
/// \param ptr pointer to the aligned memory to be released
virtual
void
free
(
void
*
ptr
)
=
0
;
};
src/ngraph/runtime/backend.cpp
View file @
03e6962d
...
@@ -86,6 +86,13 @@ void runtime::Backend::remove_compiled_function(std::shared_ptr<Executable> exec
...
@@ -86,6 +86,13 @@ void runtime::Backend::remove_compiled_function(std::shared_ptr<Executable> exec
{
{
}
}
bool
runtime
::
Backend
::
is_device_memory
(
void
*
ptr
)
{
// override this method for each supported backend to determine if the passed pointer is in
// device pinned memory or not
return
false
;
}
std
::
shared_ptr
<
runtime
::
Executable
>
runtime
::
Backend
::
load
(
istream
&
input_stream
)
std
::
shared_ptr
<
runtime
::
Executable
>
runtime
::
Backend
::
load
(
istream
&
input_stream
)
{
{
throw
runtime_error
(
"load opertion unimplemented."
);
throw
runtime_error
(
"load opertion unimplemented."
);
...
...
src/ngraph/runtime/backend.hpp
View file @
03e6962d
...
@@ -20,10 +20,12 @@
...
@@ -20,10 +20,12 @@
#include "ngraph/function.hpp"
#include "ngraph/function.hpp"
#include "ngraph/pass/pass_config.hpp"
#include "ngraph/pass/pass_config.hpp"
#include "ngraph/runtime/allocator.hpp"
#include "ngraph/runtime/executable.hpp"
#include "ngraph/runtime/executable.hpp"
#include "ngraph/runtime/performance_counter.hpp"
#include "ngraph/runtime/performance_counter.hpp"
#include "ngraph/shape.hpp"
#include "ngraph/shape.hpp"
#include "ngraph/type/element_type.hpp"
#include "ngraph/type/element_type.hpp"
#include "ngraph/util.hpp"
namespace
ngraph
namespace
ngraph
{
{
...
@@ -140,6 +142,23 @@ public:
...
@@ -140,6 +142,23 @@ public:
/// \returns a shared pointer to the op if found, else nullptr
/// \returns a shared pointer to the op if found, else nullptr
virtual
std
::
shared_ptr
<
ngraph
::
Node
>
get_backend_op
(
const
std
::
string
&
op_name
,
...);
virtual
std
::
shared_ptr
<
ngraph
::
Node
>
get_backend_op
(
const
std
::
string
&
op_name
,
...);
/// \brief Returns memory allocator used by backend for host allocations
virtual
Allocator
*
get_host_memory_allocator
()
{
return
nullptr
;
}
/// \brief Set the host memory allocator to be used by the backend
/// \param allocator is pointer to host memory allocator object
virtual
void
set_host_memory_allocator
(
std
::
unique_ptr
<
Allocator
>
allocator
)
{}
/// \brief Returns memory allocator used by backend for device allocations
virtual
Allocator
*
get_device_memory_allocator
()
{
// override this method from each supported backend to return
// its own device memory allocator
return
nullptr
;
}
/// \brief method for each supported backend to determine if the passed pointer is in device pinned memory or not
/// \param ptr pointer to the memory to determine if its in device memory or not
virtual
bool
is_device_memory
(
void
*
ptr
);
/// \brief Allows sending backend specific configuration. The map contains key, value pairs
/// \brief Allows sending backend specific configuration. The map contains key, value pairs
/// specific to a particluar backend. The definition of these key, value pairs is
/// specific to a particluar backend. The definition of these key, value pairs is
/// defined by each backend.
/// defined by each backend.
...
...
src/ngraph/runtime/cpu/cpu_backend.cpp
View file @
03e6962d
...
@@ -63,11 +63,17 @@ namespace
...
@@ -63,11 +63,17 @@ namespace
}
s_cpu_static_init
;
}
s_cpu_static_init
;
}
}
runtime
::
cpu
::
CPU_Backend
::~
CPU_Backend
()
{
m_exec_map
.
clear
();
}
shared_ptr
<
runtime
::
cpu
::
CPU_CallFrame
>
runtime
::
cpu
::
CPU_Backend
::
make_call_frame
(
shared_ptr
<
runtime
::
cpu
::
CPU_CallFrame
>
runtime
::
cpu
::
CPU_Backend
::
make_call_frame
(
const
shared_ptr
<
runtime
::
cpu
::
CPU_ExternalFunction
>&
external_function
,
const
shared_ptr
<
runtime
::
cpu
::
CPU_ExternalFunction
>&
external_function
,
ngraph
::
pass
::
PassConfig
&
pass_config
)
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
)
{
{
return
external_function
->
make_call_frame
(
pass_config
);
return
external_function
->
make_call_frame
(
pass_config
,
allocator
);
}
}
shared_ptr
<
runtime
::
Tensor
>
shared_ptr
<
runtime
::
Tensor
>
...
@@ -114,7 +120,8 @@ shared_ptr<runtime::Executable>
...
@@ -114,7 +120,8 @@ shared_ptr<runtime::Executable>
return
rc
;
return
rc
;
}
}
}
}
rc
=
make_shared
<
CPU_Executable
>
(
func
,
pass_config
,
performance_counters_enabled
);
rc
=
make_shared
<
CPU_Executable
>
(
func
,
pass_config
,
get_host_memory_allocator
(),
performance_counters_enabled
);
{
{
std
::
lock_guard
<
std
::
mutex
>
guard
(
m_exec_map_mutex
);
std
::
lock_guard
<
std
::
mutex
>
guard
(
m_exec_map_mutex
);
m_exec_map
.
insert
({
func
,
rc
});
m_exec_map
.
insert
({
func
,
rc
});
...
@@ -124,6 +131,7 @@ shared_ptr<runtime::Executable>
...
@@ -124,6 +131,7 @@ shared_ptr<runtime::Executable>
runtime
::
cpu
::
CPU_Executable
::
CPU_Executable
(
shared_ptr
<
Function
>
func
,
runtime
::
cpu
::
CPU_Executable
::
CPU_Executable
(
shared_ptr
<
Function
>
func
,
ngraph
::
pass
::
PassConfig
&
pass_config
,
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
,
bool
performance_counters_enabled
)
bool
performance_counters_enabled
)
{
{
FunctionInstance
&
instance
=
m_function_instance
;
FunctionInstance
&
instance
=
m_function_instance
;
...
@@ -131,7 +139,7 @@ runtime::cpu::CPU_Executable::CPU_Executable(shared_ptr<Function> func,
...
@@ -131,7 +139,7 @@ runtime::cpu::CPU_Executable::CPU_Executable(shared_ptr<Function> func,
{
{
instance
.
m_external_function
=
make_shared
<
CPU_ExternalFunction
>
(
func
);
instance
.
m_external_function
=
make_shared
<
CPU_ExternalFunction
>
(
func
);
instance
.
m_external_function
->
m_emit_timing
=
performance_counters_enabled
;
instance
.
m_external_function
->
m_emit_timing
=
performance_counters_enabled
;
auto
cf
=
instance
.
m_external_function
->
make_call_frame
(
pass_config
);
auto
cf
=
instance
.
m_external_function
->
make_call_frame
(
pass_config
,
allocator
);
instance
.
m_call_frame
=
dynamic_pointer_cast
<
CPU_CallFrame
>
(
cf
);
instance
.
m_call_frame
=
dynamic_pointer_cast
<
CPU_CallFrame
>
(
cf
);
}
}
set_parameters_and_results
(
*
func
);
set_parameters_and_results
(
*
func
);
...
@@ -173,6 +181,28 @@ void runtime::cpu::CPU_Backend::remove_compiled_function(shared_ptr<Executable>
...
@@ -173,6 +181,28 @@ void runtime::cpu::CPU_Backend::remove_compiled_function(shared_ptr<Executable>
}
}
}
}
runtime
::
Allocator
*
runtime
::
cpu
::
CPU_Backend
::
get_host_memory_allocator
()
{
if
(
!
m_allocator
)
{
m_allocator
=
create_default_allocator
();
}
return
m_allocator
.
get
();
}
void
runtime
::
cpu
::
CPU_Backend
::
set_host_memory_allocator
(
std
::
unique_ptr
<
runtime
::
Allocator
>
allocator
)
{
if
(
m_allocator
)
{
// Resources allocated with the existing allocator might still be around and expect it
// to be available for freeing. We cannot switch to the new allocator
throw
ngraph_error
(
"Allocator already exists. Changing allocators mid-execution is not permitted."
);
}
m_allocator
=
std
::
move
(
allocator
);
}
vector
<
runtime
::
PerformanceCounter
>
runtime
::
cpu
::
CPU_Executable
::
get_performance_data
()
const
vector
<
runtime
::
PerformanceCounter
>
runtime
::
cpu
::
CPU_Executable
::
get_performance_data
()
const
{
{
vector
<
runtime
::
PerformanceCounter
>
rc
;
vector
<
runtime
::
PerformanceCounter
>
rc
;
...
@@ -190,6 +220,7 @@ bool runtime::cpu::CPU_Backend::is_supported(const Node& op) const
...
@@ -190,6 +220,7 @@ bool runtime::cpu::CPU_Backend::is_supported(const Node& op) const
{
{
return
true
;
return
true
;
}
}
bool
runtime
::
cpu
::
CPU_Backend
::
is_supported_property
(
const
Property
prop
)
const
bool
runtime
::
cpu
::
CPU_Backend
::
is_supported_property
(
const
Property
prop
)
const
{
{
if
(
prop
==
Property
::
memory_attach
)
if
(
prop
==
Property
::
memory_attach
)
...
...
src/ngraph/runtime/cpu/cpu_backend.hpp
View file @
03e6962d
...
@@ -22,6 +22,7 @@
...
@@ -22,6 +22,7 @@
#include "cpu_backend_visibility.h"
#include "cpu_backend_visibility.h"
#include "ngraph/pass/pass_config.hpp"
#include "ngraph/pass/pass_config.hpp"
#include "ngraph/runtime/allocator.hpp"
#include "ngraph/runtime/backend.hpp"
#include "ngraph/runtime/backend.hpp"
namespace
ngraph
namespace
ngraph
...
@@ -36,9 +37,12 @@ namespace ngraph
...
@@ -36,9 +37,12 @@ namespace ngraph
class
CPU_BACKEND_API
CPU_Backend
:
public
runtime
::
Backend
class
CPU_BACKEND_API
CPU_Backend
:
public
runtime
::
Backend
{
{
public
:
public
:
~
CPU_Backend
()
override
;
std
::
shared_ptr
<
CPU_CallFrame
>
std
::
shared_ptr
<
CPU_CallFrame
>
make_call_frame
(
const
std
::
shared_ptr
<
CPU_ExternalFunction
>&
external_function
,
make_call_frame
(
const
std
::
shared_ptr
<
CPU_ExternalFunction
>&
external_function
,
ngraph
::
pass
::
PassConfig
&
pass_config
);
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
);
std
::
shared_ptr
<
ngraph
::
runtime
::
Tensor
>
std
::
shared_ptr
<
ngraph
::
runtime
::
Tensor
>
create_tensor
(
const
ngraph
::
element
::
Type
&
element_type
,
create_tensor
(
const
ngraph
::
element
::
Type
&
element_type
,
...
@@ -60,6 +64,9 @@ namespace ngraph
...
@@ -60,6 +64,9 @@ namespace ngraph
void
remove_compiled_function
(
std
::
shared_ptr
<
Executable
>
exec
)
override
;
void
remove_compiled_function
(
std
::
shared_ptr
<
Executable
>
exec
)
override
;
Allocator
*
get_host_memory_allocator
()
override
;
void
set_host_memory_allocator
(
std
::
unique_ptr
<
Allocator
>
allocator
)
override
;
bool
is_supported
(
const
Node
&
node
)
const
override
;
bool
is_supported
(
const
Node
&
node
)
const
override
;
bool
is_supported_property
(
const
Property
prop
)
const
override
;
bool
is_supported_property
(
const
Property
prop
)
const
override
;
...
@@ -69,6 +76,7 @@ namespace ngraph
...
@@ -69,6 +76,7 @@ namespace ngraph
std
::
mutex
m_exec_map_mutex
;
std
::
mutex
m_exec_map_mutex
;
std
::
unordered_map
<
std
::
shared_ptr
<
Function
>
,
std
::
shared_ptr
<
Executable
>>
std
::
unordered_map
<
std
::
shared_ptr
<
Function
>
,
std
::
shared_ptr
<
Executable
>>
m_exec_map
;
m_exec_map
;
std
::
unique_ptr
<
Allocator
>
m_allocator
;
};
};
class
CPU_BACKEND_API
CPU_Executable
:
public
runtime
::
Executable
class
CPU_BACKEND_API
CPU_Executable
:
public
runtime
::
Executable
...
@@ -76,6 +84,7 @@ namespace ngraph
...
@@ -76,6 +84,7 @@ namespace ngraph
public
:
public
:
CPU_Executable
(
std
::
shared_ptr
<
Function
>
func
,
CPU_Executable
(
std
::
shared_ptr
<
Function
>
func
,
ngraph
::
pass
::
PassConfig
&
pass_config
,
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
,
bool
performance_counters_enabled
);
bool
performance_counters_enabled
);
bool
call
(
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
outputs
,
bool
call
(
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
outputs
,
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
inputs
)
override
;
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
inputs
)
override
;
...
...
src/ngraph/runtime/cpu/cpu_call_frame.cpp
View file @
03e6962d
...
@@ -30,7 +30,8 @@ using namespace ngraph;
...
@@ -30,7 +30,8 @@ using namespace ngraph;
runtime
::
cpu
::
CPU_CallFrame
::
CPU_CallFrame
(
std
::
shared_ptr
<
CPU_ExternalFunction
>
external_function
,
runtime
::
cpu
::
CPU_CallFrame
::
CPU_CallFrame
(
std
::
shared_ptr
<
CPU_ExternalFunction
>
external_function
,
InitContextFuncCG
compiled_init_ctx_func
,
InitContextFuncCG
compiled_init_ctx_func
,
DestroyContextFuncCG
compiled_destroy_ctx_func
,
DestroyContextFuncCG
compiled_destroy_ctx_func
,
EntryPoint
compiled_function
)
EntryPoint
compiled_function
,
runtime
::
Allocator
*
allocator
)
:
m_external_function
(
external_function
)
:
m_external_function
(
external_function
)
,
m_compiled_init_ctx_func
(
compiled_init_ctx_func
)
,
m_compiled_init_ctx_func
(
compiled_init_ctx_func
)
,
m_compiled_destroy_ctx_func
(
compiled_destroy_ctx_func
)
,
m_compiled_destroy_ctx_func
(
compiled_destroy_ctx_func
)
...
@@ -47,7 +48,7 @@ runtime::cpu::CPU_CallFrame::CPU_CallFrame(std::shared_ptr<CPU_ExternalFunction>
...
@@ -47,7 +48,7 @@ runtime::cpu::CPU_CallFrame::CPU_CallFrame(std::shared_ptr<CPU_ExternalFunction>
std
::
to_string
(
std
::
thread
::
hardware_concurrency
())
+
"]"
);
std
::
to_string
(
std
::
thread
::
hardware_concurrency
())
+
"]"
);
}
}
setup_runtime_context
();
setup_runtime_context
(
allocator
);
if
(
!
m_external_function
->
is_direct_execution
())
if
(
!
m_external_function
->
is_direct_execution
())
{
{
// Invoke codegen runtime context initialization function.
// Invoke codegen runtime context initialization function.
...
@@ -178,7 +179,7 @@ void runtime::cpu::CPU_CallFrame::propagate_layouts(
...
@@ -178,7 +179,7 @@ void runtime::cpu::CPU_CallFrame::propagate_layouts(
}
}
}
}
void
runtime
::
cpu
::
CPU_CallFrame
::
setup_runtime_context
()
void
runtime
::
cpu
::
CPU_CallFrame
::
setup_runtime_context
(
Allocator
*
allocator
)
{
{
for
(
auto
i
=
0
;
i
<
m_num_ctx
;
i
++
)
for
(
auto
i
=
0
;
i
<
m_num_ctx
;
i
++
)
{
{
...
@@ -202,7 +203,7 @@ void runtime::cpu::CPU_CallFrame::setup_runtime_context()
...
@@ -202,7 +203,7 @@ void runtime::cpu::CPU_CallFrame::setup_runtime_context()
size_t
alignment
=
runtime
::
cpu
::
CPU_ExternalFunction
::
s_memory_pool_alignment
;
size_t
alignment
=
runtime
::
cpu
::
CPU_ExternalFunction
::
s_memory_pool_alignment
;
for
(
auto
buffer_size
:
m_external_function
->
get_memory_buffer_sizes
())
for
(
auto
buffer_size
:
m_external_function
->
get_memory_buffer_sizes
())
{
{
auto
buffer
=
new
AlignedBuffer
(
buffer_size
,
alignment
);
auto
buffer
=
new
AlignedBuffer
(
buffer_size
,
alignment
,
allocator
);
ctx
->
memory_buffers
.
push_back
(
buffer
);
ctx
->
memory_buffers
.
push_back
(
buffer
);
}
}
const
auto
&
mkldnn_emitter
=
m_external_function
->
get_mkldnn_emitter
();
const
auto
&
mkldnn_emitter
=
m_external_function
->
get_mkldnn_emitter
();
...
...
src/ngraph/runtime/cpu/cpu_call_frame.hpp
View file @
03e6962d
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#include <vector>
#include <vector>
#include "ngraph/function.hpp"
#include "ngraph/function.hpp"
#include "ngraph/runtime/allocator.hpp"
#include "ngraph/runtime/cpu/cpu_layout_descriptor.hpp"
#include "ngraph/runtime/cpu/cpu_layout_descriptor.hpp"
#include "ngraph/runtime/cpu/cpu_runtime_context.hpp"
#include "ngraph/runtime/cpu/cpu_runtime_context.hpp"
#include "ngraph/runtime/tensor.hpp"
#include "ngraph/runtime/tensor.hpp"
...
@@ -59,7 +60,8 @@ namespace ngraph
...
@@ -59,7 +60,8 @@ namespace ngraph
CPU_CallFrame
(
std
::
shared_ptr
<
CPU_ExternalFunction
>
external_function
,
CPU_CallFrame
(
std
::
shared_ptr
<
CPU_ExternalFunction
>
external_function
,
InitContextFuncCG
compiled_init_ctx_func
,
InitContextFuncCG
compiled_init_ctx_func
,
DestroyContextFuncCG
compiled_destroy_ctx_func
,
DestroyContextFuncCG
compiled_destroy_ctx_func
,
EntryPoint
compiled_function
);
EntryPoint
compiled_function
,
runtime
::
Allocator
*
allocator
);
~
CPU_CallFrame
();
~
CPU_CallFrame
();
/// \brief Invoke the function with values matching the signature of the function.
/// \brief Invoke the function with values matching the signature of the function.
...
@@ -71,7 +73,7 @@ namespace ngraph
...
@@ -71,7 +73,7 @@ namespace ngraph
void
propagate_layouts
(
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
tvs
,
void
propagate_layouts
(
const
std
::
vector
<
std
::
shared_ptr
<
runtime
::
Tensor
>>&
tvs
,
const
LayoutDescriptorPtrs
&
layouts
)
const
;
const
LayoutDescriptorPtrs
&
layouts
)
const
;
void
setup_runtime_context
();
void
setup_runtime_context
(
runtime
::
Allocator
*
allocator
);
void
setup_cg_runtime_context
();
void
setup_cg_runtime_context
();
void
cleanup_runtime_context
();
void
cleanup_runtime_context
();
...
...
src/ngraph/runtime/cpu/cpu_external_function.cpp
View file @
03e6962d
...
@@ -1825,7 +1825,8 @@ bool runtime::cpu::CPU_ExternalFunction::is_codegen(const ngraph::pass::PassConf
...
@@ -1825,7 +1825,8 @@ bool runtime::cpu::CPU_ExternalFunction::is_codegen(const ngraph::pass::PassConf
}
}
shared_ptr
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
shared_ptr
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
runtime
::
cpu
::
CPU_ExternalFunction
::
make_call_frame
(
ngraph
::
pass
::
PassConfig
&
pass_config
)
runtime
::
cpu
::
CPU_ExternalFunction
::
make_call_frame
(
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
)
{
{
#if defined(NGRAPH_DEX_ONLY)
#if defined(NGRAPH_DEX_ONLY)
if
(
is_codegen
(
pass_config
))
if
(
is_codegen
(
pass_config
))
...
@@ -1853,7 +1854,8 @@ shared_ptr<ngraph::runtime::cpu::CPU_CallFrame>
...
@@ -1853,7 +1854,8 @@ shared_ptr<ngraph::runtime::cpu::CPU_CallFrame>
return
make_shared
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
(
shared_from_this
(),
return
make_shared
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
(
shared_from_this
(),
m_compiled_init_ctx_func
,
m_compiled_init_ctx_func
,
m_compiled_destroy_ctx_func
,
m_compiled_destroy_ctx_func
,
m_compiled_function
);
m_compiled_function
,
allocator
);
}
}
const
runtime
::
cpu
::
LayoutDescriptorPtrs
&
const
runtime
::
cpu
::
LayoutDescriptorPtrs
&
...
...
src/ngraph/runtime/cpu/cpu_external_function.hpp
View file @
03e6962d
...
@@ -100,8 +100,7 @@ namespace ngraph
...
@@ -100,8 +100,7 @@ namespace ngraph
bool
release_function
=
true
);
bool
release_function
=
true
);
~
CPU_ExternalFunction
();
~
CPU_ExternalFunction
();
std
::
shared_ptr
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
std
::
shared_ptr
<
ngraph
::
runtime
::
cpu
::
CPU_CallFrame
>
make_call_frame
(
ngraph
::
pass
::
PassConfig
&
pass_config
);
make_call_frame
(
ngraph
::
pass
::
PassConfig
&
pass_config
,
Allocator
*
allocator
);
const
LayoutDescriptorPtrs
&
get_parameter_layout_descriptors
();
const
LayoutDescriptorPtrs
&
get_parameter_layout_descriptors
();
const
LayoutDescriptorPtrs
&
get_result_layout_descriptors
();
const
LayoutDescriptorPtrs
&
get_result_layout_descriptors
();
const
std
::
vector
<
size_t
>&
get_memory_buffer_sizes
()
const
const
std
::
vector
<
size_t
>&
get_memory_buffer_sizes
()
const
...
...
src/ngraph/runtime/cpu/cpu_runtime_context.hpp
View file @
03e6962d
...
@@ -37,7 +37,6 @@ namespace ngraph
...
@@ -37,7 +37,6 @@ namespace ngraph
{
{
class
AlignedBuffer
;
class
AlignedBuffer
;
}
}
class
State
;
class
State
;
}
}
...
...
test/files/onnx/convtranspose_output_shape/w.bin
0 → 100644
View file @
03e6962d
File added
test/files/onnx/convtranspose_output_shape/x.bin
0 → 100644
View file @
03e6962d
File added
test/files/onnx/convtranspose_output_shape/y.bin
0 → 100644
View file @
03e6962d
File added
test/models/onnx/convtranspose_output_shape.prototxt
0 → 100644
View file @
03e6962d
ir_version: 3
producer_name: "backend-test"
graph {
node {
input: "X"
input: "W"
output: "Y"
op_type: "ConvTranspose"
attribute {
name: "output_shape"
ints: 10
ints: 8
type: INTS
}
attribute {
name: "strides"
ints: 3
ints: 2
type: INTS
}
}
name: "test_convtranspose_output_shape"
input {
name: "X"
type {
tensor_type {
elem_type: 1
shape {
dim {
dim_value: 1
}
dim {
dim_value: 1
}
dim {
dim_value: 3
}
dim {
dim_value: 3
}
}
}
}
}
input {
name: "W"
type {
tensor_type {
elem_type: 1
shape {
dim {
dim_value: 1
}
dim {
dim_value: 2
}
dim {
dim_value: 3
}
dim {
dim_value: 3
}
}
}
}
}
output {
name: "Y"
type {
tensor_type {
elem_type: 1
shape {
dim {
dim_value: 1
}
dim {
dim_value: 2
}
dim {
dim_value: 10
}
dim {
dim_value: 8
}
}
}
}
}
}
opset_import {
version: 9
}
test/onnx/onnx_import_convpool.in.cpp
View file @
03e6962d
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
#include "util/all_close.hpp"
#include "util/all_close.hpp"
#include "util/all_close_f.hpp"
#include "util/all_close_f.hpp"
#include "util/ndarray.hpp"
#include "util/ndarray.hpp"
#include "util/test_case.hpp"
#include "util/test_control.hpp"
#include "util/test_control.hpp"
#include "util/test_tools.hpp"
#include "util/test_tools.hpp"
...
@@ -409,3 +410,19 @@ NGRAPH_TEST(onnx_${BACKEND_NAME}, model_global_lp_pool_p3)
...
@@ -409,3 +410,19 @@ NGRAPH_TEST(onnx_${BACKEND_NAME}, model_global_lp_pool_p3)
EXPECT_TRUE
(
test
::
all_close_f
(
expected_outputs
.
front
(),
outputs
.
front
()));
EXPECT_TRUE
(
test
::
all_close_f
(
expected_outputs
.
front
(),
outputs
.
front
()));
}
}
NGRAPH_TEST
(
onnx_
$
{
BACKEND_NAME
},
model_convtranspose_output_shape
)
{
auto
conv_transpose_fn
=
onnx_import
::
import_onnx_model
(
file_util
::
path_join
(
SERIALIZED_ZOO
,
"onnx/convtranspose_output_shape.prototxt"
));
auto
test_case
=
ngraph
::
test
::
NgraphTestCase
(
conv_transpose_fn
,
"${BACKEND_NAME}"
);
test_case
.
add_input_from_file
<
float
>
(
TEST_FILES
,
"onnx/convtranspose_output_shape/x.bin"
);
test_case
.
add_input_from_file
<
float
>
(
TEST_FILES
,
"onnx/convtranspose_output_shape/w.bin"
);
test_case
.
add_expected_output_from_file
<
float
>
(
{
1
,
2
,
10
,
8
},
TEST_FILES
,
"onnx/convtranspose_output_shape/y.bin"
);
test_case
.
dump_results
();
test_case
.
run
();
}
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