• PaddleOCR实验过程记录


    一、环境准备

    开始使用_飞桨-源于产业实践的开源深度学习平台

    快速安装:

     检查是否安装成功:

    1. pip install paddlehub -i https://pypi.tuna.tsinghua.edu.cn/simple
    2. #该Module依赖于第三方库shapely、pyclipper,使用该Module之前,请先安装shapely、pyclipper
    3. pip install shapely -i https://pypi.tuna.tsinghua.edu.cn/simple
    4. pip install pyclipper -i https://pypi.tuna.tsinghua.edu.cn/simple

     PaddleHub一键OCR中文识别(超轻量8.1M模型,火爆) - 飞桨AI Studio

    1. import matplotlib.pyplot as plt
    2. import matplotlib.image as mpimg
    3. # 待预测图片
    4. test_img_path = ["./advertisement.jpg", "./pics.jpg", "./identity_card.jpg", "./express.jpg", "./railway_ticket.jpg"]
    5. # 展示其中广告信息图片
    6. img1 = mpimg.imread(test_img_path[0])
    7. plt.figure(figsize=(10,10))
    8. plt.imshow(img1)
    9. plt.axis('off')
    10. plt.show()

     

    二、加载预训练模型

    1. import paddlehub as hub
    2. # 加载移动端预训练模型
    3. # ocr = hub.Module(name="chinese_ocr_db_crnn_mobile")
    4. # 服务端可以加载大模型,效果更好
    5. ocr = hub.Module(name="chinese_ocr_db_crnn_server")

    三、预测

     

    1. import cv2
    2. # 读取测试文件夹test.txt中的照片路径
    3. np_images =[cv2.imread(path+image_path) for image_path in test_img_path]
    4. results = ocr.recognize_text(
    5. images=np_images, # 图片数据,ndarray.shape 为 [H, W, C],BGR格式;
    6. use_gpu=False, # 是否使用 GPU;若使用GPU,请先设置CUDA_VISIBLE_DEVICES环境变量
    7. output_dir='ocr_result', # 图片的保存路径,默认设为 ocr_result;
    8. visualization=True, # 是否将识别结果保存为图片文件;
    9. box_thresh=0.5, # 检测文本框置信度的阈值;
    10. text_thresh=0.5) # 识别中文文本置信度的阈值;
    11. for result in results:
    12. data = result['data']
    13. save_path = result['save_path']
    14. for infomation in data:
    15. print('text: ', infomation['text'], '\nconfidence: ', infomation['confidence'], '\ntext_box_position: ', infomation['text_box_position'])

    recognize_text()接口返回结果results说明:

    • results (list[dict]): 识别结果的列表,列表中每一个元素为 dict,各字段为:
      • data (list[dict]): 识别文本结果,列表中每一个元素为 dict,各字段为:
        • text(str): 识别得到的文本
        • confidence(float): 识别文本结果置信度
        • text_box_position(list): 文本框在原图中的像素坐标,4*2的矩阵,依次表示文本框左下、右下、右上、左上顶点的坐标 如果无识别结果则data为[]
      • save_path (str, optional): 识别结果的保存路径,如不保存图片则save_path为''

    四、服务部署

    第一步:启动PaddleHub Serving

     

    第二步:发送预测请求

    1. import requests
    2. import json
    3. import cv2
    4. import base64
    5. def cv2_to_base64(image):
    6. data = cv2.imencode('.jpg', image)[1]
    7. return base64.b64encode(data.tostring()).decode('utf8')
    8. # 发送HTTP请求
    9. data = {'images':[cv2_to_base64(cv2.imread("D:/OCR/MMOCR/mmocr/demo/highway.jpg"))]}
    10. headers = {"Content-type": "application/json"}
    11. url = "http://127.0.0.1:8866/predict/chinese_ocr_db_crnn_server"
    12. r = requests.post(url=url, headers=headers, data=json.dumps(data))
    13. # 打印预测结果
    14. print(r.json()["results"])

     

     参考:飞桨PaddlePaddle-源于产业实践的开源深度学习平台

  • 相关阅读:
    【YOLOv5/v7改进系列】引入特征融合网络——ASFYOLO
    Linux实现文件定期本地备份/异地备份/删除备份的脚本
    PaLM-E: An Embodied Multimodal Language Model
    【最佳实践】瀚高数据库安全版v4.5.8非root用户运行的安装配置
    boost之实用工具
    在很多nlp数据集上超越tinybert 的新架构nlp神经网络模型
    Packet Tracer 实验 - 排除多区域 OSPFv3 故障
    数据处理包括哪些内容
    机器学习_10、集成学习-随机森林
    应用软件安全编程-20生成强随机数
  • 原文地址:https://blog.csdn.net/u011788214/article/details/126382644