首页/指令库/VASUBU-VV
VASUBU.VV

RISC-V VASUBU.VV 指令详解

指令手册R-type

向量无符号平均减:vd[i] = roundoff_unsigned(vs2[i] - vs1[i], 1)。

指令语法

vasubu.vv vd, vs2, vs1, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
V向量运算定点算术

指令行为说明

VASUBU.VV 执行 RVV 无符号定点平均减。差值右移 1 位并按 vxrm 舍入后写回 SEW 位结果;减法溢出按 SEW 结果处理,不是饱和减法。

快速理解与检索要点

VASUBU.VV 是定点平均减法,核心区别是无符号解释和 vxrm 舍入。

舍入模式来自 vxrm(rnu/rne/rdn/rod),不是浮点 frm。
结果不是饱和结果;需要饱和语义时应选择饱和定点指令。
只对 vl 范围内的活动元素执行;非活动元素和尾部元素受当前 vma/vta 策略影响。
除专用掩码指令外,vm=0 使用 v0 作为执行掩码,vm=1 表示不使用掩码。

常见使用场景

信号处理

结合 «vsetvli t0, a0, e32, m1, ta, ma vasubu.vv v1, v2, v3» 等实际代码理解该场景。

图像处理

结合 «vsetvli t0, a0, e32, m1, ta, ma vasubu.vv v1, v2, v3» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 R-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

舍入由 vxrm 控制(rnu/rne/rdn/rod),不是固定加 1 后右移。
vasub/vasubu 的溢出被忽略并按 SEW 回绕。

常见问题

VASUB 和 VASUBU 的区别是什么?

VASUB 按有符号元素解释差值,VASUBU 按无符号元素解释差值;二者都使用 vxrm 做平均减的舍入。