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