当前位置: 首页 > news >正文

CANN/ge DataFlow Python注册函数指南

# register

【免费下载链接】geGE(Graph Engine)是面向昇腾的图编译器和执行器,提供了计算图优化、多流并行、内存复用和模型下沉等技术手段,加速模型执行效率,减少模型内存占用。 GE 提供对 PyTorch、TensorFlow 前端的友好接入能力,并同时支持 onnx、pb 等主流模型格式的解析与编译。项目地址: https://gitcode.com/cann/ge

产品支持情况

  • Atlas A3 训练系列产品/Atlas A3 推理系列产品:支持
  • Atlas A2 推理系列产品/Atlas A2 训练系列产品:支持

函数功能

注册自定义类型对应的序列化、反序列化、计算size的函数,可结合feed,fetch接口使用,用于feed/fetch任意Python类型。

函数原型

register(msg_type, clz, serialize_func, deserialize_func, size_func=None)

参数说明

参数名称数据类型取值说明
msg_typeint注册的类型ID。
clz类型定义类型定义,比如int,str,或者自定义的class。
serialize_funcfunction序列化函数,输入是任意的Python对象,输出bytes类型的数据,即对象被序列化后的字节流。
deserialize_funcfunction反序列化函数,输入类型为bytes,表示要反序列化的字节流,输出为被反序列化的对象。可以是任何Python对象类型。
size_funcfunction计算序列化后内存大小的函数,单位字节,预留字段。

返回值

正常场景下返回None。

异常情况下会抛出DfException异常。可以通过捕捉异常获取DfException中的error_code与message查看具体的错误码及错误信息。详细信息请参考DataFlow错误码。

调用示例

import cloudpickle import dataflow as df class TestClass(): def __init__(self, name, val): self.name = name self.val = val df.msg_type_register.register(1026, TestClass, lambda obj: cloudpickle.dumps(obj), lambda buffer: cloudpickle.loads(buffer))

约束说明

【免费下载链接】geGE(Graph Engine)是面向昇腾的图编译器和执行器,提供了计算图优化、多流并行、内存复用和模型下沉等技术手段,加速模型执行效率,减少模型内存占用。 GE 提供对 PyTorch、TensorFlow 前端的友好接入能力,并同时支持 onnx、pb 等主流模型格式的解析与编译。项目地址: https://gitcode.com/cann/ge

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

http://www.gsyq.cn/news/1583152.html

相关文章:

  • TruecallerJS API深度解析:如何构建专业的电话号码验证系统
  • 002 使用单片机实现的逻辑分析仪——扩展篇
  • cann/runtime随机数生成示例
  • 性能优化秘籍:TP=2 vs TP=4配置对比,找到最佳GPU资源利用方案
  • Gemma-4-31B-StyleTune vs 传统微调:终极VRAM需求对比分析
  • CANN ops-nn ApplyAdagradD算子
  • 98个公共Tracker完整指南:彻底解决BT下载卡顿难题
  • TruecallerJS实战应用:10个真实场景下的电话号码查询解决方案
  • 5个实战项目:用Deep Learning Illustrated代码构建深度学习应用
  • ComfyUI-LTXVideo完整指南:如何在ComfyUI中轻松生成高质量AI视频
  • CANN运行时设备到主机同步内存复制示例
  • Bernini-R-GGUF-ComfyUI核心功能解析:为什么它是视频创作者的终极工具
  • 快速上手hspec:10分钟学会Haskell BDD测试框架 [特殊字符]
  • 如何3分钟上手vite-vue3-chrome-extension-v3?从安装到第一个扩展的完整指南
  • CANN/catlass优化矩阵乘法示例
  • JoyAI-Image-Edit-Plus-Diffusers核心功能解析:Diffusers库的增强版图像编辑神器
  • Ngx-restangular 测试策略:单元测试和集成测试完整指南
  • 如何用Gemma-4-26B-A4B-StyleTune提升创作质量?新手必看的AI写作指南 [特殊字符]
  • Bernini-R-GGUF-ComfyUI安装教程:5分钟快速部署AI视频生成环境
  • FreeOpcUa在实际项目中的应用案例:工业自动化系统的集成经验
  • Agora-Flutter-SDK高级功能实战:美颜、虚拟背景与空间音频实现
  • The Lightmapper对比分析:与其他Blender光照贴图插件的优劣比较
  • XRCarouselView源码解析:理解iOS轮播控件的核心实现原理
  • 10个CatSniffer实用技巧:从基础嗅探到高级攻击的完整教程
  • Continuum部署指南:从GitHub Releases到Discoverium的应用分发
  • sniffer源码解析:Go语言实现高性能网络流量捕获的关键技术
  • JoyAI-VL-Interaction-Preview技术架构深度解析:8B规模视觉优先模型的设计哲学
  • Haskell测试框架hspec:为什么它是现代Haskell开发的必备工具?[特殊字符]
  • TensorFlow Data Validation 与Apache Beam集成:大规模数据验证的完整解决方案
  • 提升laravel-money性能:处理大量货币数据的优化技巧