Advertisement
luizaspan

[PROVA FSC_COMP] Integração Numérica (Trapézio)

Nov 3rd, 2015
384
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 0.68 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <math.h>
  3.  
  4. #define N 1000 // número de "trapézios"
  5.  
  6. double f(double x)
  7. {
  8.     return 1/x; // função a ser integrada
  9. }
  10.  
  11. int main(void)
  12. {
  13.     int i;
  14.     double h,soma=0.0f,a=0.1; // a = menor limite de integração
  15.  
  16.     h=(1.0-a)/N;
  17.  
  18.     for (i=0;i<N;i++)
  19.     {
  20.         double x1 = a + h*i, x2= a + h*(i+1); // necessários dois pontos para realização do método
  21.         soma += (h/2)*(f(x1) + f(x2));
  22.     }
  23.  
  24.     double e = fabs((-log(a)-soma)/-log(a)); // comparação com o valor real da função integrada
  25.  
  26.     printf("Valor calculado: %.15e \nValor real: %.15e \n",soma,-log(a));
  27.     printf("Erro: %e % \n",e*100);
  28.  
  29.     return 0;
  30. }
  31.  
  32. // erro = 1/12 * h^2 * [f'(a) - f'(b)]
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement