paddlehub环境搭建和测试

目录

  • 1.环境搭建
    • [1.1 创建conda环境](#1.1 创建conda环境)
    • [1.2 安装paddlepaddle和paddlehub](#1.2 安装paddlepaddle和paddlehub)
    • [1.3 安装依赖](#1.3 安装依赖)
  • [2. 移动端模型部署](#2. 移动端模型部署)
    • [2.1 安装移动端模型](#2.1 安装移动端模型)
    • [2.2 测试](#2.2 测试)
  • [3. 服务部署](#3. 服务部署)
    • [3.1 启动PaddleHub Serving](#3.1 启动PaddleHub Serving)
    • [3.2 发送预测请求](#3.2 发送预测请求)

1.环境搭建

1.1 创建conda环境

bash 复制代码
conda create --name paddlehub python=3.8
conda activate paddlehub

1.2 安装paddlepaddle和paddlehub

bash 复制代码
pip install paddlepaddle -i https://pypi.tuna.tsinghua.edu.cn/simple
pip install paddlehub -i https://pypi.tuna.tsinghua.edu.cn/simple

1.3 安装依赖

bash 复制代码
pip install shapely pyclipper

2. 移动端模型部署

2.1 安装移动端模型

bash 复制代码
hub install chinese_ocr_db_crnn_mobile

报错1:

增加download函数

bash 复制代码
vim /home/yinsuan/miniconda3/envs/paddlehub/lib/python3.8/site-packages/aistudio_sdk/hub.py 
python 复制代码
def download(url, target_path):
    os.makedirs(os.path.dirname(target_path), exist_ok=True)
    response = requests.get(url, stream=True)
    with open(target_path, 'wb') as f:
        for chunk in response.iter_content(chunk_size=1024):
            if chunk:
                f.write(chunk)
    print(f"Downloaded {url} to {target_path}")

报错2:

bash 复制代码
export PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python

安装成功

2.2 测试

将其中的np.int 修改为int即可

bash 复制代码
vim /home/yinsuan/.paddlehub/modules/chinese_ocr_db_crnn_mobile/module.py
bash 复制代码
hub run chinese_ocr_db_crnn_mobile --input_path "/PATH/TO/IMAGE"

测试成功

3. 服务部署

3.1 启动PaddleHub Serving

bash 复制代码
hub serving start -m chinese_ocr_db_crnn_mobile

3.2 发送预测请求

bash 复制代码
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/chinese_ocr_db_crnn_mobile"
r = requests.post(url=url, headers=headers, data=json.dumps(data))

# 打印预测结果
print(r.json()["results"])

参考:https://www.paddlepaddle.org.cn/hubdetail?name=chinese_ocr_db_crnn_mobile&en_category=TextRecognition

相关推荐
cooldream200912 小时前
「源力觉醒 创作者计划」_基于 PaddlePaddle 部署 ERNIE-4.5-0.3B 轻量级大模型实战指南
人工智能·paddlepaddle·文心大模型
云天徽上4 天前
【PaddleOCR】OCR常见关键信息抽取数据集,包含FUNSD、XFUND、WildReceipt等整理,持续更新中......
人工智能·计算机视觉·信息可视化·paddlepaddle·paddleocr·文本识别
Sliphades4 天前
PaddleOCR独立服务:高效OCR一站式解决方案
paddlepaddle·ai ocr
univerbright18 天前
百度飞桨(PaddlePaddle)案例分享:基于 PaddleOCR 的图像文字提取系统
人工智能·百度·paddlepaddle·paddleocr·图像文字提取
一颗红心丶20 天前
Windows系统上离线部署Python运行飞桨(PaddlePaddle) OCR服务
windows·python·paddlepaddle
红酒暖心也暖胃20 天前
PaddleOCR环境安装-踩坑记录
paddlepaddle·paddleocr·踩坑
Zheng.Zeng1 个月前
第一篇:Liunx环境下搭建PaddlePaddle 3.0基础环境(Liunx Centos8.5安装Python3.10+pip3.10)
人工智能·paddlepaddle
DisonTangor1 个月前
百度飞桨PaddleOCR 3.0开源发布 OCR精度跃升13%
百度·ocr·paddlepaddle
米饭咔咔吃2 个月前
飞桨paddle import fluid报错【已解决】
人工智能·paddlepaddle·paddle