aboutsummaryrefslogtreecommitdiff
path: root/src/modules/position_estimator_mc/codegen/kalman_dlqe1.c
blob: 977565b8ed7a95adeffbf35401bdfc55ba9a512e (plain) (blame)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*
 * kalman_dlqe1.c
 *
 * Code generation for function 'kalman_dlqe1'
 *
 * C source code generated on: Wed Feb 13 20:34:32 2013
 *
 */

/* Include files */
#include "rt_nonfinite.h"
#include "kalman_dlqe1.h"

/* Type Definitions */

/* Named Constants */

/* Variable Declarations */

/* Variable Definitions */

/* Function Declarations */

/* Function Definitions */
void kalman_dlqe1(const real32_T A[9], const real32_T C[3], const real32_T K[3],
                  const real32_T x_aposteriori_k[3], real32_T z, real32_T
                  x_aposteriori[3])
{
	printf("[dlqe input]: x_aposteriori_k %12.8f\t %12.8f\t %12.8f\t z:%12.8f\n", (double)(x_aposteriori_k[0]), (double)(x_aposteriori_k[1]), (double)(x_aposteriori_k[2]), (double)z);
	printf("[dlqe input]: C[0]: %12.8f\tC[1] %12.8f\tC[2] %12.8f\n", (double)(C[0]), (double)(C[1]), (double)(C[2]));
  real32_T y;
  int32_T i0;
  real32_T b_y[3];
  int32_T i1;
  real32_T f0;
  y = 0.0F;
  for (i0 = 0; i0 < 3; i0++) {
    b_y[i0] = 0.0F;
    for (i1 = 0; i1 < 3; i1++) {
      b_y[i0] += C[i1] * A[i1 + 3 * i0];
    }

    y += b_y[i0] * x_aposteriori_k[i0];
  }

  y = z - y;
  for (i0 = 0; i0 < 3; i0++) {
    f0 = 0.0F;
    for (i1 = 0; i1 < 3; i1++) {
      f0 += A[i0 + 3 * i1] * x_aposteriori_k[i1];
    }

    x_aposteriori[i0] = f0 + K[i0] * y;
  }
  //printf("[dlqe output]: x_aposteriori %12.8f\t %12.8f\t %12.8f\n", (double)(x_aposteriori[0]), (double)(x_aposteriori[1]), (double)(x_aposteriori[2]));
}

/* End of code generation (kalman_dlqe1.c) */