У меня есть несколько вопросов:
В примере, приведенном в документе openCV:
/* генерируем измерение */ cvMatMulAdd( kalman->measurement_matrix, state, Measurement, Measurement );
Это правильно? В учебнике: Введение в фильтр Калмана Уэлч и Бишоп в уравнении 1.2 говорят, что измерение = H*состояние + шум измерения
Не похоже, что оба одинаковы.
- Я пытался реализовать отслеживание прыгающего мяча для одного мяча. Я пробовал следующее: (Пожалуйста, укажите, если я делаю это неправильно.)
Для измерения я измеряю две вещи: а) х б) у центроида шара.
Я просто упоминаю строки, которые отличаются от примера, приведенного в документации opencv.
CvKalman* kalman = cvCreateKalman( 5, 2, 0 );
const float A[] = { 1, 0, 1, 0, 0,
0, 1, 0, 1, 0,
0, 0, 1, 0, 0,
0, 0, 0, 1, 1,
0, 0, 0, 0, 1};
CvMat* state = cvCreateMat( 5, 1, CV_32FC1 );
CvMat* measurement = cvCreateMat( 2, 1, CV_32FC1 );
//initialize the state of kalman filter
state->data.fl[0] = mean_c;
state->data.fl[1] = mean_r;
state->data.fl[2] = mean_c - prev_mean_c;
state->data.fl[3] = mean_r - prev_mean_r;
state->data.fl[4] = 9.81;
после инициализации вот что дает краш
cvMatMulAdd( kalman->transition_matrix, state, kalman->process_noise_cov, state );