README.md 4.0 KB
Newer Older
1
# resnet50_vd_wildanimals
W
wuzewu 已提交
2

3 4 5 6 7 8 9 10 11
|模型名称|resnet50_vd_wildanimals|
| :--- | :---: |
|类别|图像-图像分类|
|网络|ResNet_vd|
|数据集|IFAW 自建野生动物数据集|
|是否支持Fine-tuning|否|
|模型大小|92MB|
|最新更新日期|-|
|数据指标|-|
W
wuzewu 已提交
12 13


14
## 一、模型基本信息
W
wuzewu 已提交
15 16 17



18
- ### 模型介绍
W
wuzewu 已提交
19

20
  - ResNet-vd 其实就是 ResNet-D,是ResNet 原始结构的变种,可用于图像分类和特征提取。该 PaddleHub Module 采用百度自建野生动物数据集训练得到,支持'象牙制品','象牙', '大象', '虎皮', '老虎', '虎牙/虎爪/虎骨', '穿山甲甲片', '穿山甲', '穿山甲爪子', '其他' 这十个标签的识别。模型的详情可参考[论文](https://arxiv.org/pdf/1812.01187.pdf)
W
wuzewu 已提交
21 22 23



24
## 二、安装
W
wuzewu 已提交
25

26
- ### 1、环境依赖  
W
wuzewu 已提交
27

28
  - paddlepaddle >= 1.6.2  
W
wuzewu 已提交
29

30
  - paddlehub >= 1.6.0  | [如何安装paddlehub](../../../../docs/docs_ch/get_start/installation.rst)
W
wuzewu 已提交
31 32


33
- ### 2、安装
W
wuzewu 已提交
34

35 36 37 38 39
  - ```shell
    $ hub install resnet50_vd_wildanimals
    ```
  - 如您安装时遇到问题,可参考:[零基础windows安装](../../../../docs/docs_ch/get_start/windows_quickstart.md)
 | [零基础Linux安装](../../../../docs/docs_ch/get_start/linux_quickstart.md) | [零基础MacOS安装](../../../../docs/docs_ch/get_start/mac_quickstart.md)
W
wuzewu 已提交
40

41
## 三、模型API预测
W
wuzewu 已提交
42

43
- ### 1、命令行预测
W
wuzewu 已提交
44

45 46 47 48
  - ```shell
    $ hub run resnet50_vd_wildanimals --input_path "/PATH/TO/IMAGE"
    ```
  - 通过命令行方式实现分类模型的调用,更多请见 [PaddleHub命令行指令](../../../../docs/docs_ch/tutorial/cmd_usage.rst)
W
wuzewu 已提交
49

50
- ### 2、预测代码示例
W
wuzewu 已提交
51

52 53 54
  - ```python
    import paddlehub as hub
    import cv2
W
wuzewu 已提交
55

56 57 58 59 60
    classifier = hub.Module(name="resnet50_vd_wildanimals")
    result = classifier.classification(images=[cv2.imread('/PATH/TO/IMAGE')])
    # or
    # result = classifier.classification(paths=['/PATH/TO/IMAGE'])
    ```
W
wuzewu 已提交
61

62
- ### 3、API
W
wuzewu 已提交
63 64


65 66 67 68 69 70 71 72 73
  - ```python
    def classification(images=None,
                       paths=None,
                       batch_size=1,
                       use_gpu=False,
                       top_k=1):
    ```
    - 分类接口API。
    - **参数**
W
wuzewu 已提交
74

75 76 77 78 79
      - images (list\[numpy.ndarray\]): 图片数据,每一个图片数据的shape 均为 \[H, W, C\],颜色空间为 BGR; <br/>
      - paths (list\[str\]): 图片的路径; <br/>
      - batch\_size (int): batch 的大小;<br/>
      - use\_gpu (bool): 是否使用 GPU;**若使用GPU,请先设置CUDA_VISIBLE_DEVICES环境变量** <br/>
      - top\_k (int): 返回预测结果的前 k 个。
W
wuzewu 已提交
80

81
    - **返回**
W
wuzewu 已提交
82

83
      - res (list\[dict\]): 分类结果,列表的每一个元素均为字典,其中 key 为识别的菜品类别,value为置信度。
W
wuzewu 已提交
84 85 86



87
## 四、服务部署
W
wuzewu 已提交
88

89
- PaddleHub Serving可以部署一个野生动物及其制品识别的在线服务。
W
wuzewu 已提交
90

91
- ### 第一步:启动PaddleHub Serving
W
wuzewu 已提交
92

93 94 95 96
  - 运行启动命令:
  - ```shell
    $ hub serving start -m resnet50_vd_wildanimals
    ```
W
wuzewu 已提交
97

98
  - 这样就完成了一个野生动物及其制品识别的在线服务的部署,默认端口号为8866。
W
wuzewu 已提交
99

100
  - **NOTE:** 如使用GPU预测,则需要在启动服务之前,请设置CUDA\_VISIBLE\_DEVICES环境变量,否则不用设置。
W
wuzewu 已提交
101

102
- ### 第二步:发送预测请求
W
wuzewu 已提交
103

104
  - 配置好服务端,以下数行代码即可实现发送预测请求,获取预测结果
W
wuzewu 已提交
105

106 107 108 109 110
  - ```python
    import requests
    import json
    import cv2
    import base64
W
wuzewu 已提交
111

112 113 114
    def cv2_to_base64(image):
        data = cv2.imencode('.jpg', image)[1]
        return base64.b64encode(data.tostring()).decode('utf8')
W
wuzewu 已提交
115

116 117 118 119 120
    # 发送HTTP请求
    data = {'images':[cv2_to_base64(cv2.imread("/PATH/TO/IMAGE"))]}
    headers = {"Content-type": "application/json"}
    url = "http://127.0.0.1:8866/predict/resnet50_vd_wildanimals"
    r = requests.post(url=url, headers=headers, data=json.dumps(data))
W
wuzewu 已提交
121

122 123 124
    # 打印预测结果
    print(r.json()["results"])
    ```
W
wuzewu 已提交
125 126


127
## 五、更新历史
W
wuzewu 已提交
128

129
* 1.0.0
W
wuzewu 已提交
130

131
  初始发布
jm_12138's avatar
jm_12138 已提交
132 133 134 135 136

* 1.1.0

  移除 Fluid API

137
  - ```shell
jm_12138's avatar
jm_12138 已提交
138
    $ hub install resnet50_vd_wildanimals==1.1.0
139
    ```