annotate gcc/testsuite/g++.old-deja/g++.robertl/eb120.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run }
kono
parents:
diff changeset
2 template<double functionToIntegrate(double)>
kono
parents:
diff changeset
3 double integrate(double a, double b, int numSamplePoints)
kono
parents:
diff changeset
4 {
kono
parents:
diff changeset
5 // PRECONDITION(numSamplePoints > 1);
kono
parents:
diff changeset
6 double delta = (b-a) / (numSamplePoints-1);
kono
parents:
diff changeset
7 double sum = 0.;
kono
parents:
diff changeset
8 for (int i=0; i < numSamplePoints; ++i)
kono
parents:
diff changeset
9 sum += functionToIntegrate(a + i*delta);
kono
parents:
diff changeset
10 return sum * (b-a) / numSamplePoints;
kono
parents:
diff changeset
11 }
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 inline double myFunction(double x)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 return 1 / (1 + x);
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 // Example use
kono
parents:
diff changeset
19 int main() {
kono
parents:
diff changeset
20 double z = integrate<myFunction>(0.0, 1.0, 50);
kono
parents:
diff changeset
21 return 0 ;
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23