伦伦影院久久影视,天天操天天干天天射,ririsao久久精品一区 ,一本大道香蕉大久在红桃,999久久久免费精品国产色夜,色悠悠久久综合88,亚洲国产精品久久无套麻豆,亚洲香蕉毛片久久网站,一本一道久久综合狠狠老

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

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

3天內不再提示

自定義算子開發

地瓜機器人 ? 2022-04-07 16:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

地平線工具鏈中已經支持了豐富的算子,在大多數情況下,您的模型應該可以通過使用hb_mapper工具完成轉換并順利部署到地平線芯片上。 少部分算子不支持情況下,我們建議您先嘗試下替換算子的可能性,這樣有利于將地平線芯片能力充分發揮出來。

自定義算子目前只提供CPU算子開發能力,可自定義onnx算子以及caffe算子。一個完整的自定義算子應用過程包括注冊算子、算子實現、含自定義算子模型轉換和運行含自定義op模型四個階段。

1 自定義onnx算子

1.1 將含有自定義算子的pytorch模型導出ONNX

使用torch.onnx.register_custom_op_symbolic注冊自定義算子,再導出onnx模型。有以下幾處配置參數需要注意:

1. register_custom_op_symbolic函數的第一個參數'::adaptive_avg_pool2d'為pytorch對應操作符名稱,若填寫錯誤,則會導致自定義算子注冊失敗

2. 操作域必須設置為horizon.custom,算子類型為PyOp

3. class_name_s需要與算子實現文件中的類名相對應

4. module_s與算子實現文件名相同,若算子實現文件在當前目錄的子目錄(custom_op)中,要將相對路徑包含進去:"custom_op/sample_custom"

5. 必須指定input_types_i、output_types_i、output_shape_s三個參數

6. 注意指定opset_version為10或11

參考代碼:

import torch

from horizon_nn.horizon_onnx.onnx_pb import TensorProto

from torch.onnx.utils import register_custom_op_symbolic

#prepare your model and input_data

def horizon_pool(g, input, output_size):

return g.op(

'horizon.custom::PyOp', #required, ! must be 'horizon.custom' domain !

input,

class_name_s="GlobalAveragePool", #required ! must match the class def name in sample_custom python file !

compute_s="compute", #optional, 'compute' by default

module_s="sample_custom",#required ! must match the file name of the "op_register_files" !

input_types_i=[TensorProto.FLOAT], #required

output_types_i=[TensorProto.FLOAT],#required

output_shape_s=["1, 1024, 1, 1"]) #required

register_custom_op_symbolic('::adaptive_avg_pool2d',

horizon_pool,

opset_version=11)

torch.onnx.export(model, input_data, "custom_op.onnx", opset_version=11)

1.2 算子實現

對應上一節注冊自定義算子時配置的算子實現文件(class_name需要保持一致)。

#sample_custom.py

import numpy as np

from horizon_nn.custom import op_implement_register

@op_implement_register("CustomIdentity")

class CustomIdentity(object):

def __init__(self, kernel_size, threshold):

self._kernel_size = kernel_size

self._default_threshold = threshold

def compute(self, X):

return X

@op_implement_register("GlobalAveragePool")

class GlobalAveragePool(object):

def __init__(self):

pass

def compute(self, X):

return np.nanmean(X, axis=(2, 3)).reshape(-1, 1024, 1, 1)

2 自定義caffe算子

2.1 修改prototxt

在原始模型文件中,將自定義算子對應的類型標記為"Custom" ,并設置custom_param。params 是算子的傳入參數,指定方式為‘param_name’:param_value, 多個參數之間使用 \n 分隔。

layer {

name: "hr_op"

type: "Custom"

bottom: "res3d_in"

top: "res3d"

custom_param {

kind: "CustomIdentity"

shape {

dim: 1

dim: 512

dim: 28

dim: 28

}

params: "'kernel_size': 10 \n'threshold': 0.5"

}

}

2.2 算子實現

相比于onnx模型,caffe模型的自定義算子實現還需要提供該算子的輸出尺寸。

#sample_custom.py

from horizon_nn.custom.op_registration import op_implement_register, op_shape_infer_register

@op_implement_register("CustomIdentity")

class CustomIdentity(object):

def __init__(self, kernel_size, threshold):

self._kernel_size = kernel_size

self._default_threshold = threshold

def compute(self, X):

return X

@op_shape_infer_register("CustomIdentity")

def infer_shape(inputs_shape):

"""Infer the output shapes of the custom operator.

Arguments:

input_shapes: A list of input shapes.

Returns:

Return a list of custom operator's output shapes.

"""

outputs_shape = inputs_shape

return outputs_shape

3 含自定義算子的模型轉換

在模型轉換配置文件中,添加自定義算子相關參數,示例如下:

poYBAGJOnKmALm2DAAI_kfFzMYs348.png

custom_op_method固定使用 register

op_register_files自定義算子計算的實現文件,如果有多份實現,使用 ‘;’ 將各個文件分開即可。

4 含自定義算子的模型推理

想將包含自定算子的.bin模型順利部署到開發板上,還需要提供自定義算子的C++代碼實現。 您可以使用下文提供的模板進行修改:

頭文件:

// custom_identity.h

#ifndef ADVANCED_SAMPLES_CUSTOM_IDENTITY_H_

#define ADVANCED_SAMPLES_CUSTOM_IDENTITY_H_

#include

#include

#include "dnn/hb_dnn.h"

#include "dnn/plugin/hb_dnn_layer.h"

#include "dnn/plugin/hb_dnn_ndarray.h"

namespace hobot {

namespace dnn {

Layer *CustomIdentity_layer_creator();

class CustomIdentity : public Layer {

public:

CustomIdentity() = default;

~CustomIdentity() override = default;

public:

int32_t Init(const Attribute &attributes) override;

int32_t Forward(const std::vector &bottomBlobs,

std::vector &topBlobs,

const hbDNNInferCtrlParam *inferCtrlParam) override;

std::string GetType() const override { return "CustomIdentity"; }

private:

std::string module_;

};

} // namespace dnn

} // namespace hobot

#endif

cpp文件:

// custom_identity.cpp

#include "custom_identity.h"

namespace hobot {

namespace dnn {

Layer *CustomIdentity_layer_creator() { return new CustomIdentity; }

int32_t CustomIdentity::Init(const Attribute &attributes) {

// unused attribute, just demonstrating

attributes.GetAttributeValue(&module_, "module");

return 0;

}

int32_t CustomIdentity::Forward(const std::vector &bottomBlobs,

std::vector &topBlobs,

const hbDNNInferCtrlParam *inferCtrlParam) {

const NDArray *input = bottomBlobs[0];

NDArray *out = topBlobs[0];

const auto *input_data = input->Dptr();

auto *out_data = out->Dptr();

uint32_t size = input->Size();

for (uint32_t i = 0U; i < size; i++) {?

out_data[i] = input_data[i];

}

return 0;

}

} // namespace dnn

} // namespace hobot

將以上兩個文件放在當前工程目錄下之后,編寫infer代碼時僅需要在加載模型之前增加對算子的注冊即可,注冊可參考以下代碼:

//infer.cpp

#include "custom_identity.h"

// register custom layer

hbDNNRegisterLayerCreator("CustomIdentity",

hobot::dnn::CustomIdentity_layer_creator)

本文轉載自地平線開發者社區:https://developer.horizon.ai
原作者:顏值即正義
原文鏈接:https://developer.horizon.ai/forumDetail/71036525692881018

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

    關注

    0

    文章

    16

    瀏覽量

    7413
  • 模型轉換
    +關注

    關注

    0

    文章

    4

    瀏覽量

    5399
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    使用Python/MyHDL創建自定義FPGA IP

    使用 Python/MyHDL 創建自定義 FPGA IP,與 Vivado 集成,并通過 PYNQ 進行控制——實現軟件上的簡單硬件設計。
    的頭像 發表于 04-09 09:53 ?74次閱讀
    使用Python/MyHDL創建<b class='flag-5'>自定義</b>FPGA IP

    MCUXpresso SDK創建自定義清單

    概述 MCUXpresso SDK 24.12 介紹塞德恩漢CED支持自定義清單,使開發人員能夠精確定義其工作區中包含哪些組件、驅動程序、中間件和板支持包。此功能在極簡主義、可重復性和 CI/CD
    發表于 04-07 07:11

    極海APM32F427如何實現自定義USB HID設備與PC進行通信

    最近需要使用到 APM32F427 枚舉成Custom HID設備進行用戶自定義通信,但是官方的例程只有提供的HID枚舉為鼠標或者鍵盤類型的設備。這里記錄一下,怎么使用Geehy官方的USB中間件,實現自定義的USB HID設備進行用戶通信。
    的頭像 發表于 03-30 09:30 ?2669次閱讀
    極海APM32F427如何實現<b class='flag-5'>自定義</b>USB HID設備與PC進行通信

    如何為 Vision Five 2 編譯自定義 Linux 內核?

    參考、幫助和鏈接,說明如何為 Vision Five 2 編譯自定義內核以及 StarFive 開發團隊必須提供哪些驅動程序,那就太好了。
    發表于 02-24 07:44

    如何在TensorFlow Lite Micro中添加自定義操作符(2)

    reshape算子進行說明,如何將reshape算子注冊到解析器中,接下來介紹如果我們想自定義一個算子需要干些什么。
    的頭像 發表于 12-26 10:53 ?1508次閱讀

    電能質量監測裝置可自定義監測時段嗎?

    電能質量監測裝置普遍支持自定義監測時段,現代中高端裝置還具備分時差異化監測與靈活觸發能力,可按時間、事件或混合策略定制采集與存儲,兼顧精度、效率與存儲成本。 一、自定義監測時段的核心實現方式 1.
    的頭像 發表于 12-10 16:49 ?1150次閱讀

    電能質量在線監測裝置的自定義監測時段功能有哪些應用場景?

    電能質量在線監測裝置的 自定義監測時段功能 ,核心價值是通過 “按需配置監測時間、采樣頻率和數據策略”,實現精準監測、資源優化與數據針對性分析,其應用場景覆蓋工業生產、商業運營、電網運維、特殊保障等
    的頭像 發表于 12-10 14:01 ?492次閱讀
    電能質量在線監測裝置的<b class='flag-5'>自定義</b>監測時段功能有哪些應用場景?

    無圖形界面模式下自定義檢查工具的應用

    此前文章已介紹 ANSA 中的自定義檢查工具。本文將探討該功能在無圖形界面(No-GUI)模式下的應用,旨在滿足標準化工作流程的需求,適用于需要高度自動化的前處理場景。通過集成自定義檢查,用戶可實現工作流程的高效自動化運行。
    的頭像 發表于 11-30 14:13 ?711次閱讀
    無圖形界面模式下<b class='flag-5'>自定義</b>檢查工具的應用

    采用匯編指示符來使用自定義指令

    具體實現 1、采用.word .half .dword等匯編指示符直接插入自定義指令,這種方法需要自己指定寄存器。其中.word為插入一個字的數據即32位,.half為插入半字即16位
    發表于 10-28 06:02

    如何使用SDK進行自定義音頻播放功能

    在上一篇文章安信可離線語音模組 VC-01、VC-02 系列教程 【二次開發篇】自定義音頻替換失敗過程中,簡要概述了res_build_tool.py 文件, 其主要的作用就是將音頻文件進行轉換,從而使編譯固件的時候能夠將音頻文件編譯到BIN中,然后在各項事件觸發的時候實
    的頭像 發表于 09-25 15:52 ?4165次閱讀
    如何使用SDK進行<b class='flag-5'>自定義</b>音頻播放功能

    LOTO示波器自定義解碼功能—CANFD解碼

    LOTO示波器軟件更新了自定義解碼功能,并在bilibili上傳了演示視頻,視頻鏈接: https://www.bilibili.com/video/BV1wq3ezjEjQ
    的頭像 發表于 07-11 10:34 ?1156次閱讀
    LOTO示波器<b class='flag-5'>自定義</b>解碼功能—CANFD解碼

    大彩講堂:VisualTFT軟件如何自定義圓形進度條

    VisualTFT軟件如何自定義圓形進度條
    的頭像 發表于 07-07 17:10 ?1814次閱讀
    大彩講堂:VisualTFT軟件如何<b class='flag-5'>自定義</b>圓形進度條

    KiCad 中的自定義規則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規則系統,并詳細講解了自定義規則的設計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
    的頭像 發表于 06-16 11:17 ?2451次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規則(KiCon 演講)

    HarmonyOS應用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統默認鍵盤的解決方案,可實現鍵盤個性化交互。允許用戶結合業務需求與操作習慣,對按鍵布局進行可視化重構、設置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義鍵盤可以
    的頭像 發表于 06-05 14:19 ?2563次閱讀

    如何使用自定義設置回調函數?

    你好,我正在嘗試編寫自己的自定義設置回調函數,并使用 fastEnum=false。 是否有任何代碼示例或資料可供我參考? void CyU3PUsbRegisterSetupCallback
    發表于 05-21 06:11