精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

在AI愛克斯開發板上用OpenVINO?加速YOLOv8分類模型

英特爾物聯網 ? 來源:英特爾物聯網 ? 2023-05-05 11:47 ? 次閱讀

文章作者:

英特爾物聯網行業創新大使 楊雪鋒

本系列文章將在AI 愛克斯開發板上使用 OpenVINO開發套件依次部署并測評 YOLOv8 的分類模型、目標檢測模型、實例分割模型和人體姿態估計模型。

接下來,本文將介紹在AI 愛克斯開發板上搭建 OpenVINO 推理程序的開發環境、導出并優化 YOLOv8 分類模型、完成 YOLOv8 分類模型的推理程序,最后給出實測性能。

請先下載本文的代碼倉:

git clone https://gitee.com/ppov-nuc/yolov8_openvino.git

1YOLOv8 簡介

YOLOv8 是 Ultralytics 公司基于 YOLO 框架,發布的一款面向物體檢測與跟蹤、實例分割、圖像分類和姿態估計任務的 SOTA 模型工具套件。

只需要幾行 Python 代碼,或者一行命令,即可完成在自己的數據集上從頭訓練 (Training a model from scratch) 或者微調(Fine-tune) YOLOv8 模型。

d1c41c2e-e6b2-11ed-ab56-dac502259ad0.png

用 Python 代碼訓練 YOLOv8 模型

d1d3e0dc-e6b2-11ed-ab56-dac502259ad0.png

用命令行訓練 YOLOv8 模型

導出訓練好的 YOLOv8 模型,并用 OpenVINO 部署在英特爾硬件平臺上,也非常方便,下面依次介紹。

2準備 YOLOv8 的

OpenVINO 推理程序開發環境

請基于本文范例代碼倉提供的 requirements.txt 文件,通過一行命令完成開發環境安裝。

# Usage: pip install -r requirements.txt
ultralytics
# Base ----------------------------------------
matplotlib>=3.2.2
numpy>=1.21.6
opencv-python>=4.6.0
Pillow>=7.1.2
PyYAML>=5.3.1
requests>=2.23.0
scipy>=1.4.1
torch==1.13.1
torchvision==0.14.1
tqdm>=4.64.0
# Plotting ------------------------------------
pandas>=1.1.4
seaborn>=0.11.0
# Export --------------------------------------
onnx>=1.12.0 # ONNX export
onnxruntime
openvino-dev==2023.0.0.dev20230407 # modify the openvino-dev version to the latest one
# Extras --------------------------------------
psutil # system utilization
thop>=0.1.1 # FLOPs computation

向右滑動查看完整代碼

一行命令完成開發環境安裝。

pip install -r requirements.txt

3導出 YOLOv8 OpenVINOIR 模型

YOLOv8 的分類模型有5種,在 ImageNet 數據集上的精度如下表所示。

d1e398b0-e6b2-11ed-ab56-dac502259ad0.png

首先使用命令:

yolo classify export model=yolov8n-cls.pt format=onnx imgsz=224

完成 yolov8n-cls.onnx 模型導出,如下圖所示。

d1ff0bcc-e6b2-11ed-ab56-dac502259ad0.png

然后使用命令:

mo -m yolov8n-cls.onnx --compress_to_fp16

優化并導出 FP16 精度的 OpenVINO IR 格式模型,如下圖所示。

d21687b6-e6b2-11ed-ab56-dac502259ad0.png

4用 benchmark_app 測試 YOLOv8 分類模型的推理計算性能

benchmark_app 是 OpenVINO 工具套件自帶的 AI 模型推理計算性能測試工具,可以指定在不同的計算設備上,在同步或異步模式下,測試出不帶前后處理的純AI 模型推理計算性能。

使用命令:benchmark_app -m yolov8n-cls.xml -d GPU ,獲得 yolov8n-cls.xml 模型在 AI 愛克斯開發板的集成顯卡上的異步推理計算性能,如下圖所示。

d231fd2a-e6b2-11ed-ab56-dac502259ad0.png

5使用 OpenVINO Python API 編寫 YOLOv8 分類模型推理程序

基于 OpenVINO Python API 的 YOLOv8 分類模型范例程序 yolov8_cls_ov_sync_infer.py 的核心源代碼,如下所示:

# 實例化Core對象
core = Core() 
# 載入并編譯模型
net = core.compile_model(f'{MODEL_NAME}-cls.xml', device_name="GPU")
# 獲得模型輸入輸出節點
input_node = net.inputs[0]  # yolov8n-cls只有一個輸入節點
N, C, H, W = input_node.shape # 獲得輸入張量的形狀
output_node = net.outputs[0] # yolov8n-cls只有一個輸出節點
ir = net.create_infer_request()
##########################################
#  ---根據模型定義預處理和后處理函數-------
##########################################
# 定義預處理函數
def preprocess(image, new_shape=(W,H)):
  # Preprocess image data from OpenCV
  image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)  # BGR->RGB
  resized = cv2.resize(image, new_shape)      # Resize Image
  norm = (resized - IMAGENET_MEAN) / IMAGENET_STD # Normalization
  blob = np.transpose(norm, (2, 0, 1))       # HWC->CHW
  blob = np.expand_dims(blob, 0)          # CHW->NCHW
  return blob
# 定義后處理函數
def postprocess(outs):
  score = np.max(outs)
  id = np.argmax(outs)
  return score, id, imagenet_labels[id]
##########################################
#  ----- AI同步推理計算 ------------
##########################################
# 采集圖像
image = cv2.imread("bus.jpg")
# 數據預處理
blob = preprocess(image)
# 執行推理計算并獲得結果
outs = ir.infer(blob)[output_node]
# 對推理結果進行后處理
score, id, label = postprocess(outs)
# 顯示處理結果
msg = f"YOLOv5s-cls Result:{label}, Score:{score:4.2f}, FPS:{FPS:4.2f}"
cv2.putText(image, msg, (10, 50), cv2.FONT_HERSHEY_SIMPLEX, 0.8, (100, 100, 200), 2)
cv2.imshow("YOLOv5s-cls OpenVINO Sync Infer Demo",image)
cv2.waitKey()
cv2.destroyAllWindows()

向右滑動查看完整代碼

運行結果如下圖所示:

d2436eb6-e6b2-11ed-ab56-dac502259ad0.png

6

使用 OpenVINO 預處理 API 提升推理計算性能

參考《將數據預處理嵌入 AI 模型的常見技巧》,使用 OpenVINO 預處理 API ,將數據預處理嵌入 YOLOv8 分類模型,可以進一步提高推理設備(例如,英特爾集成顯卡/獨立顯卡)的利用率,進而提高包含前后處理的端到端的AI 推理計算性能。

使用 OpenVINO預處理 API 將預處理嵌入模型的范例程序 export_yolov8_cls_ppp.py 的核心代碼,如下所示:

# ======== Step 0: read original model =========
core = Core()
model = core.read_model(f"{MODEL_NAME}-cls.xml")


# Step 1: Add Preprocessing steps to a model ==
ppp = PrePostProcessor(model) 
# Declare User’s Data Format
ppp.input().tensor() 
  .set_element_type(Type.u8) 
  .set_spatial_dynamic_shape() 
  .set_layout(Layout('NHWC')) 
  .set_color_format(ColorFormat.BGR)
# Declaring Model Layout
ppp.input().model().set_layout(Layout('NCHW'))
# Explicit preprocessing steps. Layout conversion will be done automatically as last step
ppp.input().preprocess() 
  .convert_element_type()   
  .convert_color(ColorFormat.RGB) 
  .resize(ResizeAlgorithm.RESIZE_LINEAR) 
  .mean([123.675, 116.28, 103.53]) 
  .scale([58.624, 57.12, 57.375])
# Integrate preprocessing Steps into a Model
print(f'Dump preprocessor: {ppp}')
model_with_ppp = ppp.build()
# ======== Step 2: Save the model with preprocessor================
serialize(model_with_ppp, f'{MODEL_NAME}-cls_ppp.xml', f'{MODEL_NAME}-cls_ppp.bin')

向右滑動查看完整代碼

運行結果,如下圖所示:

d2621370-e6b2-11ed-ab56-dac502259ad0.png

基于內嵌預處理模型的推理程序

yolov8_cls_ppp_sync_infer.py 的核心代碼,如下所示

##########################################
#  ----- AI同步推理計算 ------------
##########################################
# 采集圖像
image = cv2.imread("bus.jpg")
blob = np.expand_dims(image,0)
# 執行推理計算并獲得結果
outs = ir.infer(blob)[output_node]
# 對推理結果進行后處理
score, id, label = postprocess(outs)
##########################################
#  ----- 統計帶前后預處理的AI推理性能------
##########################################
start = time.time()
N = 1000
for i in range(N):
  blob = np.expand_dims(image,0)
  outs = ir.infer(blob)[output_node]
  score, id, label = postprocess(outs)
FPS = N / (time.time() - start)

向右滑動查看完整代碼

運行結果,如下所示:

d2823254-e6b2-11ed-ab56-dac502259ad0.png

結論

AI 愛克斯開發板借助N5105處理器的集成顯卡(24個執行單元)和 OpenVINO ,可以在 YOLOv8 的分類模型上獲得相當不錯的性能。

通過異步處理和AsyncInferQueue ,還能進一步提升計算設備的利用率,提高 AI 推理程序的吞吐量。下一篇將繼續介紹在《在 AI 愛克斯開發板上用 OpenVINO 加速 YOLOv8 目標檢測模型》。

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 英特爾
    +關注

    關注

    60

    文章

    9880

    瀏覽量

    171482
  • AI
    AI
    +關注

    關注

    87

    文章

    30106

    瀏覽量

    268399
  • 開發板
    +關注

    關注

    25

    文章

    4943

    瀏覽量

    97188
  • 模型
    +關注

    關注

    1

    文章

    3171

    瀏覽量

    48711
  • python
    +關注

    關注

    56

    文章

    4782

    瀏覽量

    84449

原文標題:在AI愛克斯開發板上用OpenVINO?加速YOLOv8分類模型 | 開發者實戰

文章出處:【微信號:英特爾物聯網,微信公眾號:英特爾物聯網】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【愛芯派 Pro 開發板試用體驗】yolov8模型轉換

    通過開發板預制的ax_run_model 工具,測試模型速度和精度。 示例都是yolov5的,沒有yolov8
    發表于 11-20 12:19

    YOLOv8自定義數據集訓練到模型部署推理簡析

    如果你只是想使用而不是開發,強烈推薦通過pip安裝方式獲取YOLOv8包!YOLOv8安裝命令行
    的頭像 發表于 03-24 09:27 ?4590次閱讀

    AI愛克斯開發板OpenVINO?加速YOLOv8目標檢測模型

    AI 愛克斯開發板 OpenVINO
    的頭像 發表于 05-12 09:08 ?1261次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發板</b><b class='flag-5'>上</b><b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b>?<b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>目標檢測<b class='flag-5'>模型</b>

    ?AI愛克斯開發板OpenVINO加速YOLOv8-seg實例分割模型

    benchmark_app是OpenVINOTM工具套件自帶的AI模型推理計算性能測試工具,可以指定在不同的計算設備同步或異步模式下,測試出不帶前后處理的純
    的頭像 發表于 05-24 11:19 ?600次閱讀
    ?<b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發板</b><b class='flag-5'>上</b><b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b><b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>-seg實例分割<b class='flag-5'>模型</b>

    AI愛克斯開發板使用OpenVINO加速YOLOv8目標檢測模型

    AI愛克斯開發板OpenVINO
    的頭像 發表于 05-26 11:03 ?1187次閱讀
    <b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發板</b><b class='flag-5'>上</b>使用<b class='flag-5'>OpenVINO</b><b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>目標檢測<b class='flag-5'>模型</b>

    AI愛克斯開發板OpenVINO?加速YOLOv8-seg實例分割模型

    AI 愛克斯開發板 OpenVINO
    的頭像 發表于 06-05 11:52 ?967次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發板</b><b class='flag-5'>上</b><b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b>?<b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>-seg實例分割<b class='flag-5'>模型</b>

    英特爾開發者套件OpenVINO? 2023.0加速YOLOv8-Pose姿態估計模型

    benchmark_app 是 OpenVINO 工具套件自帶的 AI 模型推理計算性能測試工具,可以指定在不同的計算設備同步或異步模
    的頭像 發表于 06-15 17:41 ?995次閱讀
    <b class='flag-5'>在</b>英特爾<b class='flag-5'>開發</b>者套件<b class='flag-5'>上</b><b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b>? 2023.0<b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>-Pose姿態估計<b class='flag-5'>模型</b>

    教你如何用兩行代碼搞定YOLOv8各種模型推理

    大家好,YOLOv8 框架本身提供的API函數是可以兩行代碼實現 YOLOv8 模型推理,這次我把這段代碼封裝成了一個,只有40行代碼左右,可以同時支持
    的頭像 發表于 06-18 11:50 ?2982次閱讀
    教你如何用兩行代碼搞定<b class='flag-5'>YOLOv8</b>各種<b class='flag-5'>模型</b>推理

    OpenVINO? C++ API編寫YOLOv8-Seg實例分割模型推理程序

    本文章將介紹使用 OpenVINO 2023.0 C++ API 開發YOLOv8-Seg 實例分割(Instance Segmentation)模型
    的頭像 發表于 06-25 16:09 ?1511次閱讀
    <b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b>? C++ API編寫<b class='flag-5'>YOLOv8</b>-Seg實例分割<b class='flag-5'>模型</b>推理程序

    AI愛克斯開發板OpenVINO?加速YOLOv8-seg實例分割模型

    AI 愛克斯開發板 OpenVINO
    的頭像 發表于 06-30 10:43 ?872次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發板</b><b class='flag-5'>上</b><b class='flag-5'>用</b><b class='flag-5'>OpenVINO</b>?<b class='flag-5'>加速</b><b class='flag-5'>YOLOv8</b>-seg實例分割<b class='flag-5'>模型</b>

    三種主流模型部署框架YOLOv8推理演示

    部署。這里以YOLOv8為例,演示了YOLOv8對象檢測模型OpenVINO、ONNXRUNTIME、TensorRT三個主流框架上C++
    的頭像 發表于 08-06 11:39 ?2652次閱讀

    YOLOv8實現任意目錄下命令行訓練

    當你使用YOLOv8命令行訓練模型的時候,如果當前執行的目錄下沒有相關的預訓練模型文件,YOLOv8就會自動下載模型權重文件。這個是一個正常
    的頭像 發表于 09-04 10:50 ?1065次閱讀
    <b class='flag-5'>YOLOv8</b>實現任意目錄下命令行訓練

    自己的數據集訓練YOLOv8實例分割模型

    YOLOv8 于 2023 年 1 月 10 日推出。截至目前,這是計算機視覺領域分類、檢測和分割任務的最先進模型。該模型準確性和執行時間
    的頭像 發表于 11-10 16:44 ?4141次閱讀
    <b class='flag-5'>用</b>自己的數據集訓練<b class='flag-5'>YOLOv8</b>實例分割<b class='flag-5'>模型</b>

    基于YOLOv8的自定義醫學圖像分割

    YOLOv8是一種令人驚嘆的分割模型;它易于訓練、測試和部署。本教程中,我們將學習如何在自定義數據集使用YOLOv8。但在此之前,我想告
    的頭像 發表于 12-20 10:51 ?733次閱讀
    基于<b class='flag-5'>YOLOv8</b>的自定義醫學圖像分割

    基于哪吒開發板部署YOLOv8模型

    開發板的推理性能,同時測試所推出的 OpenVINO C# API (https://github.com/guojin-yan/OpenVINO-CSharp-API) 項目能否應用到該
    的頭像 發表于 11-15 14:13 ?153次閱讀
    基于哪吒<b class='flag-5'>開發板</b>部署<b class='flag-5'>YOLOv8</b><b class='flag-5'>模型</b>