summaryrefslogtreecommitdiff
path: root/test/approx_derivative.t.c
blob: 6bcac793fc216b64499e0ce32d096e0598c34f35 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include "lizfcm.test.h"

double f(double x) { return x * x; }

double f_prime(double x) { return 2 * x; }

double H = 0.0001;
double ACCEPTED_DERIVATIVE_ERROR = 0.0001;

UTEST(derivative, central) {
  double a = 3.0;
  double expected = f_prime(a);
  double f_prime_x = central_derivative_at(&f, a, H);

  EXPECT_NEAR(expected, f_prime_x, ACCEPTED_DERIVATIVE_ERROR);
}

UTEST(derivative, forward) {
  double a = 3.0;
  double expected = f_prime(a);
  double f_prime_x = forward_derivative_at(&f, a, H);

  EXPECT_NEAR(expected, f_prime_x, ACCEPTED_DERIVATIVE_ERROR);
}

UTEST(derivative, backward) {
  double a = 3.0;
  double expected = f_prime(a);
  double f_prime_x = backward_derivative_at(&f, a, H);

  EXPECT_NEAR(expected, f_prime_x, ACCEPTED_DERIVATIVE_ERROR);
}