|
|
|
@ -11,11 +11,16 @@ 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 <algorithm>
|
|
|
|
|
#include <map>
|
|
|
|
|
#include <mutex> // NOLINT // for call_once
|
|
|
|
|
#include <string>
|
|
|
|
|
#include <unordered_map>
|
|
|
|
|
#include <utility>
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
|
#include "paddle/fluid/pybind/protobuf.h"
|
|
|
|
|
|
|
|
|
|
#include <mutex> // for call_once
|
|
|
|
|
#include <unordered_map>
|
|
|
|
|
#include "paddle/fluid/framework/backward.h"
|
|
|
|
|
#include "paddle/fluid/framework/channel.h"
|
|
|
|
|
#include "paddle/fluid/framework/executor.h"
|
|
|
|
@ -32,7 +37,6 @@ limitations under the License. */
|
|
|
|
|
#include "paddle/fluid/operators/cond_op.h"
|
|
|
|
|
#include "paddle/fluid/operators/net_op.h"
|
|
|
|
|
#include "paddle/fluid/platform/enforce.h"
|
|
|
|
|
#include "paddle/fluid/platform/gpu_info.h"
|
|
|
|
|
#include "paddle/fluid/platform/place.h"
|
|
|
|
|
#include "paddle/fluid/platform/profiler.h"
|
|
|
|
|
#include "paddle/fluid/pybind/const_value.h"
|
|
|
|
@ -100,6 +104,14 @@ PYBIND11_PLUGIN(core) {
|
|
|
|
|
[](Tensor &self, paddle::platform::CUDAPlace &place) {
|
|
|
|
|
self.mutable_data<int>(place);
|
|
|
|
|
})
|
|
|
|
|
.def("alloc_int",
|
|
|
|
|
[](Tensor &self, paddle::platform::CUDAPinnedPlace &place) {
|
|
|
|
|
self.mutable_data<int>(place);
|
|
|
|
|
})
|
|
|
|
|
.def("alloc_float",
|
|
|
|
|
[](Tensor &self, paddle::platform::CUDAPinnedPlace &place) {
|
|
|
|
|
self.mutable_data<float>(place);
|
|
|
|
|
})
|
|
|
|
|
.def("set", PyCPUTensorSetFromArray<float>)
|
|
|
|
|
.def("set", PyCPUTensorSetFromArray<int>)
|
|
|
|
|
.def("set", PyCPUTensorSetFromArray<double>)
|
|
|
|
@ -317,7 +329,17 @@ All parameter, weight, gradient are variables in Paddle.
|
|
|
|
|
#else
|
|
|
|
|
return new paddle::platform::CUDADeviceContext(place);
|
|
|
|
|
#endif
|
|
|
|
|
});
|
|
|
|
|
})
|
|
|
|
|
.def_static("create",
|
|
|
|
|
[](paddle::platform::CUDAPinnedPlace& place)
|
|
|
|
|
-> paddle::platform::DeviceContext* {
|
|
|
|
|
#ifndef PADDLE_WITH_CUDA
|
|
|
|
|
PADDLE_THROW(
|
|
|
|
|
"CUDAPinnedPlace is not supported in CPU device.");
|
|
|
|
|
#else
|
|
|
|
|
return new paddle::platform::CUDAPinnedDeviceContext(place);
|
|
|
|
|
#endif
|
|
|
|
|
});;
|
|
|
|
|
// clang-format on
|
|
|
|
|
#ifdef PADDLE_WITH_CUDA
|
|
|
|
|
py::class_<platform::Communicator>(m, "Communicator").def(py::init<>());
|
|
|
|
@ -330,6 +352,10 @@ All parameter, weight, gradient are variables in Paddle.
|
|
|
|
|
.def(py::init<>())
|
|
|
|
|
.def("__str__", string::to_string<const platform::CPUPlace &>);
|
|
|
|
|
|
|
|
|
|
py::class_<paddle::platform::CUDAPinnedPlace>(m, "CUDAPinnedPlace")
|
|
|
|
|
.def(py::init<>())
|
|
|
|
|
.def("__str__", string::to_string<const platform::CUDAPinnedPlace &>);
|
|
|
|
|
|
|
|
|
|
py::class_<platform::Place>(m, "Place")
|
|
|
|
|
.def(py::init<>())
|
|
|
|
|
.def("set_place",
|
|
|
|
@ -339,6 +365,10 @@ All parameter, weight, gradient are variables in Paddle.
|
|
|
|
|
.def("set_place",
|
|
|
|
|
[](platform::Place &self, const platform::CUDAPlace &gpu_place) {
|
|
|
|
|
self = gpu_place;
|
|
|
|
|
})
|
|
|
|
|
.def("set_place", [](platform::Place &self,
|
|
|
|
|
const platform::CUDAPinnedPlace &gpu_place) {
|
|
|
|
|
self = gpu_place;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
py::class_<OperatorBase>(m, "Operator")
|
|
|
|
@ -363,6 +393,11 @@ All parameter, weight, gradient are variables in Paddle.
|
|
|
|
|
.def("run",
|
|
|
|
|
[](OperatorBase &self, const Scope &scope,
|
|
|
|
|
const platform::CUDAPlace &place) { self.Run(scope, place); })
|
|
|
|
|
.def("run",
|
|
|
|
|
[](OperatorBase &self, const Scope &scope,
|
|
|
|
|
const platform::CUDAPinnedPlace &place) {
|
|
|
|
|
self.Run(scope, place);
|
|
|
|
|
})
|
|
|
|
|
.def("type",
|
|
|
|
|
[](const OperatorBase &op) -> std::string { return op.Type(); })
|
|
|
|
|
.def("outputs",
|
|
|
|
|