【发布时间】:2016-01-28 17:59:24
【问题描述】:
我一直在尝试使用卡尔曼滤波器进行多对象跟踪。这是我的代码,
for (int i =0; i<vGlobal.size(); i++) // Vector of objects of interest
{
cv::Point pTemp = cv::Point(vGlobal[i].iX, vGlobal[i].iY);
cv::KalmanFilter kTempKF(4,2,0);
kTempKF.statePre.at<floatt>(0) = pTemp.x;
kTempKF.statePre.at<float>(1) = pTemp.y;
kTempKF.statePre.at<float>(2) = 0;
kTempKF.statePre.at<float>(3) = 0;
kTempKF.transitionMatrix = *(cv::Mat_<float>(4,4)<< 1,0,1,0, 0,1,0,1, 0,0,1,0, 0,0,0,1);
cv::setIdentity(kTempKF.measurementMatrix);
cv::setIdentity(kTempKF.processNoiseCov, cv::Scalar::all(1e-4));
cv::setIdentity(kTempKF.measurementNoiseCov, cv::Scalar::all(10));
cv::setIdentity(kTempKF.errorCovPost, cv::Scalar::all(.1));
vKalmanFilters.push_back(kTempKF);
}
我正在使用卡尔曼滤波器矢量来跟踪我的每个对象。如上所述,我已经完成了过滤器的初始化。现在我尝试在下面的代码中进行预测和测量。
for (int i=0; i<vKalmanFilters.size();i++)
{
cv::Mat mPrediction = vKalmanFilters[i].predict();
cv::Point pPredict(mPrediction.at<float>(0), mPrediction.at<float>(1));
mMeasurement(0) = vGlobal[i].iX;
mMeasurement(1) = vGlobal[i].iY;
cv::Mat mEstimated;
mEstimated = vKalmanFilters[i].correct(mPrediction); // Run time Error occurs here
}
当我尝试运行这个程序时,我得到了正确的运行时错误(预测)
OpenCV Error: Assertion failed (C.type() == type && (((flags&GEMM_3_T) == 0 && C.rows == d_size.height && C.cols == d_size.width) || ((flags&GEMM_3_T) != 0 && C.rows == d_size.width && C.cols == d_size.height))) in gemm, file /build/buildd/opencv-2.4.8+dfsg1/modules/core/src/matmul.cpp, line 741
terminate called after throwing an instance of 'cv::Exception'
what(): /build/buildd/opencv-2.4.8+dfsg1/modules/core/src/matmul.cpp:741: error: (-215) C.type() == type && (((flags&GEMM_3_T) == 0 && C.rows == d_size.height && C.cols == d_size.width) || ((flags&GEMM_3_T) != 0 && C.rows == d_size.width && C.cols == d_size.height)) in function gemm
我还是卡尔曼滤波器的初学者。错误发生在预测点。我的方法完全错误吗?请有人解释我哪里出错了。
【问题讨论】:
-
矩阵应该是
float(CV_32F) 或double(CV_64F),而不是int -
@Berriel:是的,它奏效了。但是现在(如新编辑的那样),在我现在添加的正确(预测)步骤中发生了不同的运行时错误。
标签: c++ image opencv kalman-filter