1

まず、getGaussianKernel と filter2D は double 値で動作しますか? はいの場合、どのように?

私はこれを持っています:

void smoothAngles(cv::Mat& cos_angles, cv::Mat& angles){
    cv::Mat sin_angles;

    cos_angles.create(angles.size(), CV_64FC1);
    sin_angles.create(angles.size(), CV_64FC1);

    for(int i = 0; i < cos_angles.cols; i++){
        for(int j = 0; j < cos_angles.rows; j++){
            cos_angles.at<double>(i, j) = std::cos(2 * angles.at<double>(i, j));
            sin_angles.at<double>(i, j) = std::sin(2 * angles.at<double>(i, j));
        }
    }

    cv::Mat gaussKernel = cv::getGaussianKernel(5, 1.0, CV_32FC1);

    // aplica o filtro gaussiano low-pass
    cv::filter2D(cos_angles, cos_angles, cos_angles.depth(), gaussKernel);
    cv::filter2D(sin_angles, sin_angles, sin_angles.depth(), gaussKernel);

    for (int i = 0; i < cos_angles.cols; i++) {
        for (int j = 0; j < cos_angles.rows; j++) {
            cos_angles.at<double>(i, j) = std::atan2(sin_angles.at<double>(i, j), cos_angles.at<double>(i, j)) / 2;
        }
    }
}

の最初の使用でエラーが発生しますfilter2D。エラーは次のとおりです。

FingerPrint - 01(11534) malloc: *** error for object 0x10081a408: incorrect 
checksum for freed object - object was probably modified after being freed.
*** set a breakpoint in malloc_error_break to debug

代わりに使用してみcv::GaussianBlur(cos_angles, cos_angles, cv::Size(5,5), 1.0);ましたが、同じエラーが発生します。

4

1 に答える 1