mip中的fibonacci序列并将结果存储在2个寄存器中

时间:2015-03-22 19:34:05

标签: assembly mips 32-bit

我用mips写了一个Fibonacci程序,最大的Int将达到 1836311903 ,因为它存储在$ t3寄存器中。

我读到可以超越这个我使用2个寄存器来存储fib值。

下面是我的代码如何查找fib序列,它的最大术语是44。

    .data 
fib:.word
    .text
    .globl  main
main:

    # The loop
        li      $t2, 1                  # Initialize f_old to 1
        li      $t1, 0                  # Initialize f_older to 0
        li      $t4, 2                  # Initialize counter i to 2
        li  $t0 ,0          #This is the n in fib(n)
        la  $s0,fib
        li  $t9 , 44   #this is the max value of n that can be stored in 32bit , anything greater causes overflow.
lp_tst: blt    $t9, $t0, done          # If $t4 > $t0 (i >  n), 
                                        #    branch out of loop.
                                        #    Otherwise continue.
        add     $t3, $t2, $t1           # Add f_old to f_older
        move    $t1, $t2                # Replace f_older with f_old
        move    $t2, $t3                # Replace f_old with f_new

    sw  $t2 , 0($s0)

        addi    $t4, $t4, 1             # Increment i (i++)
        addi    $t0,$t0,1
        j       lp_tst                  # Go to the loop test

        # Done with the loop, print result
done:   li      $v0, 1                  # Code to print an int
        move    $a0, $t2                # Put f_old in $a0
        syscall                         # Print the string


        li      $v0, 10
        syscall

关于如何将值存储在多个寄存器中以允许它存储64位整数的任何想法?

感谢

2 个答案:

答案 0 :(得分:2)

假设64位f_old位于$t2:$t1f_older位于$t4:$t3中:

addu  $t5, $t1, $t3    # f_new.lo = f_old.lo + f_older.lo 
sltu  $t0, $t5, $t1    # set "carry" in $t0 if f_new.lo < f_old.lo  
addu  $t0, $t0, $t4    # f_older.hi + carry
addu  $t6, $t0, $t2    # f_new.hi = f_old.hi + f_older.hi + carry

现在,64位f_new位于$t6:$t5

答案 1 :(得分:0)

如果使用32位无符号整数,则可以计算fib(47)。您可以使用下面的代码来消除某些寄存器的使用并缩短代码。我没有检查代码,因为我没有mips board或mips模拟器,我也不知道你正在使用哪个版本。

        li      $t9,47          #max value for n
#fibonacci code                 #i = 0 (for comments only, not in code)
        li      $t1,0           #if n odd, t1 = 0 = fib( 0)
        andi    $t0,$t9,1       #          t0 = 1 = fib(-1)
        bgtz    $t0,fib1        #br if n odd
        li      $t1,1           #if n even, t0 = 0, t1 = 1
        j       fib2            #br to check for n == 0
fib0:   add     $t1,$t1,$t0     #i++, fib(i-2) += fib(i-1), t1 = fib(i)
fib1:   add     $t0,$t0,$t1     #i++, fib(i-2) += fib(i-1), t0 = fib(i)
fib2:   subi    $t9,$t9,2       #loop if not done
        bgez    $t9,fib0
                                #result in t0