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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

三行代碼完成AI模型的部署!

CVer ? 來(lái)源:CVer ? 作者:CVer ? 2022-11-10 10:18 ? 次閱讀
人工智能產(chǎn)業(yè)應(yīng)用發(fā)展的越來(lái)越快,開發(fā)者需要面對(duì)的適配部署工作也越來(lái)越復(fù)雜。層出不窮的算法模型、各種架構(gòu)的AI硬件、不同場(chǎng)景的部署需求(服務(wù)器、服務(wù)化、嵌入式、移動(dòng)端等)、不同操作系統(tǒng)和開發(fā)語(yǔ)言,為AI開發(fā)者項(xiàng)目落地帶來(lái)不小的挑戰(zhàn)。44eb51b4-609d-11ed-8abf-dac502259ad0.png

為了解決AI部署落地難題,我們發(fā)起了FastDeploy項(xiàng)目。FastDeploy針對(duì)產(chǎn)業(yè)落地場(chǎng)景中的重要AI模型,將模型API標(biāo)準(zhǔn)化,提供下載即可運(yùn)行的Demo示例。相比傳統(tǒng)推理引擎,做到端到端的推理性能優(yōu)化。FastDeploy還支持在線(服務(wù)化部署)和離線部署形態(tài),滿足不同開發(fā)者的部署需求。

經(jīng)過(guò)為期一年的高密度打磨,F(xiàn)astDeploy目前具備三類特色能力:

全場(chǎng)景:支持GPU、CPU、Jetson、ARM CPU、瑞芯微NPU、晶晨NPU、恩智浦NPU等多類硬件,支持本地部署、服務(wù)化部署、Web端部署、移動(dòng)端部署等,支持CV、NLP、Speech三大領(lǐng)域,支持圖像分類、圖像分割、語(yǔ)義分割、物體檢測(cè)、字符識(shí)別(OCR)、人臉檢測(cè)識(shí)別、人像扣圖、姿態(tài)估計(jì)、文本分類、信息抽取、行人跟蹤、語(yǔ)音合成等16大主流算法場(chǎng)景。

易用靈活:三行代碼完成AI模型的部署,一行API完成模型替換,無(wú)縫切換至其他模型部署,提供了150+熱門AI模型的部署Demo。

極致高效:相比傳統(tǒng)深度學(xué)習(xí)推理引擎只關(guān)注模型的推理時(shí)間,F(xiàn)astDeploy則關(guān)注模型任務(wù)的端到端部署性能。通過(guò)高性能前后處理、整合高性能推理引擎、一鍵自動(dòng)壓縮等技術(shù),實(shí)現(xiàn)了AI模型推理部署的極致性能優(yōu)化。

項(xiàng)目傳送門:

https://github.com/PaddlePaddle/FastDeploy

以下將對(duì)該3大特性做進(jìn)一步技術(shù)解讀,全文大約2100字,預(yù)計(jì)閱讀時(shí)長(zhǎng)3分鐘。

1

3大特性篇

2

3步部署實(shí)戰(zhàn)篇,搶先看

CPU/GPU部署實(shí)戰(zhàn)

Jetson部署實(shí)戰(zhàn)

RK3588部署實(shí)戰(zhàn)(RV1126、晶晨A311D等NPU類似)

1

3大特性解讀

全場(chǎng)景:一套代碼云邊端多平臺(tái)多硬件一網(wǎng)打盡,覆蓋CV、NLP、Speech

支持PaddleInference、TensorRT、OpenVINO、ONNXRuntime、PaddleLite、RKNN等后端,覆蓋常見的NVIDIAGPU、x86CPU、Jetson Nano、Jetson TX2、ARMCPU(移動(dòng)端、ARM開發(fā)板)、Jetson Xavier、瑞芯微NPU(RK3588、RK3568、RV1126、RV1109、RK1808)、晶晨NPU(A311D、S905D)等云邊端場(chǎng)景的多類幾十款A(yù)I硬件部署。同時(shí)支持服務(wù)化部署、離線CPU/GPU部署、端側(cè)和移動(dòng)端部署方式。針對(duì)不同硬件,統(tǒng)一API保證一套代碼在數(shù)據(jù)中心、邊緣部署和端側(cè)部署無(wú)縫切換。45072542-609d-11ed-8abf-dac502259ad0.jpgFastDeploy支持CV、NLP、Speech三大AI領(lǐng)域,覆蓋16大類算法(圖像分類、圖像分割、語(yǔ)義分割、物體檢測(cè)、字符識(shí)別(OCR) 、人臉檢測(cè)、人臉關(guān)鍵點(diǎn)檢測(cè)、人臉識(shí)別、人像扣圖、視頻扣圖、姿態(tài)估計(jì)、文本分類 信息抽取 文圖生成、行人跟蹤、語(yǔ)音合成)。支持飛槳PaddleClas、PaddleDetection、PaddleSeg、PaddleOCR、PaddleNLP、PaddleSpeech 6大熱門AI套件的主流模型,同時(shí)也支持生態(tài)(如PyTorch、ONNX等)熱門模型的部署。4517dd88-609d-11ed-8abf-dac502259ad0.gif ?

易用靈活,三行代碼完成模型部署,一行命令快速體驗(yàn)150+熱門模型部署

FastDeploy三行代碼可完成AI模型在不同硬件上的部署,極大降低了AI模型部署難度和工作量。一行命令切換TensorRT、OpenVINO、Paddle Inference、Paddle Lite、ONNX Runtime、RKNN等不同推理后端和對(duì)應(yīng)硬件。低門檻的推理引擎后端集成方案,平均一周時(shí)間即可完成任意硬件推理引擎的接入使用,解耦前后端架構(gòu)設(shè)計(jì),簡(jiǎn)單編譯測(cè)試即可體驗(yàn)FastDeploy支持的AI模型。開發(fā)者可以根據(jù)模型API實(shí)現(xiàn)相應(yīng)模型部署,也可以選擇git clone一鍵獲取150+熱門AI模型的部署示例Demo,快速體驗(yàn)不同模型的推理部署。

			# PP-YOLOE的部署 import fastdeploy as fd import cv2 model = fd.vision.detection.PPYOLOE("model.pdmodel", "model.pdiparams", "infer_cfg.yml") im = cv2.imread("test.jpg") result = model.predict(im) # YOLOv7的部署 import fastdeploy as fd import cv2 model = fd.vision.detection.YOLOv7("model.onnx") im = cv2.imread("test.jpg") result = model.predict(im)

FastDeploy部署不同模型


			# PP-YOLOE的部署 import fastdeploy as fd import cv2 option = fd.RuntimeOption() option.use_cpu() option.use_openvino_backend() # 一行命令切換使用 OpenVINO部署 model = fd.vision.detection.PPYOLOE("model.pdmodel", "model.pdiparams", "infer_cfg.yml", runtime_option=option) im = cv2.imread("test.jpg") result = model.predict(im)FastDeploy切換后端和硬件
						

極致高效:一鍵壓縮提速,預(yù)處理加速,端到端性能優(yōu)化,提升AI算法產(chǎn)業(yè)落地

FastDeploy在吸收TensorRT、OpenVINO、Paddle Inference、Paddle Lite、ONNX Runtime、RKNN等高性能推理優(yōu)勢(shì)的同時(shí),通過(guò)端到端的推理優(yōu)化解決了傳統(tǒng)推理引擎僅關(guān)心模型推理速度的問(wèn)題,提升整體推理速度和性能。集成自動(dòng)壓縮工具,在參數(shù)量大大減小的同時(shí)(精度幾乎無(wú)損),推理速度大幅提升。使用CUDA加速優(yōu)化預(yù)處理和后處理模塊,將YOLO系列的模型推理加速整體從41ms優(yōu)化到25ms。端到端的優(yōu)化策略,徹底解決AI部署落地中的性能難題。更多性能優(yōu)化,歡迎關(guān)注GitHub了解詳情。https://github.com/PaddlePaddle/FastDeploy45fb784a-609d-11ed-8abf-dac502259ad0.png ? ?

2

3步部署實(shí)戰(zhàn)篇,搶先看

1

CPU/GPU部署實(shí)戰(zhàn)(以YOLOv7為例)

安裝FastDeploy部署包,下載部署示例(可選,也可以三行API實(shí)現(xiàn)部署代碼)


			pip install fastdeploy-gpu-python -f https://www.paddlepaddle.org.cn/whl/fastdeploy.html git clone https://github.com/PaddlePaddle/FastDeploy.git cd examples/vision/detection/yolov7/python/
						

準(zhǔn)備模型文件和測(cè)試圖片


			wget https://bj.bcebos.com/paddlehub/fastdeploy/yolov7.onnx wget https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000014439.jpg
						

CPU/GPU推理模型


			# CPU推理 python infer.py --model yolov7.onnx --image 000000014439.jpg --device cpu # GPU推理 python infer.py --model yolov7.onnx --image 000000014439.jpg --device gpu # GPU上使用TensorRT推理 python infer.py --model yolov7.onnx --image 000000014439.jpg --device gpu --use_trt True

推理結(jié)果示例:

462f6b6e-609d-11ed-8abf-dac502259ad0.png

2

Jetson部署實(shí)戰(zhàn)(以YOLOv7為例)

安裝FastDeploy部署包,配置環(huán)境變量


			git clone https://github.com/PaddlePaddle/FastDeploy cd FastDeploy mkdir build && cd build cmake .. -DBUILD_ON_JETSON=ON -DENABLE_VISION=ON -DCMAKE_INSTALL_PREFIX=${PWD}/install make -j8 make install cd FastDeploy/build/install source fastdeploy_init.sh
						

準(zhǔn)備模型文件和測(cè)試圖片


			wget https://bj.bcebos.com/paddlehub/fastdeploy/yolov7.onnx wget https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000014439.jpg
						

編譯推理模型


			cd examples/vision/detection/yolov7/cpp cmake .. -DFASTDEPLOY_INSTALL_DIR=${FASTDEPOLY_DIR} mkdir build && cd build make -j # 使用TensorRT推理(當(dāng)模型不支持TensorRT時(shí)會(huì)自動(dòng)轉(zhuǎn)成使用CPU推理) ./infer_demo yolov7s.onnx 000000014439.jpg 27s.onnx 000000014439.jpg 2

推理結(jié)果示例:

4645f58c-609d-11ed-8abf-dac502259ad0.png

3

RK3588部署實(shí)戰(zhàn)以輕量化檢測(cè)網(wǎng)絡(luò)PicoDet為例)

安裝FastDeploy部署包,下載部署示例(可選,也可以三行API實(shí)現(xiàn)部署代碼)


			# 參考編譯文檔,完成FastDeploy編譯安裝 # 參考文檔鏈接:https://github.com/PaddlePaddle/FastDeploy/blob/develop/docs/cn/build_and_install/rknpu2.md # 下載部署示例代碼 git clone https://github.com/PaddlePaddle/FastDeploy.git cd examples/vision/detection/paddledetection/rknpu2/python
						

準(zhǔn)備模型文件和測(cè)試圖片


			wget https://bj.bcebos.com/fastdeploy/models/rknn2/picodet_s_416_coco_npu.zip unzip -qo picodet_s_416_coco_npu.zip ## 下載Paddle靜態(tài)圖模型并解壓 wget https://bj.bcebos.com/fastdeploy/models/rknn2/picodet_s_416_coco_npu.zip unzip -qo picodet_s_416_coco_npu.zip # 靜態(tài)圖轉(zhuǎn)ONNX模型,注意,這里的save_file請(qǐng)和壓縮包名對(duì)齊 paddle2onnx --model_dir picodet_s_416_coco_npu --model_filename model.pdmodel --params_filename model.pdiparams --save_file picodet_s_416_coco_npu/picodet_s_416_coco_npu.onnx --enable_dev_version True python -m paddle2onnx.optimize --input_model picodet_s_416_coco_npu/picodet_s_416_coco_npu.onnx --output_model picodet_s_416_coco_npu/picodet_s_416_coco_npu.onnx --input_shape_dict "{'image':[1,3,416,416]}" # ONNX模型轉(zhuǎn)RKNN模型 # 轉(zhuǎn)換模型,模型將生成在picodet_s_320_coco_lcnet_non_postprocess目錄下 python tools/rknpu2/export.py --config_path tools/rknpu2/config/RK3588/picodet_s_416_coco_npu.yaml # 下載圖片 wget https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000014439.jpg
						

推理模型


		python3 infer.py --model_file ./picodet _3588/picodet_3588.rknn --config_file ./picodet_3588/deploy.yaml --image images/000000014439.jpg
		


審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • AI
    AI
    +關(guān)注

    關(guān)注

    87

    文章

    30998

    瀏覽量

    269312
  • 人工智能
    +關(guān)注

    關(guān)注

    1791

    文章

    47352

    瀏覽量

    238779
  • 深度學(xué)習(xí)
    +關(guān)注

    關(guān)注

    73

    文章

    5504

    瀏覽量

    121232

原文標(biāo)題:炸裂!三行代碼完成AI模型的部署!

文章出處:【微信號(hào):CVer,微信公眾號(hào):CVer】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    企業(yè)AI模型部署攻略

    當(dāng)下,越來(lái)越多的企業(yè)開始探索和實(shí)施AI模型,以提升業(yè)務(wù)效率和競(jìng)爭(zhēng)力。然而,AI模型部署并非易事,需要企業(yè)在多個(gè)層面進(jìn)行細(xì)致的規(guī)劃和準(zhǔn)備。下
    的頭像 發(fā)表于 12-23 10:31 ?130次閱讀

    AI模型部署邊緣設(shè)備的奇妙之旅:目標(biāo)檢測(cè)模型

    智視覺(jué)模塊上部署 PaddleDetection 模型如果說(shuō)有自己制作數(shù)據(jù)的話,需要將數(shù)據(jù)上傳,然后在修改全局配置項(xiàng),修改數(shù)據(jù)集地址以及對(duì)應(yīng)的類別數(shù)。 按照廠家提供的配置直接進(jìn)行訓(xùn)練轉(zhuǎn)換。 訓(xùn)練完成后,會(huì)自動(dòng)生成一個(gè)rknn
    發(fā)表于 12-19 14:33

    AI模型部署邊緣設(shè)備的奇妙之旅:如何實(shí)現(xiàn)手寫數(shù)字識(shí)別

    更適合生產(chǎn)環(huán)境的框架來(lái)部署。此外,許多推理引擎和硬件加速器也支持ONNX格式,從而進(jìn)一步加快了模型部署的速度。 在凌智視覺(jué)模塊中模型轉(zhuǎn)換就比較簡(jiǎn)單,我們只需要點(diǎn)擊運(yùn)行即可,下面是具體的
    發(fā)表于 12-06 17:20

    AI模型部署和管理的關(guān)系

    AI模型部署與管理是AI項(xiàng)目成功的兩大支柱,它們之間既相互獨(dú)立又緊密相連,共同推動(dòng)著AI技術(shù)從實(shí)驗(yàn)室走向?qū)嶋H應(yīng)用。
    的頭像 發(fā)表于 11-21 10:02 ?164次閱讀

    如何在STM32f4系列開發(fā)板上部署STM32Cube.AI,

    已下載STM32Cube.AI擴(kuò)展包,但是無(wú)法使用,感覺(jué)像是沒(méi)有部署AI模型,我是想要通過(guò)攝像頭拍照,上傳圖像后,經(jīng)過(guò)開發(fā)板處理器進(jìn)行AI
    發(fā)表于 11-18 09:39

    AI模型托管原理分析

    AI模型托管是指將訓(xùn)練好的AI模型部署在云端或邊緣服務(wù)器上,由第方平臺(tái)提供
    的頭像 發(fā)表于 11-07 09:33 ?192次閱讀

    企業(yè)AI模型部署怎么做

    AI模型部署作為這一轉(zhuǎn)型過(guò)程中的關(guān)鍵環(huán)節(jié),其成功實(shí)施對(duì)于企業(yè)的長(zhǎng)遠(yuǎn)發(fā)展至關(guān)重要。在此,AI部落小編為您介紹企業(yè)AI
    的頭像 發(fā)表于 11-04 10:15 ?158次閱讀

    三行代碼完成生成式AI部署

    LLM加載與推理部署能力,實(shí)現(xiàn)了OpenVINO對(duì)CNN網(wǎng)絡(luò)、生成式模型、LLM網(wǎng)絡(luò)主流模型的全面推理支持。
    的頭像 發(fā)表于 08-30 16:49 ?428次閱讀
    <b class='flag-5'>三行</b><b class='flag-5'>代碼</b><b class='flag-5'>完成</b>生成式<b class='flag-5'>AI</b><b class='flag-5'>部署</b>

    利用恩智浦云實(shí)驗(yàn)室部署AI模型

    如今,人工智能(AI)非常火爆,這個(gè)風(fēng)口該如何把握?作為一個(gè)電子工程師,和AI最主要的交集應(yīng)該就是邊緣計(jì)算了,具體來(lái)講,就是在一些性能、功耗以及價(jià)格相對(duì)較低的嵌入式平臺(tái)上部署和運(yùn)行AI
    的頭像 發(fā)表于 08-02 11:46 ?2785次閱讀
    利用恩智浦云實(shí)驗(yàn)室<b class='flag-5'>部署</b><b class='flag-5'>AI</b><b class='flag-5'>模型</b>

    摩爾線程攜手東華軟件完成AI模型推理測(cè)試與適配

    近日,摩爾線程與東華軟件云筑AI創(chuàng)新中心宣布,雙方已完成模型推理測(cè)試與適配。依托摩爾線程的全功能GPU國(guó)產(chǎn)算力,東華軟件打造安全可信的基于私有化大模型的“智多型(A.I.Cognif
    的頭像 發(fā)表于 07-31 10:51 ?749次閱讀

    英偉達(dá)推出Flextron AI框架:賦能靈活高效的AI模型部署

    在人工智能與機(jī)器學(xué)習(xí)領(lǐng)域,隨著技術(shù)的不斷演進(jìn),模型的高效部署與適應(yīng)性成為研究的新熱點(diǎn)。近日,英偉達(dá)與德克薩斯大學(xué)奧斯汀分校攜手宣布了一項(xiàng)重大突破——推出了一種名為FLEXTRON的新型靈活模型架構(gòu)及訓(xùn)練后優(yōu)化框架,這一創(chuàng)新成果為
    的頭像 發(fā)表于 07-18 15:22 ?2762次閱讀

    CubeIDE生成的代碼框架會(huì)卡在MX_X_CUBE_AI_Process()函數(shù)中是怎么回事?

    當(dāng)我將網(wǎng)絡(luò)模型部署到STM32F407VGT6中時(shí),CubeIDE生成的代碼框架會(huì)卡在MX_X_CUBE_AI_Process()函數(shù)中是怎么回事?CUbeAI庫(kù)的版本是9.0。期待您
    發(fā)表于 05-30 06:11

    愛芯通元NPU完成Llama 3和Phi-3大模型適配,推動(dòng)AI模型技術(shù)普及

    AI模型技術(shù)的持續(xù)進(jìn)步正在推動(dòng)千百業(yè)智能化升級(jí)。
    的頭像 發(fā)表于 04-26 16:57 ?873次閱讀
    愛芯通元NPU<b class='flag-5'>完成</b>Llama 3和Phi-3大<b class='flag-5'>模型</b>適配,推動(dòng)<b class='flag-5'>AI</b>大<b class='flag-5'>模型</b>技術(shù)普及

    防止AI模型被黑客病毒入侵控制(原創(chuàng))聆思大模型AI開發(fā)套件評(píng)測(cè)4

    風(fēng)險(xiǎn)。 以下是我編寫的一個(gè)簡(jiǎn)單的Python代碼,用于防止AI模型被黑客病毒入侵控制: import os# 這是咱的“大管家”,專門負(fù)責(zé)家里(系統(tǒng))的各種瑣事,比如找個(gè)文件、開個(gè)窗戶什么的
    發(fā)表于 03-19 11:18

    使用CUBEAI部署tflite模型到STM32F0中,模型創(chuàng)建失敗怎么解決?

    CRC IP,用MX生成工程時(shí)已經(jīng)啟用了CRC,代碼中也有。 但是依舊無(wú)法生成模型。 想問(wèn)問(wèn)該如何解決,還是說(shuō)F0還是無(wú)法部署AI模型
    發(fā)表于 03-15 08:10