色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

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

英特爾物聯(lián)網 ? 來源:英特爾物聯(lián)網 ? 2023-05-05 11:47 ? 次閱讀

文章作者:

英特爾物聯(lián)網行業(yè)創(chuàng)新大使 楊雪鋒

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

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

請先下載本文的代碼倉:

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

1YOLOv8 簡介

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

只需要幾行 Python 代碼,或者一行命令,即可完成在自己的數(shù)據(jù)集上從頭訓練 (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 推理程序開發(fā)環(huán)境

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

# 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

向右滑動查看完整代碼

一行命令完成開發(fā)環(huán)境安裝。

pip install -r requirements.txt

3導出 YOLOv8 OpenVINOIR 模型

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

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

優(yōu)化并導出 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 愛克斯開發(fā)板的集成顯卡上的異步推理計算性能,如下圖所示。

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")
# 獲得模型輸入輸出節(jié)點
input_node = net.inputs[0]  # yolov8n-cls只有一個輸入節(jié)點
N, C, H, W = input_node.shape # 獲得輸入張量的形狀
output_node = net.outputs[0] # yolov8n-cls只有一個輸出節(jié)點
ir = net.create_infer_request()
##########################################
#  ---根據(jù)模型定義預處理和后處理函數(shù)-------
##########################################
# 定義預處理函數(shù)
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
# 定義后處理函數(shù)
def postprocess(outs):
  score = np.max(outs)
  id = np.argmax(outs)
  return score, id, imagenet_labels[id]
##########################################
#  ----- AI同步推理計算 ------------
##########################################
# 采集圖像
image = cv2.imread("bus.jpg")
# 數(shù)據(jù)預處理
blob = preprocess(image)
# 執(zhí)行推理計算并獲得結果
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 提升推理計算性能

參考《將數(shù)據(jù)預處理嵌入 AI 模型的常見技巧》,使用 OpenVINO 預處理 API ,將數(shù)據(jù)預處理嵌入 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)
# 執(zhí)行推理計算并獲得結果
outs = ir.infer(blob)[output_node]
# 對推理結果進行后處理
score, id, label = postprocess(outs)
##########################################
#  ----- 統(tǒng)計帶前后預處理的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 愛克斯開發(fā)板借助N5105處理器的集成顯卡(24個執(zhí)行單元)和 OpenVINO ,可以在 YOLOv8 的分類模型上獲得相當不錯的性能。

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

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

    關注

    61

    文章

    9949

    瀏覽量

    171692
  • AI
    AI
    +關注

    關注

    87

    文章

    30728

    瀏覽量

    268886
  • 開發(fā)板
    +關注

    關注

    25

    文章

    5032

    瀏覽量

    97371
  • 模型
    +關注

    關注

    1

    文章

    3226

    瀏覽量

    48807
  • python
    +關注

    關注

    56

    文章

    4792

    瀏覽量

    84627

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

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

收藏 人收藏

    評論

    相關推薦

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

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

    YOLOv8自定義數(shù)據(jù)集訓練到模型部署推理簡析

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

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

    AI 愛克斯開發(fā)板 OpenVINO
    的頭像 發(fā)表于 05-12 09:08 ?1312次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發(fā)板</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愛克斯開發(fā)板OpenVINO加速YOLOv8-seg實例分割模型

    benchmark_app是OpenVINOTM工具套件自帶的AI模型推理計算性能測試工具,可以指定在不同的計算設備同步或異步模式下,測試出不帶前后處理的純
    的頭像 發(fā)表于 05-24 11:19 ?634次閱讀
    ?<b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發(fā)板</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愛克斯開發(fā)板使用OpenVINO加速YOLOv8目標檢測模型

    AI愛克斯開發(fā)板OpenVINO
    的頭像 發(fā)表于 05-26 11:03 ?1239次閱讀
    <b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發(fā)板</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愛克斯開發(fā)板OpenVINO?加速YOLOv8-seg實例分割模型

    AI 愛克斯開發(fā)板 OpenVINO
    的頭像 發(fā)表于 06-05 11:52 ?1000次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發(fā)板</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>

    英特爾開發(fā)者套件OpenVINO? 2023.0加速YOLOv8-Pose姿態(tài)估計模型

    benchmark_app 是 OpenVINO 工具套件自帶的 AI 模型推理計算性能測試工具,可以指定在不同的計算設備同步或異步模
    的頭像 發(fā)表于 06-15 17:41 ?1022次閱讀
    <b class='flag-5'>在</b>英特爾<b class='flag-5'>開發(fā)</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姿態(tài)估計<b class='flag-5'>模型</b>

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

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

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

    本文章將介紹使用 OpenVINO 2023.0 C++ API 開發(fā)YOLOv8-Seg 實例分割(Instance Segmentation)模型
    的頭像 發(fā)表于 06-25 16:09 ?1581次閱讀
    <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愛克斯開發(fā)板OpenVINO?加速YOLOv8-seg實例分割模型

    AI 愛克斯開發(fā)板 OpenVINO
    的頭像 發(fā)表于 06-30 10:43 ?904次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>AI</b><b class='flag-5'>愛克斯</b><b class='flag-5'>開發(fā)板</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++
    的頭像 發(fā)表于 08-06 11:39 ?2728次閱讀

    YOLOv8實現(xiàn)任意目錄下命令行訓練

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

    自己的數(shù)據(jù)集訓練YOLOv8實例分割模型

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

    基于YOLOv8的自定義醫(yī)學圖像分割

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

    基于哪吒開發(fā)板部署YOLOv8模型

    開發(fā)板的推理性能,同時測試所推出的 OpenVINO C# API (https://github.com/guojin-yan/OpenVINO-CSharp-API) 項目能否應用到該
    的頭像 發(fā)表于 11-15 14:13 ?222次閱讀
    基于哪吒<b class='flag-5'>開發(fā)板</b>部署<b class='flag-5'>YOLOv8</b><b class='flag-5'>模型</b>
    主站蜘蛛池模板: 久久久无码精品亚洲欧美| 精品视频久久久久| 国产高清在线a视频大全| 国产AV精品无码免费看| 国产精品A8198V久久A片| 国产喷水1区2区3区咪咪爱AV| 灰原哀被啪漫画禁漫| 鸭子玩富婆流白浆视频| 亚洲 国产 日韩 欧美 在线| 艳照门在线观看| 99久久国内精品成人免费| 成年人国产视频| 国产亚洲欧美日韩综合综合二区| 久久久久久久伊人电影| 欧美成人免费观看久久| 双手绑在床头调教乳尖| 亚洲乱码国产一区三区| 97亚洲狠狠色综合久久久久| 短篇合集纯肉高H深陷骚| 果冻传媒2021在线观看| 理论片午午伦夜理片影院| 欧美性色生活片天天看99顶级| 四虎视频最新视频在线观看| 亚洲中文 字幕 国产 综合| 97视频免费在线| 国产精品私人玩物在线观看| 久久伊人电影| 色婷婷我要去我去也| 一个人免费观看HD完整版| qvod快播在线观看| 好紧好湿太硬了我太爽了小说| 久久亚洲欧美国产综合| 色欲蜜臀AV免费视频| 伊人久久大香线蕉综合电影网| 成人啪啪色婷婷久色社区| 精品精品国产自在现拍| 日本枯瘦娇小| 中文无码熟妇人妻AV在线| 帝王被大臣们调教高肉| 久久黄色大片| 无码任你躁久久久久久久|