// Approximating the area under sqrt(4-x^2) on [0, 2] using the Trapezoidal Rule.
// Version 2:  A function performs the area computation.

#include <iostream.h>
#include <math.h>

double f(double x);
/* function to be used in the area approximation */

double area(double a, double b, int n);
/* Approximation of area under f(x) on [a, b] using the Trapezoidal Rule */

int main (void)
{  int n;
   cout << "Program approximates the area under a function using the "
        << "Trapezoidal Rule." << endl;
   cout << "Enter number of subintervals to be used: ";
   cin  >> n;
   cout << "The approximate area is " << area (0.0, 2.0, n) << endl;
   return 0;
}

double f(double x) 
/* function to be used in the area approximation */
{  return (sqrt(4.0 - x*x));
}
 
double area (double a, double b, int n)
/* Finding area via the Trapezoidal Rule */
{  double width = (b - a) / n; 
   double sum = (f(a) + f(b)) / 2.0;   /* first and last terms in sum */
   double xvalue;

   for (xvalue = a + width; xvalue < b; xvalue += width)
      sum += f(xvalue);
   return (sum * width);
}
