在MIPS中将浮点数除以整数

时间:2015-03-27 14:17:45

标签: assembly floating-point mips cpu-registers

我在两个$ t寄存器中加载了浮点双精度数,现在我想将它除以(-4)(不使用fp指令)并将其存储回$ f寄存器。

mfc1 $t0, $f0  #$f0 = 0x00000000
mfc1 $t1, $f1  #$f1 = 0x40240000
div $t1, $t1, -4
mfhi $t0 #move the remainder to $t0
mflo $t1 #move the quotient to $t1

mtc1 $t0, $f0
mtc1 $t1, $f1


# store the $f0 result in memory
# print X/(-4)


mov.d $f12, $f0
li $v0, 3
syscall

但这会产生非常意外的结果,即-2.231744757682269E231

任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:3)

显然,你不能只使用整数除法。在一般情况下,你必须将数字分解为它们的组成部分,即符号,尾数和指数,然后用整数运算实现除法。

如果你特别想要除以-4,你可以使用它是2的幂的事实,所以你只需要翻转符号位并从指数中减去2。

也许请阅读floating point representations