这些指令使用 vxrm 吗?
不使用。浮点算术和转换使用 frm 或指令规定的固定舍入;vxrm 用于定点舍入指令。
浮点融合乘加/乘减:vd[i] = +(f[rs1] * vd[i]) + vs2[i]。
VFMADD.VF 按官方 RVV FMA 公式执行:vd[i] = +(f[rs1] * vd[i]) + vs2[i]。乘法和加/减融合为一次舍入,不产生中间舍入的乘积;旧 vd 也是乘法输入之一,vs2 是加数或减数。 向量 FP32/FP64 操作需要相应标量 F/D 支持;FP16 由相应向量半精度扩展控制,基础 V 扩展不自动包含半精度算术。
VFMADD.VF 的关键是官方 FMA 公式 vd[i] = +(f[rs1] * vd[i]) + vs2[i] 和单次舍入语义。
结合 «vsetvli t0, a0, e32, m1, ta, ma vfmadd.vf v1, ft0, v2 # vd[i] = +(f[rs1] * vd[i]) + vs2[i]» 等实际代码理解该场景。
结合 «vsetvli t0, a0, e32, m1, ta, ma vfmadd.vf v1, ft0, v2 # vd[i] = +(f[rs1] * vd[i]) + vs2[i]» 等实际代码理解该场景。
不使用。浮点算术和转换使用 frm 或指令规定的固定舍入;vxrm 用于定点舍入指令。