pybind_general_model.cpp 5.4 KB
Newer Older
M
MRXLT 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
// Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
//
// 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.

G
guru4elephant 已提交
15 16
#include <Python.h>
#include <pybind11/pybind11.h>
M
MRXLT 已提交
17
#include <pybind11/stl.h>
G
guru4elephant 已提交
18
#include <unordered_map>
G
guru4elephant 已提交
19
#include "core/general-client/include/general_model.h"
G
guru4elephant 已提交
20 21 22 23 24 25 26 27 28 29

namespace py = pybind11;

namespace baidu {
namespace paddle_serving {
namespace general_model {

PYBIND11_MODULE(serving_client, m) {
  m.doc() = R"pddoc(this is a practice
       )pddoc";
30 31 32 33

  py::class_<PredictorRes>(m, "PredictorRes", py::buffer_protocol())
      .def(py::init())
      .def("get_int64_by_name",
B
barrierye 已提交
34 35
           [](PredictorRes &self, int model_idx, std::string &name) {
             return self.get_int64_by_name(model_idx, name);
M
MRXLT 已提交
36 37
           },
           py::return_value_policy::reference)
38
      .def("get_float_by_name",
B
barrierye 已提交
39 40
           [](PredictorRes &self, int model_idx, std::string &name) {
             return self.get_float_by_name(model_idx, name);
M
MRXLT 已提交
41
           },
42
           py::return_value_policy::reference)
43
      .def("get_shape",
B
barrierye 已提交
44 45
           [](PredictorRes &self, int model_idx, std::string &name) {
             return self.get_shape(model_idx, name);
46 47 48
           },
           py::return_value_policy::reference)
      .def("get_lod",
B
barrierye 已提交
49 50
           [](PredictorRes &self, int model_idx, std::string &name) {
             return self.get_lod(model_idx, name);
51 52
           },
           py::return_value_policy::reference)
B
barrierye 已提交
53 54 55
      .def("variant_tag", [](PredictorRes &self) { return self.variant_tag(); })
      .def("get_engine_names",
           [](PredictorRes &self) { return self.get_engine_names(); });
56

G
guru4elephant 已提交
57 58
  py::class_<PredictorClient>(m, "PredictorClient", py::buffer_protocol())
      .def(py::init())
59 60 61 62
      .def("init_gflags",
           [](PredictorClient &self, std::vector<std::string> argv) {
             self.init_gflags(argv);
           })
G
guru4elephant 已提交
63
      .def("init",
M
MRXLT 已提交
64
           [](PredictorClient &self, const std::string &conf) {
65
             return self.init(conf);
G
guru4elephant 已提交
66 67
           })
      .def("set_predictor_conf",
M
MRXLT 已提交
68 69 70
           [](PredictorClient &self,
              const std::string &conf_path,
              const std::string &conf_file) {
G
guru4elephant 已提交
71 72
             self.set_predictor_conf(conf_path, conf_file);
           })
G
guru4elephant 已提交
73
      .def("create_predictor_by_desc",
M
MRXLT 已提交
74 75 76
           [](PredictorClient &self, const std::string &sdk_desc) {
             self.create_predictor_by_desc(sdk_desc);
           })
G
guru4elephant 已提交
77
      .def("create_predictor",
M
MRXLT 已提交
78
           [](PredictorClient &self) { self.create_predictor(); })
79 80
      .def("destroy_predictor",
           [](PredictorClient &self) { self.destroy_predictor(); })
M
MRXLT 已提交
81
      .def("batch_predict",
M
MRXLT 已提交
82 83 84 85
           [](PredictorClient &self,
              const std::vector<std::vector<std::vector<float>>>
                  &float_feed_batch,
              const std::vector<std::string> &float_feed_name,
D
dongdaxiang 已提交
86
              const std::vector<std::vector<int>> &float_shape,
M
MRXLT 已提交
87 88 89
              const std::vector<std::vector<std::vector<int64_t>>>
                  &int_feed_batch,
              const std::vector<std::string> &int_feed_name,
D
dongdaxiang 已提交
90
              const std::vector<std::vector<int>> &int_shape,
M
MRXLT 已提交
91
              const std::vector<std::string> &fetch_name,
M
MRXLT 已提交
92
              PredictorRes &predict_res_batch,
M
MRXLT 已提交
93
              const int &pid) {
M
MRXLT 已提交
94 95
             return self.batch_predict(float_feed_batch,
                                       float_feed_name,
D
dongdaxiang 已提交
96
                                       float_shape,
M
MRXLT 已提交
97 98
                                       int_feed_batch,
                                       int_feed_name,
D
dongdaxiang 已提交
99
                                       int_shape,
M
MRXLT 已提交
100
                                       fetch_name,
M
MRXLT 已提交
101
                                       predict_res_batch,
M
MRXLT 已提交
102
                                       pid);
M
MRXLT 已提交
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
           })
      .def("numpy_predict",
           [](PredictorClient &self,
              const std::vector<std::vector<py::array_t<float>>>
                  &float_feed_batch,
              const std::vector<std::string> &float_feed_name,
              const std::vector<std::vector<int>> &float_shape,
              const std::vector<std::vector<py::array_t<int64_t>>>
                  &int_feed_batch,
              const std::vector<std::string> &int_feed_name,
              const std::vector<std::vector<int>> &int_shape,
              const std::vector<std::string> &fetch_name,
              PredictorRes &predict_res_batch,
              const int &pid) {
             return self.numpy_predict(float_feed_batch,
                                       float_feed_name,
                                       float_shape,
                                       int_feed_batch,
                                       int_feed_name,
                                       int_shape,
                                       fetch_name,
                                       predict_res_batch,
                                       pid);
126 127
           },
           py::call_guard<py::gil_scoped_release>());
G
guru4elephant 已提交
128 129 130 131 132
}

}  // namespace general_model
}  // namespace paddle_serving
}  // namespace baidu