Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
T
tic
Overview
Overview
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
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wenyuanbo
tic
Commits
19cf5c66
Unverified
Commit
19cf5c66
authored
Aug 11, 2018
by
Tianqi Chen
Committed by
GitHub
Aug 11, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[DLPACK] Enable cython support (#1589)
parent
ec3f09b3
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
112 additions
and
46 deletions
+112
-46
HalideIR
+1
-1
include/tvm/runtime/c_runtime_api.h
+0
-0
python/tvm/_ffi/_ctypes/ndarray.py
+48
-1
python/tvm/_ffi/_cython/base.pxi
+12
-1
python/tvm/_ffi/_cython/ndarray.pxi
+38
-0
python/tvm/_ffi/ndarray.py
+5
-43
tests/scripts/task_python_nnvm.sh
+4
-0
tests/scripts/task_python_topi.sh
+4
-0
No files found.
HalideIR
@
a0b9563f
Subproject commit a
5a80bdc8232c9dbfe508bb5c46e8f58cdf7ec2
0
Subproject commit a
0b9563f45719553adf4d39fe3c14db1af0e1f4
0
include/tvm/runtime/c_runtime_api.h
View file @
19cf5c66
python/tvm/_ffi/_ctypes/ndarray.py
View file @
19cf5c66
# pylint: disable=invalid-name
"""Runtime NDArray api"""
"""Runtime NDArray api"""
from
__future__
import
absolute_import
from
__future__
import
absolute_import
import
ctypes
import
ctypes
from
..base
import
_LIB
,
check_call
from
..base
import
_LIB
,
check_call
,
c_str
from
..runtime_ctypes
import
TVMArrayHandle
from
..runtime_ctypes
import
TVMArrayHandle
from
.types
import
RETURN_SWITCH
,
C_TO_PY_ARG_SWITCH
,
_wrap_arg_func
,
_return_handle
from
.types
import
RETURN_SWITCH
,
C_TO_PY_ARG_SWITCH
,
_wrap_arg_func
,
_return_handle
TVMPyCapsuleDestructor
=
ctypes
.
CFUNCTYPE
(
None
,
ctypes
.
c_void_p
)
_c_str_dltensor
=
c_str
(
'dltensor'
)
_c_str_used_dltensor
=
c_str
(
'used_dltensor'
)
# used for PyCapsule manipulation
if
hasattr
(
ctypes
,
'pythonapi'
):
ctypes
.
pythonapi
.
PyCapsule_GetName
.
restype
=
ctypes
.
c_char_p
ctypes
.
pythonapi
.
PyCapsule_GetPointer
.
restype
=
ctypes
.
c_void_p
ctypes
.
pythonapi
.
PyCapsule_New
.
restype
=
ctypes
.
py_object
def
_from_dlpack
(
dltensor
):
dltensor
=
ctypes
.
py_object
(
dltensor
)
if
ctypes
.
pythonapi
.
PyCapsule_IsValid
(
dltensor
,
_c_str_dltensor
):
ptr
=
ctypes
.
pythonapi
.
PyCapsule_GetPointer
(
dltensor
,
_c_str_dltensor
)
handle
=
TVMArrayHandle
()
check_call
(
_LIB
.
TVMArrayFromDLPack
(
ptr
,
ctypes
.
byref
(
handle
)))
ctypes
.
pythonapi
.
PyCapsule_SetName
(
dltensor
,
_c_str_used_dltensor
)
ctypes
.
pythonapi
.
PyCapsule_SetDestructor
(
dltensor
,
TVMPyCapsuleDestructor
(
0
))
return
_make_array
(
handle
,
False
)
raise
ValueError
(
"Expect a dltensor field, PyCapsule can only be consumed once"
)
def
_dlpack_deleter
(
pycapsule
):
pycapsule
=
ctypes
.
cast
(
pycapsule
,
ctypes
.
py_object
)
if
ctypes
.
pythonapi
.
PyCapsule_IsValid
(
pycapsule
,
_c_str_dltensor
):
ptr
=
ctypes
.
pythonapi
.
PyCapsule_GetPointer
(
pycapsule
,
_c_str_dltensor
)
_LIB
.
TVMDLManagedTensorCallDeleter
(
ptr
)
ctypes
.
pythonapi
.
PyCapsule_SetDestructor
(
dltensor
,
TVMPyCapsuleDestructor
(
0
))
_c_dlpack_deleter
=
TVMPyCapsuleDestructor
(
_dlpack_deleter
)
class
NDArrayBase
(
object
):
class
NDArrayBase
(
object
):
"""A simple Device/CPU Array object in runtime."""
"""A simple Device/CPU Array object in runtime."""
__slots__
=
[
"handle"
,
"is_view"
]
__slots__
=
[
"handle"
,
"is_view"
]
...
@@ -29,6 +65,17 @@ class NDArrayBase(object):
...
@@ -29,6 +65,17 @@ class NDArrayBase(object):
def
_tvm_handle
(
self
):
def
_tvm_handle
(
self
):
return
ctypes
.
cast
(
self
.
handle
,
ctypes
.
c_void_p
)
.
value
return
ctypes
.
cast
(
self
.
handle
,
ctypes
.
c_void_p
)
.
value
def
to_dlpack
(
self
):
"""Produce an array from a DLPack Tensor without copying memory
Returns
-------
dlpack : DLPack tensor view of the array data
"""
handle
=
ctypes
.
c_void_p
()
check_call
(
_LIB
.
TVMArrayToDLPack
(
self
.
handle
,
ctypes
.
byref
(
handle
)))
return
ctypes
.
pythonapi
.
PyCapsule_New
(
handle
,
_c_str_dltensor
,
_c_dlpack_deleter
)
def
_make_array
(
handle
,
is_view
):
def
_make_array
(
handle
,
is_view
):
handle
=
ctypes
.
cast
(
handle
,
TVMArrayHandle
)
handle
=
ctypes
.
cast
(
handle
,
TVMArrayHandle
)
...
...
python/tvm/_ffi/_cython/base.pxi
View file @
19cf5c66
from ..base import TVMError
from ..base import TVMError
from libcpp.vector cimport vector
from libcpp.vector cimport vector
from cpython.version cimport PY_MAJOR_VERSION
from cpython.version cimport PY_MAJOR_VERSION
from cpython cimport pycapsule
from libc.stdint cimport int64_t, uint64_t, uint8_t, uint16_t
from libc.stdint cimport int64_t, uint64_t, uint8_t, uint16_t
import ctypes
import ctypes
...
@@ -40,6 +41,11 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
...
@@ -40,6 +41,11 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
int64_t* strides
int64_t* strides
uint64_t byte_offset
uint64_t byte_offset
ctypedef struct DLManagedTensor:
DLTensor dl_tensor
void* manager_ctx
void (*deleter)(DLManagedTensor* self)
ctypedef struct TVMValue:
ctypedef struct TVMValue:
int64_t v_int64
int64_t v_int64
double v_float64
double v_float64
...
@@ -49,7 +55,7 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
...
@@ -49,7 +55,7 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
DLContext v_ctx
DLContext v_ctx
ctypedef int64_t tvm_index_t
ctypedef int64_t tvm_index_t
ctypedef
void
* DLTensorHandle
ctypedef
DLTensor
* DLTensorHandle
ctypedef void* TVMStreamHandle
ctypedef void* TVMStreamHandle
ctypedef void* TVMRetValueHandle
ctypedef void* TVMRetValueHandle
ctypedef void* TVMFunctionHandle
ctypedef void* TVMFunctionHandle
...
@@ -92,6 +98,11 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
...
@@ -92,6 +98,11 @@ cdef extern from "tvm/runtime/c_runtime_api.h":
int TVMArrayCopyFromTo(DLTensorHandle src,
int TVMArrayCopyFromTo(DLTensorHandle src,
DLTensorHandle to,
DLTensorHandle to,
TVMStreamHandle stream)
TVMStreamHandle stream)
int TVMArrayFromDLPack(DLManagedTensor* arr_from,
DLTensorHandle* out)
int TVMArrayToDLPack(DLTensorHandle arr_from,
DLManagedTensor** out)
void TVMDLManagedTensorCallDeleter(DLManagedTensor* dltensor)
cdef extern from "tvm/c_dsl_api.h":
cdef extern from "tvm/c_dsl_api.h":
int TVMNodeFree(NodeHandle handle)
int TVMNodeFree(NodeHandle handle)
...
...
python/tvm/_ffi/_cython/ndarray.pxi
View file @
19cf5c66
from ..runtime_ctypes import TVMArrayHandle
from ..runtime_ctypes import TVMArrayHandle
cdef const char* _c_str_dltensor = "dltensor"
cdef const char* _c_str_used_dltensor = "used_dltensor"
cdef void _c_dlpack_deleter(object pycaps):
cdef DLManagedTensor* dltensor
if pycapsule.PyCapsule_IsValid(pycaps, _c_str_dltensor):
dltensor = <DLManagedTensor*>pycapsule.PyCapsule_GetPointer(pycaps, _c_str_dltensor)
TVMDLManagedTensorCallDeleter(dltensor)
def _from_dlpack(object dltensor):
cdef DLManagedTensor* ptr
cdef DLTensorHandle chandle
if pycapsule.PyCapsule_IsValid(dltensor, _c_str_dltensor):
ptr = <DLManagedTensor*>pycapsule.PyCapsule_GetPointer(dltensor, _c_str_dltensor)
CALL(TVMArrayFromDLPack(ptr, &chandle))
# set name and destructor to be empty
pycapsule.PyCapsule_SetDestructor(dltensor, NULL)
pycapsule.PyCapsule_SetName(dltensor, _c_str_used_dltensor)
return c_make_array(chandle, 0)
raise ValueError("Expect a dltensor field, pycapsule.PyCapsule can only be consumed once")
cdef class NDArrayBase:
cdef class NDArrayBase:
cdef DLTensor* chandle
cdef DLTensor* chandle
cdef int c_is_view
cdef int c_is_view
...
@@ -35,12 +59,26 @@ cdef class NDArrayBase:
...
@@ -35,12 +59,26 @@ cdef class NDArrayBase:
if self.c_is_view == 0:
if self.c_is_view == 0:
CALL(TVMArrayFree(self.chandle))
CALL(TVMArrayFree(self.chandle))
def to_dlpack(self):
"""Produce an array from a DLPack Tensor without copying memory
Returns
-------
dlpack : DLPack tensor view of the array data
"""
cdef DLManagedTensor* dltensor
if self.c_is_view != 0:
raise ValueError("to_dlpack do not work with memory views")
CALL(TVMArrayToDLPack(self.chandle, &dltensor))
return pycapsule.PyCapsule_New(dltensor, _c_str_dltensor, _c_dlpack_deleter)
cdef c_make_array(void* chandle, is_view):
cdef c_make_array(void* chandle, is_view):
ret = _CLASS_NDARRAY(None, is_view)
ret = _CLASS_NDARRAY(None, is_view)
(<NDArrayBase>ret).chandle = <DLTensor*>chandle
(<NDArrayBase>ret).chandle = <DLTensor*>chandle
return ret
return ret
cdef _TVM_COMPATS = ()
cdef _TVM_COMPATS = ()
cdef _TVM_EXT_RET = {}
cdef _TVM_EXT_RET = {}
...
...
python/tvm/_ffi/ndarray.py
View file @
19cf5c66
...
@@ -17,28 +17,17 @@ try:
...
@@ -17,28 +17,17 @@ try:
if
_FFI_MODE
==
"ctypes"
:
if
_FFI_MODE
==
"ctypes"
:
raise
ImportError
()
raise
ImportError
()
if
sys
.
version_info
>=
(
3
,
0
):
if
sys
.
version_info
>=
(
3
,
0
):
from
._cy3.core
import
_set_class_ndarray
,
_reg_extension
,
_make_array
from
._cy3.core
import
_set_class_ndarray
,
_reg_extension
,
_make_array
,
_from_dlpack
from
._cy3.core
import
NDArrayBase
as
_NDArrayBase
from
._cy3.core
import
NDArrayBase
as
_NDArrayBase
else
:
else
:
from
._cy2.core
import
_set_class_ndarray
,
_reg_extension
,
_make_array
from
._cy2.core
import
_set_class_ndarray
,
_reg_extension
,
_make_array
,
_from_dlpack
from
._cy2.core
import
NDArrayBase
as
_NDArrayBase
from
._cy2.core
import
NDArrayBase
as
_NDArrayBase
except
IMPORT_EXCEPT
:
except
IMPORT_EXCEPT
:
# pylint: disable=wrong-import-position
# pylint: disable=wrong-import-position
from
._ctypes.ndarray
import
_set_class_ndarray
,
_reg_extension
,
_make_array
from
._ctypes.ndarray
import
_set_class_ndarray
,
_reg_extension
,
_make_array
,
_from_dlpack
from
._ctypes.ndarray
import
NDArrayBase
as
_NDArrayBase
from
._ctypes.ndarray
import
NDArrayBase
as
_NDArrayBase
TVMPyCapsuleDestructor
=
ctypes
.
CFUNCTYPE
(
None
,
ctypes
.
c_void_p
)
_c_str_dltensor
=
c_str
(
'dltensor'
)
# used for PyCapsule manipulation
if
hasattr
(
ctypes
,
'pythonapi'
):
ctypes
.
pythonapi
.
PyCapsule_GetName
.
restype
=
ctypes
.
c_char_p
ctypes
.
pythonapi
.
PyCapsule_GetPointer
.
restype
=
ctypes
.
c_void_p
ctypes
.
pythonapi
.
PyCapsule_New
.
restype
=
ctypes
.
py_object
def
context
(
dev_type
,
dev_id
=
0
):
def
context
(
dev_type
,
dev_id
=
0
):
"""Construct a TVM context with given device type and id.
"""Construct a TVM context with given device type and id.
...
@@ -134,30 +123,14 @@ def from_dlpack(dltensor):
...
@@ -134,30 +123,14 @@ def from_dlpack(dltensor):
Parameters
Parameters
----------
----------
dltensor : DLPack tensor
dltensor : DLPack tensor
Input DLManagedTensor, can only be consumed once.
Returns
Returns
-------
-------
arr: tvm.nd.NDArray
arr: tvm.nd.NDArray
The array view of the tensor data.
The array view of the tensor data.
"""
"""
dltensor
=
ctypes
.
py_object
(
dltensor
)
return
_from_dlpack
(
dltensor
)
name
=
ctypes
.
pythonapi
.
PyCapsule_GetName
(
dltensor
)
ptr
=
ctypes
.
pythonapi
.
PyCapsule_GetPointer
(
dltensor
,
name
)
handle
=
TVMArrayHandle
()
check_call
(
_LIB
.
TVMArrayFromDLPack
(
ptr
,
ctypes
.
byref
(
handle
)))
ctypes
.
pythonapi
.
PyCapsule_SetDestructor
(
dltensor
,
None
)
return
_make_array
(
handle
,
False
)
def
_dlpack_deleter
(
pycapsule
):
pycapsule
=
ctypes
.
py_object
(
pycapsule
)
if
ctypes
.
pythonapi
.
PyCapsule_IsValid
(
pycapsule
,
_c_str_dltensor
):
ptr
=
ctypes
.
pythonapi
.
PyCapsule_GetPointer
(
pycapsule
,
_c_str_dltensor
)
_LIB
.
TVMDLManagedTensorCallDeleter
(
ptr
)
ctypes
.
pythonapi
.
PyCapsule_SetDestructor
(
dltensor
,
TVMPyCapsuleDestructor
(
0
))
_c_dlpack_deleter
=
TVMPyCapsuleDestructor
(
_dlpack_deleter
)
class
NDArrayBase
(
_NDArrayBase
):
class
NDArrayBase
(
_NDArrayBase
):
...
@@ -308,17 +281,6 @@ class NDArrayBase(_NDArrayBase):
...
@@ -308,17 +281,6 @@ class NDArrayBase(_NDArrayBase):
raise
ValueError
(
"Unsupported target type
%
s"
%
str
(
type
(
target
)))
raise
ValueError
(
"Unsupported target type
%
s"
%
str
(
type
(
target
)))
return
target
return
target
def
to_dlpack
(
self
):
"""Produce an array from a DLPack Tensor without copying memory
Returns
-------
dlpack : DLPack tensor view of the array data
"""
handle
=
ctypes
.
c_void_p
()
check_call
(
_LIB
.
TVMArrayToDLPack
(
self
.
handle
,
ctypes
.
byref
(
handle
)))
return
ctypes
.
pythonapi
.
PyCapsule_New
(
handle
,
_c_str_dltensor
,
_c_dlpack_deleter
)
def
free_extension_handle
(
handle
,
type_code
):
def
free_extension_handle
(
handle
,
type_code
):
"""Free c++ extension type handle
"""Free c++ extension type handle
...
...
tests/scripts/task_python_nnvm.sh
View file @
19cf5c66
...
@@ -4,6 +4,10 @@ export PYTHONPATH=nnvm/python:python:topi/python
...
@@ -4,6 +4,10 @@ export PYTHONPATH=nnvm/python:python:topi/python
# to avoid openblas threading error
# to avoid openblas threading error
export
OMP_NUM_THREADS
=
1
export
OMP_NUM_THREADS
=
1
# Rebuild cython
make cython
||
exit
-1
make cython3
||
exit
-1
echo
"Running unittest..."
echo
"Running unittest..."
python
-m
nose
-v
nnvm/tests/python/unittest
||
exit
-1
python
-m
nose
-v
nnvm/tests/python/unittest
||
exit
-1
python3
-m
nose
-v
nnvm/tests/python/unittest
||
exit
-1
python3
-m
nose
-v
nnvm/tests/python/unittest
||
exit
-1
...
...
tests/scripts/task_python_topi.sh
View file @
19cf5c66
export
PYTHONPATH
=
python:topi/python
export
PYTHONPATH
=
python:topi/python
# Rebuild cython
make cython
||
exit
-1
make cython3
||
exit
-1
python
-m
nose
-v
topi/tests/python
||
exit
-1
python
-m
nose
-v
topi/tests/python
||
exit
-1
python3
-m
nose
-v
topi/tests/python
||
exit
-1
python3
-m
nose
-v
topi/tests/python
||
exit
-1
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