在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

Segment Anything量化加速有多強!

英特爾物聯網 ? 來源:OpenVINO 中文社區 ? 2023-06-11 14:24 ? 次閱讀

前言

“分割一切,大家一起失業!”——近期,這樣一句話在社交媒體上大火!這講的就是 Segment Anything Model(簡稱 “SAM” )。SAM 到底是什么?它具備哪些功能?它真的有這么強大嗎?讓我們一起通過本文了解詳情!

SAM 是一個由 Meta AI 實驗室推出的強大人工智能圖像分割應用,可以自動識別哪些圖像像素屬于一個對象,并且對圖像中各個對象進行自動風格處理,可廣泛用于分析科學圖像、編輯照片等。

SAM 的完整應用由一個圖片編碼器模型(encoder)以及掩碼解碼(mask decoder) + 提示編碼模型(prompt encoder)構成,這兩部分都可以被解析為獨立的靜態模型。其中大部分的算力負載和推理延時都集中在圖片編碼器任務,因此如果進一步提升圖片編碼器部分的執行效率,就成為了 SAM 應用的主要優化方向之一。

66ebdbbc-05f2-11ee-962d-dac502259ad0.png

圖:SAM 模型任務pipeline

本次分享將重點演示如何通過 OpenVINO的 NNCF 模型壓縮工具實現對 SAM 編碼器部分的量化壓縮,實現在 CPU 側的性能提升。

01

量化介紹

在正式開始實戰之前,我們不得不提一下量化的概念,量化是指在不改變模型結構的情況下,將模型參數的表達區間從 FP32 映射到 INT8 或是 INT4 范圍,用更小數值位寬來表示相同的信息,實現對于模型體積的壓縮,降低內存消耗,同時在模型網絡的執行過程中,系統會自動調用硬件平臺專門針對低比特數據優化的指令集或 kernel 函數,提升性能。

673320bc-05f2-11ee-962d-dac502259ad0.png

圖:SAM不同精度數據的表示位寬

Intel AVX512 VNNI 擴展指令集實現了將原本需要 3 個時鐘周期才能完成的 INT8 矩陣點乘與加法運算壓縮到一個時鐘周期,而在最新的 AMX 指令集更是將多個 VNNI 模塊進行堆疊實現了單周期內成倍的性能提升。

67543ebe-05f2-11ee-962d-dac502259ad0.png

圖:INT8 矩陣點乘與加法運算指令集優化

02

NNCF 訓練后量化模式

NNCF 工具的全稱是Neural Network Compression Framework,是 OpenVINO 工具鏈中專門用于模型壓縮加速的方案實現,包含量化,剪枝,二值化等多種模型壓縮算法,調用方式又可以分化為訓練后量化 (PTQ)和訓練時壓縮 (QAT)兩種模式,訓練時壓縮要需要引入原始的訓練腳本和數據集,而訓練后量化則可以直接針對訓練生成模型文件進行壓縮,無需額外的訓練腳本和標注數據集參與,這也是 NNCF 在 OpenVINO 2023.0 正式發布的新功能特性, 而這個模式也僅僅需要以下步驟便可實現:

1. 準備校驗數據集

這里的校驗數據僅用作量化過程中對數據表示范圍與分布的計算,因此不需要額外的標簽數據,例如在圖像識別任務中,我們僅需要送入 200-300 張左右的圖片文件即可。此外我們還需要定義 DataLoader 對象與 transform_fn 數據轉換函數, DataLoader 用于讀取校驗數據集中的每一個元素,transform_fn 用于將讀取的元素轉化為 OpenVINO 模型推理的直接輸入數據。

 import nncf
calibration_loader = torch.utils.data.DataLoader(...)
def transform_fn(data_item):
  images, _ = data_item
  return images
calibration_dataset = nncf.Dataset(calibration_loader, transform_fn)

向右滑動查看完整代碼

2. 運行模型量化

首先需要導入模型對象,然后通過 nncf.quantize() 接口,將模型對象與校驗數據集綁定開啟量化任務,NNCF 工具可以支持多種模型對象類型,包含openvino.runtime.Model,torch.nn.Module,onnx.ModelProto以及 tensorflow.Module

model = ... #OpenVINO/ONNX/PyTorch/TF object
quantized_model = nncf.quantize(model, calibration_dataset) 

向右滑動查看完整代碼

3.(可選)準確性控制模式

如果發現 NNCF 在默認模式下的導出的模型準確性下降超過預期,我們也可以使用準確性控制模式(accuracy control)完成訓練后量化,此時我們需要加入帶標簽的測試集數據,用來評估模型在量化過程中哪些 layer 對模型準確性損失的影響(敏感度)比較大,并作為排序依據,依次將這些 layer 回退至原始精度,直到模型符合預期準確性表現。通過這個模式,我們可以在保證模型準確性的情況下,盡可能壓縮模型體積,實現性能和準確性之間的平衡。

04

Segment Anything + NNCF 實戰

接下來讓我們具體一步步看下如何使用 NNCF 的 PTQ 模式完成 SAM encoder 的量化。

1. 定義數據加載器

本示例使用 coco128 作為校驗數據集,其中包含 128 張 .jpg 格式的圖片。由于在量化 ONNX 或 IR 靜態模型的情況下,數據加載器必須是一個 torch 的 DataLoader 類,因此這里我們需要繼承 torch.utils.data.Dataset 并重新構建一個數據集類,其中必須包含__getitem__方法,用于遍歷數據集中的每一個對象,__len__用于獲取數據集的對象數量,最后再通過 torch.utils.data.DataLoader 方法生成數據加載器。

class COCOLoader(data.Dataset):
  def __init__(self, images_path):
    self.images = list(Path(images_path).iterdir())


  def __getitem__(self, index):
    image_path = self.images[index]
    image = cv2.imread(str(image_path))
    image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
    return image
  
  def __len__(self):
    return len(self.images)
  
coco_dataset = COCOLoader(OUT_DIR / 'coco128/images/train2017')
calibration_loader = torch.utils.data.DataLoader(coco_dataset)

向右滑動查看完整代碼

2. 定義數據格式轉化模塊

下一步是定義數據轉化模塊,我們可以調用之前定義 preprocess_image 函數完成數據的預處理,值得注意的是由于 calibration_loader 模塊返回的單個數據對象為 torch tensor 類型,而 OpenVINO 的 Python 接口不支持該類型數據,我們需要先將其強制轉化為 numpy 格式。

def transform_fn(image_data):
  image = image_data.numpy()
  processed_image = preprocess_image(np.squeeze(image))
  return processed_image


calibration_dataset = nncf.Dataset(calibration_loader, transform_fn)

向右滑動查看完整代碼

3. 運行 NNCF 量化

為了確保量化后的模型準確性,這里我們使用原始的 FP32 ONNX 格式模型作為輸入對象,而不是 FP16 的 IR 格式模型,然后再將該對象送入 nncf.quantize 接口執行量化,該函數接口中有幾個比較重要的額外參數:

# Load FP32 ONNX model
model = core.read_model(onnx_encoder_path)
quantized_model = nncf.quantize(model,
                calibration_dataset,
                model_type=nncf.parameters.ModelType.TRANSFORMER,
                preset=nncf.common.quantization.structs.QuantizationPreset.MIXED)
ov_encoder_path_int8 = "sam_image_encoder_int8.xml"
serialize(quantized_model, ov_encoder_path_int8)

向右滑動查看完整代碼

model_type:模型類別,用于開啟特殊的量化策略,例如在類 Transformer 模型中,我們需要優先保證模型的準確性。

preset量化模式,默認為 PERFORMANCE,使用對卷積的權重和偏置均采用對稱量化算法,有助于提升模型性能,此處為了提升模型準確性,我們采用 MIXED 模式,采用權重對稱量化,偏置非對稱量化的方法,適合模型中包含非 Relu 或者非對稱的激活層。

由于 SAM encoder 模型的網絡結構比較復雜,而量化過程中我們需要多次遍歷模型每一個 layer 的參數,所以量化耗時相對會長一些,請大家耐心等待。這邊建議使用 32G 以上內存的硬件設備,如果遇到內存不夠的情況,可以通過 subset_size=100 參數,適當降低校驗數據數量。

4. 模型準確性比較

接下來我們比較下 INT8 和 FP16 模型的推理結果:

67cee254-05f2-11ee-962d-dac502259ad0.png6813cb08-05f2-11ee-962d-dac502259ad0.png

左右滑動查看 prompt 模式 FP16 – INT8 結果比較

6851442e-05f2-11ee-962d-dac502259ad0.jpg6872bcda-05f2-11ee-962d-dac502259ad0.jpg

左右滑動查看 auto 模式 FP16 – INT8 結果比較

可以看到在 prompt 和 auto 模式下,INT8 模型的準確性相較 FP16 模型,幾乎沒有任何變化。

注:auto 模式下,mask 將使用隨機生成的顏色。

5. 性能比較

最后我們通過OpenVINO自帶的 benchmark_app 工具比較下性能指標:

[ INFO ] Execution Devices:['CPU']
[ INFO ] Count:      60 iterations
[ INFO ] Duration:     75716.93 ms
[ INFO ] Latency:
[ INFO ]  Median:    14832.33 ms
[ INFO ]  Average:    14780.77 ms
[ INFO ]  Min:      10398.47 ms
[ INFO ]  Max:      16725.65 ms
[ INFO ] Throughput:  0.79 FPS

Benchmark結果(FP16)

[ INFO ] Execution Devices:['CPU']
[ INFO ] Count:      72 iterations
[ INFO ] Duration:     68936.14 ms
[ INFO ] Latency:
[ INFO ]  Median:    11281.87 ms
[ INFO ]  Average:    11162.87 ms
[ INFO ]  Min:      6736.09 ms
[ INFO ]  Max:      12547.48 ms
[ INFO ] Throughput:  1.04 FPS

Benchmark 結果 (INT8)

可以看到在 CPU 端,INT8 模型相較 FP16 提升了大約 30%, 體積從原本的 350MB 壓縮到了 100MB 不到。

05

總結

鑒于 SAM 出色的自動化分割能力,相信未來會有越來越多應用場景會部署這項技術,而在產業化落地的過程中,開發者往往最關注的就是性能和準確性之間的平衡,以此獲取成本更優的方案。OpenVINO NNCF 工具通過對 Segment Anything encoder 部分的量化壓縮,在幾乎沒有影響模型準確性的情況下,顯著提升模型的運行效率,降低模型占用空間。




審核編輯:劉清

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

    關注

    45

    文章

    3648

    瀏覽量

    134731
  • 人工智能
    +關注

    關注

    1792

    文章

    47399

    瀏覽量

    238902
  • SAM
    SAM
    +關注

    關注

    0

    文章

    112

    瀏覽量

    33545
  • 類加載器
    +關注

    關注

    0

    文章

    6

    瀏覽量

    937

原文標題:分割一切?Segment Anything量化加速有多強!

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

收藏 人收藏

    評論

    相關推薦

    引領輕量化趨勢| 法法易輕量化充電槍通過2023版標準強檢測試

    法法易輕量化充電槍經過嚴格的測試與評估,已正式通過2023新國標測試,并榮獲相應測試報告。通過的測試報告中詳細記錄了充電槍的各項性能指標。包括但不限于充電效率、耐久性、防護等級等,均達到了新國標
    的頭像 發表于 12-24 09:40 ?127次閱讀
    引領輕<b class='flag-5'>量化</b>趨勢| 法法易輕<b class='flag-5'>量化</b>充電槍通過2023版標準強檢測試

    中海達推出輕量化監測簡易感知解決方案

    近期,針對汛期橋梁結構和公路邊坡受自然災害影響出現滑坡、坍塌等事故,交通運輸部和應急管理部密集發布相關政策文件,明確各地需加強橋梁結構和公路邊坡檢測監測工作,多地積極響應政策號召,提出通過輕量化監測簡易感知方案來保障公路安全。順應市場需求,中海達推出中小橋和公路邊坡輕量化
    的頭像 發表于 11-19 11:40 ?360次閱讀

    5G輕量化網關是什么

    5G輕量化網關:物聯網的新引擎 隨著5G技術的不斷發展和普及,物聯網(IoT)領域迎來了新的變革。5G輕量化網關,作為這一變革中的關鍵角色,正逐漸成為連接人、機、物的重要橋梁。本文將深入探討5G
    的頭像 發表于 09-04 15:17 ?313次閱讀
    5G輕<b class='flag-5'>量化</b>網關是什么

    【飛凌嵌入式OK3576-C開發板體驗】rkllm模型量化構建

    (model = modelpath) if ret != 0: print(\'Load model failed!\') exit(ret) 模型量化構建 # Build model ret
    發表于 08-27 22:50

    深度神經網絡模型量化的基本方法

    深度神經網絡模型量化是深度學習領域中的一種重要優化技術,旨在通過減少模型參數的精度(即從高精度浮點數如32位浮點數FP32降低到低精度整數如8位整數INT8或更低)來降低模型的計算和存儲需求,同時
    的頭像 發表于 07-15 11:26 ?709次閱讀

    深度學習模型量化方法

    深度學習模型量化是一種重要的模型輕量化技術,旨在通過減少網絡參數的比特寬度來減小模型大小和加速推理過程,同時盡量保持模型性能。從而達到把模型部署到邊緣或者低算力設備上,實現降本增效的目標。
    的頭像 發表于 07-15 11:01 ?502次閱讀
    深度學習模型<b class='flag-5'>量化</b>方法

    使用esp-dl中的example量化我的YOLO模型時,提示ValueError: current model is not supported by esp-dl錯誤,為什么?

    使用esp-dl中的example量化我的YOLO模型時,提示:ValueError: current model is not supported by esp-dl 錯誤, 請看我的代碼和模型
    發表于 06-28 06:47

    利爾達出席華為RedCap(5G輕量化)產業峰會,協同加速產業繁榮

    //近日,利爾達作為行業領先的物聯網解決方案提供商,受邀參加了在蘇州華為研究所舉辦的RedCap(5G輕量化)產業峰會。此次峰會匯聚了中國信息通信研究院、三大電信運營商、眾多行業巨頭及產業鏈上
    的頭像 發表于 06-21 08:14 ?743次閱讀
    利爾達出席華為RedCap(5G輕<b class='flag-5'>量化</b>)產業峰會,協同<b class='flag-5'>加速</b>產業繁榮

    PCB與PCBA工藝復雜度的量化評估與應用初探!

    問題背景和目標 隨著電子信息產品的精度和復雜 度越來越高,對PCB和PCBA的設計、 制作,以及PCBA組裝都會帶來新的 挑戰和難度。而在我們的工作當中, 因為缺乏對PCB和PCBA量化的評估
    發表于 06-14 11:15

    基于esp32輕量化的PSA及Web3的組件,怎么向組件庫提交component ?

    您好: 我們開發了一套基于 esp32 輕量化的 PSA 及 Web3 的組件,但是應該如何提交到 espressif 的組件庫呢?謝謝
    發表于 06-07 07:29

    存內計算技術工具鏈——量化

    本篇文章將重點講述存內計算技術工具鏈之“量化”,我們將從面向存內計算芯片的深度學習編譯工具鏈、神經網絡中的量化(包括訓練后量化量化感知訓練)、基于存內計算芯片硬件特性的
    的頭像 發表于 05-16 12:35 ?1265次閱讀
    存內計算技術工具鏈——<b class='flag-5'>量化</b>篇

    Keil5提示__segment_end未定義是哪里的問題?

    編譯后的錯誤信息如下: .ObjectsGD_LiteOSTest.axf: Error: L6218E: Undefined symbol __segment_end (referred
    發表于 04-03 07:10

    超級電容的環保性、壽命、充電速度有多強

    超級電容的環保性、壽命、充電速度有多強? 超級電容是一種具有極高能量密度和電荷/放電速度的電子設備,它在環保性、壽命和充電速度方面都具有令人印象深刻的優勢。在本篇文章中,我們將詳細探討超級電容在這
    的頭像 發表于 02-02 10:19 ?1075次閱讀
    主站蜘蛛池模板: 日本三级吹潮| 久久青草视频| 天天摸天天添人人澡| 午夜伦理片免费观看在线| 四虎国产在线| 男人的天堂视频网站清风阁| 快播久久| 337p亚洲精品色噜噜狠狠 | 二区中文字幕| 级毛片| 久久免费视频99| 丁香花成人另类小说| 中文字幕天天干| 欧日韩视频777888| www干| 日产精品卡二卡三卡四卡无卡乱码| 久久婷婷激情| 婷婷综合丁香| 欧美三级视频在线| 国产成人精品日本亚洲语言| 伊人黄色| 国产特黄一级一片免费| 亚洲一区二区视频| 亚洲国产精品久久久久婷婷老年| 日韩毛片在线视频| 黑森林福利视频导航| 午夜日韩| 欧美性猛交xxxx乱大交高清| 老师叫我揉她内裤越快越好| 四虎在线最新地址公告| 精品手机在线视频| 午夜免费观看福利片一区二区三区| 精品视频一区在线观看| 在线观看日本一区| 五月激情六月婷婷| 黄色免费网站在线| 天堂va欧美ⅴa亚洲va一国产| 午夜啪啪网站| 亚洲 欧美 自拍 卡通 综合| 免费人成在线观看网站品爱网日本| 91精品久久国产青草|