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

Relay IR的核心数据结构

Apache TVMRelay IR 中,基础节点(VarConstCallFunctionExpr)是构建计算图的核心数据结构。以下是对它们的详细解析,包括定义、作用、内部组成及相互关系:


1. Expr(表达式基类)

作用

  • 所有 Relay IR 节点的基类,提供统一的类型系统和遍历接口。
  • 支持递归访问、变换和类型检查。

关键组成

字段/方法说明
checked_type_表达式的推断类型(如 TensorTypeTupleType)。
span源代码位置信息(用于调试和错误报告)。
VisitAttrs(visitor)递归访问所有属性和子节点(用于序列化、优化等)。
Mutate()生成表达式的副本(用于变换和优化)。

子类关系

Expr
Var
Const
Call
Function
Tuple
Let
If

2. Var(变量)

作用

  • 表示计算图中的 输入变量中间变量(符号化张量)。
  • 类似于深度学习模型中的输入占位符或中间激活值。

关键组成

字段说明
name_hint变量名称(字符串标识符,如 "x")。
type_annotation变量的显式类型注解(可选,如 TensorType({1,3}, float32))。
vid内部唯一 ID(用于优化和去重)。

示例

// 定义一个浮点型张量变量
Var x("x", TensorType({1, 3}, DataType::Float(32)));

3. Const(常量)

作用

  • 表示 不可变的数据(如模型权重、超参数)。
  • 在计算图中作为叶子节点存在。

关键组成

字段说明
data存储的常量值(runtime::NDArrayrelay::ConstantNode)。
checked_type_常量的类型(通常从 data 自动推断)。

示例

// 定义一个常量张量
NDArray weight = NDArray::Empty({3, 3}, DataType::Float(32), {kDLCPU, 0});
Const weight_const(weight);

4. Call(函数调用)

作用

  • 表示对 算子(Operator)函数(Function) 的调用。
  • 是构建计算图的核心节点(如 addconv2d)。

关键组成

字段说明
op调用的目标(OpFunctionGlobalVar)。
args参数列表(Array<Expr>,可以是 VarConst 或其他 Call)。
attrs调用的属性(如卷积的 stridespadding)。

示例

// 调用加法算子
Expr a = Var("a", TensorType({1}, DataType::Float(32)));
Expr b = Var("b", TensorType({1}, DataType::Float(32)));
Expr add_call = Call(Op::Get("add"), {a, b});

5. Function(函数定义)

作用

  • 封装可复用的计算单元(类似 Lambda 表达式)。
  • 用于表示模型中的子图或复合算子(如 conv2d + relu 融合)。

关键组成

字段说明
params输入参数列表(Array<Var>)。
body函数体的表达式(Expr)。
ret_type返回值的类型(如 TensorType)。
type_params泛型类型参数(支持多态,类似 C++ 模板)。

示例

// 定义一个简单的加法函数
Var x("x", TensorType({1}, DataType::Float(32)));
Var y("y", TensorType({1}, DataType::Float(32)));
Expr body = Call(Op::Get("add"), {x, y});
Function add_func({x, y}, body, TensorType({1}, DataType::Float(32)));

6. 节点间的协作关系

计算图示例

z = (x + y) * 2

对应的 Relay IR 结构:

  1. 变量xyVar 节点)。
  2. 常量2Const 节点)。
  3. 调用add(x, y)multiply(add_result, 2)Call 节点)。
  4. 函数:封装整个计算(Function 节点)。

代码实现

Var x("x", TensorType({1}, DataType::Float(32)));
Var y("y", TensorType({1}, DataType::Float(32)));
Expr add = Call(Op::Get("add"), {x, y});
Expr two = Const(NDArray::FromVector({2.0f}));
Expr mul = Call(Op::Get("multiply"), {add, two});
Function func({x, y}, mul, TensorType({1}, DataType::Float(32)));

7. 类型系统支持

所有 Expr 节点都关联类型信息:

  • Var/Const:通过 type_annotationchecked_type_ 指定张量类型。
  • Call:根据算子的类型规则推断返回类型(如 add(Tensor, Tensor) -> Tensor)。
  • Function:通过 ret_type 声明返回值类型。

总结

节点角色关键特性
Expr所有节点的基类提供类型检查和遍历接口。
Var输入/中间变量符号化表示,支持类型注解。
Const常量数据存储不可变值(如权重)。
Call算子或函数调用构建计算图的核心节点,依赖 opargs
Function可复用的计算单元封装参数、计算体和返回类型,支持多态。

这些基础节点共同构成了 Relay IR 的 静态计算图,通过组合它们可以表示复杂的深度学习模型,并为后续优化和代码生成提供基础。

相关文章:

  • Docker 与 Docker-Compose 的区别
  • leetcode day36 01背包问题 494
  • 08_Docker Portainer可视化管理
  • 【Linux】47.高级IO(1)
  • SQLiteDatabase 增删改查(CRUD)详细操作
  • Java函数生成实际应用案例:数据处理流水线
  • # 基于PyTorch的食品图像分类系统:从训练到部署全流程指南
  • 基于javaweb的SpringBoot校园失物招领系统设计与实现(源码+文档+部署讲解)
  • 鸿蒙NEXT开发权限工具类(申请授权相关)(ArkTs)
  • Python-27:游戏英雄升级潜力评估
  • 【TeamFlow】4.3.1 SI单位系统库(Units)
  • 《MySQL 核心技能:SQL 查询与数据库概述》
  • 达梦官方管理工具 SQLark 更新--不仅支持达梦、Oracle、MySQL,还新增 PostgreSQL 数据库!
  • android 发送onkey广播,Android 添加键值并上报从驱动到上层
  • PerfettoSQL
  • 【RAG】一篇文章介绍多模态RAG(MRAG)
  • 电商虚拟户分账系统:破解电商资金管理难题的密钥
  • 蓝牙耳机开发--提示音制作生成的方法
  • 深入探索RAG:用LlamaIndex为大语言模型扩展知识,实现智能检索增强生成
  • Win10 关闭自动更新、关闭自动更新并重启
  • 被电诈100万元又要被骗71万元,女子经民警近8小时劝阻幡然醒悟
  • 长征十梦舟揽月稳步推进
  • 大学2025丨本科专业大调整,教育专家:化解就业难背后供需错配
  • 艺术家会怎么造机器人?
  • 纪念沈渭滨︱“要把近代史搞得会通”——读《士与大变动时代》随札
  • 现货黄金价格站上3400美元,今年迄今累涨逾29%