Jkljk

MODULARIZAÇÃO - trigo.c (codigo implementado que calcula seno, cosseno e tangente sem o uso da math.h)

Sep 14th, 2020 (edited)
2,403
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. #include "trigo.h"
  2.  
  3. double grausRadianos(double x){
  4.     double aux = (x/180)*PI;
  5.     return aux;
  6. }
  7.  
  8. double fat(double a){
  9.     double valor;
  10.     if( a==1 || a==0 ){
  11.         return 1;
  12.     }
  13.     else{
  14.         valor = a * fat(a-1);
  15.     }
  16.     return valor;
  17. }
  18. double potencia(double base, double expoente){
  19.     int cont=1;
  20.     double aux;
  21.     aux = base;
  22.     if(expoente == 0){
  23.         base=1;
  24.     }
  25.     while(expoente>cont){
  26.         base = base * aux;
  27.         cont++;
  28.     }
  29.  
  30.     return base;
  31. }
  32.  
  33. double cosseno(double x)
  34. {
  35.     int i, sinal = (-1);
  36.     double soma, fatorial=1;
  37.     soma  = 1;
  38.     for(i=2; i<=termos; i+=2)
  39.     {
  40.         fatorial = fat(i);
  41.         soma = soma + sinal * potencia(x, i)/fatorial; //aqui e calculada a serie de maclaurin para o cosseno
  42.         sinal = sinal * (-1);
  43.     }
  44.     return soma;
  45. }
  46. double seno(double x)
  47. {
  48.     int i, sinal = (-1);
  49.     double soma, fatorial=1;
  50.     soma  = x;
  51.     for(i=3; i<=termos; i+=2)
  52.     {
  53.         fatorial = fat(i);
  54.         soma = soma + sinal * potencia(x, i)/fatorial; //serie de maclaurin para seno
  55.         sinal = sinal * (-1);
  56.     }
  57.     return soma;
  58. }
  59. double tangente(double x){
  60.     double resultado1, resultado2, resposta;
  61.     resultado1 = seno(x);
  62.     resultado2 = cosseno(x);
  63.     resposta = resultado1/resultado2; // como a tang = sen/cos, simplesmente é divido o retorno da chamada das duas funçoes
  64.     return resposta;
  65.  
  66. }
RAW Paste Data