$ hub install mobilenet_v3_large_imagenet_ssld==1.0.0
hub run mobilenet_v3_large_imagenet_ssld --input_path "/PATH/TO/IMAGE"
def get_expected_image_width()
返回预处理的图片宽度,也就是224。
def get_expected_image_height()
返回预处理的图片高度,也就是224。
def get_pretrained_images_mean()
返回预处理的图片均值,也就是 [0.485, 0.456, 0.406]。
def get_pretrained_images_std()
返回预处理的图片标准差,也就是 [0.229, 0.224, 0.225]。
def context(trainable=True, pretrained=True)
参数
返回
def classification(images=None,
paths=None,
batch_size=1,
use_gpu=False,
top_k=1):
参数
返回
res (list[dict]): 分类结果,列表的每一个元素均为字典,其中 key 为识别动物的类别,value为置信度。
def save_inference_model(dirname,
model_filename=None,
params_filename=None,
combined=True)
将模型保存到指定路径。
参数
combined
为True时生效)import paddlehub as hub
import cv2
classifier = hub.Module(name="mobilenet_v3_large_imagenet_ssld")
result = classifier.classification(images=[cv2.imread('/PATH/TO/IMAGE')])
# or
# result = classifier.classification(paths=['/PATH/TO/IMAGE'])
PaddleHub Serving可以部署一个在线动物识别服务。
运行启动命令:
$ hub serving start -m mobilenet_v3_large_imagenet_ssld
这样就完成了一个在线动物识别服务化API的部署,默认端口号为8866。
NOTE: 如使用GPU预测,则需要在启动服务之前,请设置CUDA_VISIBLE_DEVICES环境变量,否则不用设置。
配置好服务端,以下数行代码即可实现发送预测请求,获取预测结果
import requests
import json
import cv2
import base64
def cv2_to_base64(image):
data = cv2.imencode('.jpg', image)[1]
return base64.b64encode(data.tostring()).decode('utf8')
# 发送HTTP请求
data = {'images':[cv2_to_base64(cv2.imread("/PATH/TO/IMAGE"))]}
headers = {"Content-type": "application/json"}
url = "http://127.0.0.1:8866/predict/mobilenet_v3_large_imagenet_ssld"
r = requests.post(url=url, headers=headers, data=json.dumps(data))
# 打印预测结果
print(r.json()["results"])
paddlepaddle >= 1.6.2
paddlehub >= 1.6.0