衡阳派盒市场营销有限公司

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

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

3天內不再提示

低門檻AI部署工具FastDeploy開源!

新機器視覺 ? 來源:新機器視覺 ? 作者:新機器視覺 ? 2022-11-08 14:28 ? 次閱讀

人工智能產業應用發展的越來越快,開發者需要面對的適配部署工作也越來越復雜。層出不窮的算法模型、各種架構的AI硬件、不同場景的部署需求(服務器、服務化、嵌入式、移動端等)、不同操作系統和開發語言,為AI開發者項目落地帶來不小的挑戰。edc63234-5f1e-11ed-8abf-dac502259ad0.png

為了解決AI部署落地難題,我們發起了FastDeploy項目。FastDeploy針對產業落地場景中的重要AI模型,將模型API標準化,提供下載即可運行的Demo示例。相比傳統推理引擎,做到端到端的推理性能優化。FastDeploy還支持在線(服務化部署)和離線部署形態,滿足不同開發者的部署需求。

經過為期一年的高密度打磨,FastDeploy目前具備三類特色能力:

全場景:支持GPUCPU、Jetson、ARM CPU、瑞芯微NPU、晶晨NPU、恩智浦NPU等多類硬件,支持本地部署、服務化部署、Web端部署、移動端部署等,支持CV、NLP、Speech三大領域,支持圖像分類、圖像分割、語義分割、物體檢測、字符識別(OCR)、人臉檢測識別、人像扣圖、姿態估計、文本分類、信息抽取、行人跟蹤、語音合成等16大主流算法場景。

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

極致高效:相比傳統深度學習推理引擎只關注模型的推理時間,FastDeploy則關注模型任務的端到端部署性能。通過高性能前后處理、整合高性能推理引擎、一鍵自動壓縮等技術,實現了AI模型推理部署的極致性能優化。

項目傳送門:

https://github.com/PaddlePaddle/FastDeploy

以下將對該3大特性做進一步技術解讀,全文大約2100字,預計閱讀時長3分鐘。

1

3大特性篇

2

3步部署實戰篇,搶先看

CPU/GPU部署實戰

Jetson部署實戰

RK3588部署實戰(RV1126、晶晨A311D等NPU類似)

1

3大特性解讀

全場景:一套代碼云邊端多平臺多硬件一網打盡,覆蓋CV、NLP、Speech

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

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

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

			# 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切換后端和硬件
						

極致高效:一鍵壓縮提速,預處理加速,端到端性能優化,提升AI算法產業落地

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

2

3步部署實戰篇,搶先看

1

CPU/GPU部署實戰(以YOLOv7為例)

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


			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/
						

準備模型文件和測試圖片


			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

推理結果示例:

ee3d56b6-5f1e-11ed-8abf-dac502259ad0.png

2

Jetson部署實戰(以YOLOv7為例)

安裝FastDeploy部署包,配置環境變量


			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
						

準備模型文件和測試圖片


			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推理(當模型不支持TensorRT時會自動轉成使用CPU推理) ./infer_demo yolov7s.onnx 000000014439.jpg 27s.onnx 000000014439.jpg 2

推理結果示例:

ee534ce6-5f1e-11ed-8abf-dac502259ad0.png

3

RK3588部署實戰以輕量化檢測網絡PicoDet為例)

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


			# 參考編譯文檔,完成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
						

準備模型文件和測試圖片


			wget https://bj.bcebos.com/fastdeploy/models/rknn2/picodet_s_416_coco_npu.zip unzip -qo picodet_s_416_coco_npu.zip ## 下載Paddle靜態圖模型并解壓 wget https://bj.bcebos.com/fastdeploy/models/rknn2/picodet_s_416_coco_npu.zip unzip -qo picodet_s_416_coco_npu.zip # 靜態圖轉ONNX模型,注意,這里的save_file請和壓縮包名對齊 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模型轉RKNN模型 # 轉換模型,模型將生成在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
		審核編輯 :李倩

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

    關注

    87

    文章

    31520

    瀏覽量

    270335
  • 人工智能
    +關注

    關注

    1796

    文章

    47674

    瀏覽量

    240292
  • 深度學習
    +關注

    關注

    73

    文章

    5515

    瀏覽量

    121551

原文標題:模型部署不再難!低門檻AI部署工具FastDeploy開源!

文章出處:【微信號:vision263com,微信公眾號:新機器視覺】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    AI開發平臺如何賦能開發者

    當下,AI開發平臺通過提供豐富的工具集、優化的開發環境以及高效的部署能力,極大地降低了AI應用的開發門檻,加速了創新步伐。那么,
    的頭像 發表于 01-17 14:47 ?71次閱讀

    企業AI模型部署攻略

    當下,越來越多的企業開始探索和實施AI模型,以提升業務效率和競爭力。然而,AI模型的部署并非易事,需要企業在多個層面進行細致的規劃和準備。下面,AI部落小編為企業提供一份
    的頭像 發表于 12-23 10:31 ?172次閱讀

    開源AI模型庫是干嘛的

    開源AI模型庫是指那些公開源代碼、允許自由訪問和使用的AI模型集合。這些模型通常經過訓練,能夠執行特定的任務。以下,是對開源
    的頭像 發表于 12-14 10:33 ?294次閱讀

    云端AI開發者工具怎么用

    云端AI開發者工具通常包括代碼編輯器、模型訓練平臺、自動化測試工具、代碼管理工具等。這些工具不僅降低了A
    的頭像 發表于 12-05 13:31 ?184次閱讀

    AI模型部署和管理的關系

    AI模型的部署與管理是AI項目成功的兩大支柱,它們之間既相互獨立又緊密相連,共同推動著AI技術從實驗室走向實際應用。
    的頭像 發表于 11-21 10:02 ?216次閱讀

    如何在STM32f4系列開發板上部署STM32Cube.AI

    已下載STM32Cube.AI擴展包,但是無法使用,感覺像是沒有部署AI模型,我是想要通過攝像頭拍照,上傳圖像后,經過開發板處理器進行AI模型處理識別過后,告訴我識別結果,顯示在TFL
    發表于 11-18 09:39

    企業AI模型部署怎么做

    AI模型部署作為這一轉型過程中的關鍵環節,其成功實施對于企業的長遠發展至關重要。在此,AI部落小編為您介紹企業AI模型部署的步驟以及注意事項
    的頭像 發表于 11-04 10:15 ?201次閱讀

    Arm推出GitHub平臺AI工具,簡化開發者AI應用開發部署流程

    專為 GitHub Copilot 設計的 Arm 擴展程序,可加速從云到邊緣側基于 Arm 平臺的開發。 Arm 原生運行器為部署云原生、Windows on Arm 以及云到邊緣側的 AI
    的頭像 發表于 10-31 18:51 ?2899次閱讀

    生成式AI工具作用

    生成式AI工具是指那些能夠自動生成文本、圖像、音頻、視頻等多種類型數據的人工智能技術。在此,petacloud.ai小編為您整理生成式AI工具
    的頭像 發表于 10-28 11:19 ?318次閱讀

    真格基金宣布捐贈開源AI項目vLLM

    開源技術處于 AI 革命的中心。Llama 3、Mistral 等開源大模型迅速追趕 GPT-4,TensorFlow、Pytorch 等開源深度學習框架提供了豐富的庫和
    的頭像 發表于 09-24 16:13 ?444次閱讀

    NVIDIA RTX AI套件簡化AI驅動的應用開發

    NVIDIA 于近日發布 NVIDIA RTX AI套件,這一工具和 SDK 集合能夠幫助 Windows 應用開發者定制、優化和部署適用于 Windows 應用的 AI 模型。該套件
    的頭像 發表于 09-06 14:45 ?522次閱讀

    降價潮背后:大模型落地門檻真的降了嗎?

    “比起價格門檻AI大模型的應用門檻,更難跨越。”大模型爭相降價下,AI應用的門檻真的降低了嗎?答案還真不一定。因為除了價格
    的頭像 發表于 06-13 08:04 ?275次閱讀
    降價潮背后:大模型落地<b class='flag-5'>門檻</b>真的降了嗎?

    紅帽發布RHEL AI開發者預覽版,集成IBM Granite模型,簡化AI開發流程

    RHEL AI依托InstructLab開源項目,結合IBM Research的開源授權Granite大型語言模型與InstructLab模型對齊工具,采用LAB(Large-scal
    的頭像 發表于 05-08 15:01 ?534次閱讀

    簡單兩步使用OpenVINO?搞定Qwen2的量化與部署任務

    英特爾 OpenVINO? 工具套件是一款開源 AI 推理優化部署工具套件,可幫助開發人員和企業加速生成式人工智能 (AIGC)、大語言模
    的頭像 發表于 04-26 09:39 ?1845次閱讀
    簡單兩步使用OpenVINO?搞定Qwen2的量化與<b class='flag-5'>部署</b>任務

    簡單三步使用OpenVINO?搞定ChatGLM3的本地部署

    英特爾 OpenVINO? 工具套件是一款開源 AI 推理優化部署工具套件,可幫助開發人員和企業加速生成式人工智能 (AIGC)、大語言模
    的頭像 發表于 04-03 18:18 ?2207次閱讀
    簡單三步使用OpenVINO?搞定ChatGLM3的本地<b class='flag-5'>部署</b>
    万人迷百家乐的玩法技巧和规则| 百家乐官网下载| 百家乐电子路单破解| 大玩家百家乐的玩法技巧和规则| 财神娱乐城信誉| 百家乐官网群html| 百家乐账号变动原因| 北京太阳城老年公寓| 平武县| 百家乐官网赢多少该止赢| 百家乐破解方法技巧| 大发888怎么找不到了| 百家乐官网博彩通网| 澳门百家乐打法精华| 菲律宾太阳城88| 至尊百家乐官网年代| 大世界百家乐娱乐城| 云博国际| 太阳神百家乐官网的玩法技巧和规则 | 百家乐里什么叫洗码| 花莲市| 太阳百家乐官网路单生| 百家乐图形的秘密破解| 皇冠百家乐官网客户端皇冠 | 百家乐官网游戏模拟| 百家乐庄闲庄庄闲| 手游| 太阳城百家乐怎样开户| 沙龙国际| 博狗百家乐官网的玩法技巧和规则| 威尼斯人娱乐城博彩网站| 真人百家乐官网娱乐好玩| 在线百家乐游戏软件| 沙雅县| 百家乐网上真钱麻将| 黔南| 百家乐赢足球博彩皇冠| 明升m88娱乐城| 玩百家乐官网怎么才能赢| 网上玩百家乐游戏有人挣到钱了吗| 百家乐官网游戏机子|