web_service.py 2.3 KB
Newer Older
B
barriery 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
# 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.
B
fix cpu  
barriery 已提交
14
try:
B
barriery 已提交
15
    from paddle_serving_server_gpu.web_service import WebService, Op
B
fix cpu  
barriery 已提交
16
except ImportError:
B
barriery 已提交
17
    from paddle_serving_server.web_service import WebService, Op
B
barriery 已提交
18 19
import logging
import numpy as np
T
TeslaZhao 已提交
20
import sys
B
barriery 已提交
21 22 23 24

_LOGGER = logging.getLogger()


B
barriery 已提交
25 26
class UciOp(Op):
    def init_op(self):
B
barriery 已提交
27 28
        self.separator = ","

29
    def preprocess(self, input_dicts, data_id, log_id):
B
barriery 已提交
30
        (_, input_dict), = input_dicts.items()
31 32
        _LOGGER.error("UciOp::preprocess >>> log_id:{}, input:{}".format(
            log_id, input_dict))
B
barriery 已提交
33
        x_value = input_dict["x"]
34
        proc_dict = {}
T
TeslaZhao 已提交
35 36 37 38 39 40 41 42 43 44 45 46
        if sys.version_info.major == 2:
            if isinstance(x_value, (str, unicode)):
                input_dict["x"] = np.array(
                    [float(x.strip())
                     for x in x_value.split(self.separator)]).reshape(1, 13)
                _LOGGER.error("input_dict:{}".format(input_dict))
        else:
            if isinstance(x_value, str):
                input_dict["x"] = np.array(
                    [float(x.strip())
                     for x in x_value.split(self.separator)]).reshape(1, 13)
                _LOGGER.error("input_dict:{}".format(input_dict))
B
barriery 已提交
47

48 49 50 51 52
        return input_dict, False, None, ""

    def postprocess(self, input_dicts, fetch_dict, log_id):
        _LOGGER.info("UciOp::postprocess >>> log_id:{}, fetch_dict:{}".format(
            log_id, fetch_dict))
B
barriery 已提交
53
        fetch_dict["price"] = str(fetch_dict["price"][0][0])
54
        return fetch_dict, None, ""
B
barriery 已提交
55 56


B
barriery 已提交
57 58 59 60 61 62
class UciService(WebService):
    def get_pipeline_response(self, read_op):
        uci_op = UciOp(name="uci", input_ops=[read_op])
        return uci_op


B
barriery 已提交
63
uci_service = UciService(name="uci")
B
barriery 已提交
64
uci_service.prepare_pipeline_config("config.yml")
B
barriery 已提交
65
uci_service.run_service()