INF1612 - Software Básico

Aulas de Laboratório

Manipulação de Números com Ponto Flutuante em Assembler

Reescreva as funções abaixo em assembler. Teste seus resultados.
  1. float foo (double a, float b) {
      return (a+b)*(a-b);
    }
    
  2. float foo1 (float a, float b) {
      return sin(a) + b;
    }
    

    Observação: não use as operações de seno/coseno do coprocessador. Chame explicitamente as funções sin/cos quando necessário. Lembre-se que o argumento dessas funções é um double.

  3. double foo2 (float a, float b) {
      return sin(a) + cos(b);
    }
    
    (Dica: use um espaço na pilha para guardar o resultado da primeira chamada de função.)
  4. double foo3 (double *a, int n) {
      int i;
      double r = 0.0;
      for (i=0; i<n; i++)
        r += sin(a[i]);
      return r;
    }