首页/指令库/FROUNDNX-Q
FROUNDNX.Q

RISC-V FROUNDNX.Q 指令详解

指令手册R-type

把四精度浮点数按 rm 舍入到整数值,结果仍为浮点格式,并按需设置 NX。

指令语法

froundnx.q rd, rs1, rm
操作数说明
rd:目标浮点寄存器,接收该格式的浮点结果。
rs1/rs2:源浮点寄存器;带 rm 的算术/舍入指令由 rm 或动态 frm 选择舍入模式。
ZfaQ浮点精度

指令行为说明

FROUNDNX.Q 将 f[rs1] 的四精度浮点值按 rm 指定的舍入模式舍入为整数值,但结果仍以四精度浮点格式写入 f[rd]。FROUNDNX 版本在结果不精确时设置 NX。信号 NaN 设置 NV;quiet NaN 按浮点规则传播为 NaN。

快速理解与检索要点

FROUNDNX.Q 和 FCVT 的区别是输出类型:FROUNDNX.Q 输出仍在浮点寄存器中,只是数值被舍入到整数值。FROUNDNX 还会报告不准 NX。

rm 选择舍入方向,动态舍入由 frm 提供。
零和无穷等特殊值按 Zfa 规则处理;信号 NaN 仍设置 NV。

常见使用场景

浮点舍入

结合 «froundnx.q f0, f1, rne # f0 = round(f1) with inexact flag» 等实际代码理解该场景。

数值格式处理

结合 «froundnx.q f0, f1, rne # f0 = round(f1) with inexact flag» 等实际代码理解该场景。

使用前检查清单

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

容易混淆 / 常见误区

FROUNDNX 会在不精确时设置 NX;不要与不设置 NX 的 FROUND 混淆。
结果仍是浮点数,不是整数寄存器结果;若需要整数结果使用 FCVT。
rm 控制舍入到整数值的方向。

常见问题

FROUNDNX.Q 会把结果写入整数寄存器吗?

不会。结果仍写入浮点寄存器 f[rd];只是浮点值已经是整数值。

FROUNDNX.Q 和 FROUND.Q 有什么差异?

FROUNDNX 在不精确时设置 NX;FROUND 不设置 NX。