demo/math/quadratic_fit/calc.c

64 lines
3.3 KiB
C
Raw Normal View History

2024-07-21 16:07:07 +08:00
#include "calc.h"
static NUM_TYPE quadratic_fit_sumx1_arr[CALC_POINTS];
static NUM_TYPE quadratic_fit_sumx2_arr[CALC_POINTS];
static NUM_TYPE quadratic_fit_sumx1;
static NUM_TYPE quadratic_fit_sumx2;
static NUM_TYPE quadratic_fit_sumx3;
static NUM_TYPE quadratic_fit_sumx4;
static NUM_TYPE quadratic_fit_d;
static NUM_TYPE quadratic_fit_matrix[3][3];
void calc_quadratic_fit_init(int length)
{
for (int i = 0; i < length; i++) {
quadratic_fit_sumx1_arr[i] = (NUM_TYPE)i;
quadratic_fit_sumx2_arr[i] = quadratic_fit_sumx1_arr[i] * quadratic_fit_sumx1_arr[i];
}
quadratic_fit_sumx1 = (NUM_TYPE)0;
quadratic_fit_sumx2 = (NUM_TYPE)0;
quadratic_fit_sumx3 = (NUM_TYPE)0;
quadratic_fit_sumx4 = (NUM_TYPE)0;
for (int i = 0; i < length; i++) {
quadratic_fit_sumx1 += quadratic_fit_sumx1_arr[i];
quadratic_fit_sumx2 += quadratic_fit_sumx2_arr[i];
quadratic_fit_sumx3 += quadratic_fit_sumx1_arr[i] * quadratic_fit_sumx2_arr[i];
quadratic_fit_sumx4 += quadratic_fit_sumx2_arr[i] * quadratic_fit_sumx2_arr[i];
}
quadratic_fit_d = \
quadratic_fit_sumx2 * quadratic_fit_sumx2 * quadratic_fit_sumx2 + \
quadratic_fit_sumx1 * quadratic_fit_sumx1 * quadratic_fit_sumx4 + \
(NUM_TYPE)length * quadratic_fit_sumx3 * quadratic_fit_sumx3 - \
(NUM_TYPE)length * quadratic_fit_sumx2 * quadratic_fit_sumx4 - \
(NUM_TYPE)2 * quadratic_fit_sumx1 * quadratic_fit_sumx2 * quadratic_fit_sumx3;
quadratic_fit_matrix[0][0] = quadratic_fit_sumx2 * quadratic_fit_sumx2 - quadratic_fit_sumx1 * quadratic_fit_sumx3;
quadratic_fit_matrix[0][1] = (NUM_TYPE)length * quadratic_fit_sumx3 - quadratic_fit_sumx1 * quadratic_fit_sumx2;
quadratic_fit_matrix[0][2] = quadratic_fit_sumx1 * quadratic_fit_sumx1 - (NUM_TYPE)length * quadratic_fit_sumx2;
quadratic_fit_matrix[1][0] = quadratic_fit_sumx1 * quadratic_fit_sumx4 - quadratic_fit_sumx2 * quadratic_fit_sumx3;
quadratic_fit_matrix[1][1] = quadratic_fit_sumx2 * quadratic_fit_sumx2 - (NUM_TYPE)length * quadratic_fit_sumx4;
quadratic_fit_matrix[1][2] = quadratic_fit_matrix[0][1];
quadratic_fit_matrix[2][0] = quadratic_fit_sumx3 * quadratic_fit_sumx3 - quadratic_fit_sumx2 * quadratic_fit_sumx4;
quadratic_fit_matrix[2][1] = quadratic_fit_matrix[1][0];
quadratic_fit_matrix[2][2] = quadratic_fit_matrix[0][0];
}
void calc_quadratic_fit(NUM_TYPE *buff, struct quadratic_coefficient_s *coeff, int length)
{
NUM_TYPE sum_y1, sum_xy, sum_x2y;
if ((buff == (void *)0) || (coeff == (void *)0) || (length == 0)) {
return;
}
sum_y1 = (NUM_TYPE)0;
sum_xy = (NUM_TYPE)0;
sum_x2y = (NUM_TYPE)0;
for (int i = 0; i < length; i++) {
sum_y1 += buff[i];
sum_xy += quadratic_fit_sumx1_arr[i] * buff[i];
sum_x2y += quadratic_fit_sumx2_arr[i] * buff[i];
}
coeff->a = (sum_y1 * quadratic_fit_matrix[0][0] + sum_xy * quadratic_fit_matrix[0][1] + sum_x2y * quadratic_fit_matrix[0][2]) / quadratic_fit_d;
coeff->b = (sum_y1 * quadratic_fit_matrix[1][0] + sum_xy * quadratic_fit_matrix[1][1] + sum_x2y * quadratic_fit_matrix[1][2]) / quadratic_fit_d;
coeff->c = (sum_y1 * quadratic_fit_matrix[2][0] + sum_xy * quadratic_fit_matrix[2][1] + sum_x2y * quadratic_fit_matrix[2][2]) / quadratic_fit_d;
}