簡體   English   中英

OpenCV錯誤:斷言在MixChannels(..)中失敗

[英]OpenCV Error: Assertion Failed in MixChannels(..)

我正在嘗試將MATLAB .mat文件轉換為openCV MAT,然后將多個蒙版應用於這些文件。 我正在從cvmatio源代碼構建。 我收到以下錯誤:

OpenCV錯誤:init在文件/home/derek/Documents/Libraries/opencv-3.0.0-beta/modules/core/src/matrix.cpp中,斷言失敗(A.size == arrays [i0]-> size),在拋出'cv :: Exception'what()實例之后調用第4279行終止:/home/derek/Documents/Libraries/opencv-3.0.0-beta/modules/core/src/matrix.cpp:4279:錯誤: (-215)函數init中的A.size == arrays [i0]-> size

這是我寫的源文件。 它發生在MixChannels行中。 請注意,SrcImage是3通道Mat。 lower和upper是數組中的閾值,其長度等於通道數。

/*
 * Mask.cpp
 *
 *  Created on: Mar 16, 2015
 *      Author: derek
 */


#include <cv.h>
#include <highgui.h>
#include "imgcodecs.hpp"
#include "highgui.hpp"
#include "imgproc.hpp"

using namespace cv;


Mat Mask(Mat SrcImage, double lower[], double upper[]){
    int height=SrcImage.rows;
    int width=SrcImage.cols;
    int depth=SrcImage.depth();
    Mat B2d = Mat::ones(height, width,depth);

    Mat out(height, width, depth);
    Mat outL(height, width, depth);
    Mat outU(height,width, depth);
    for (int i=1; i< SrcImage.channels(); i=i+1){
        int from_to[]={i,1};
        mixChannels(&SrcImage, 3, &out, 1, from_to, 1 );
        threshold(out, outL, lower[i], 1, THRESH_BINARY);
        threshold(out, outU, upper[i], 1, THRESH_BINARY);
        bitwise_and(B2d, outL, B2d);
        bitwise_and(B2d, outU, B2d);

    }

    return B2d;
}

另外,這是實際CV_Assertion錯誤位置的摘錄。 如錯誤所示,它發生在“(A.size == arrays [i0]-> size)”處。

void NAryMatIterator::init(const Mat** _arrays, Mat* _planes, uchar** _ptrs, int _narrays)
{
    CV_Assert( _arrays && (_ptrs || _planes) );
    int i, j, d1=0, i0 = -1, d = -1;

    arrays = _arrays;
    ptrs = _ptrs;
    planes = _planes;
    narrays = _narrays;
    nplanes = 0;
    size = 0;

    if( narrays < 0 )
    {
        for( i = 0; _arrays[i] != 0; i++ )
            ;
        narrays = i;
        CV_Assert(narrays <= 1000);
    }

    iterdepth = 0;

    for( i = 0; i < narrays; i++ )
    {
        CV_Assert(arrays[i] != 0);
        const Mat& A = *arrays[i];
        if( ptrs )
            ptrs[i] = A.data;

        if( !A.data )
            continue;

        if( i0 < 0 )
        {
            i0 = i;
            d = A.dims;

            // find the first dimensionality which is different from 1;
            // in any of the arrays the first "d1" step do not affect the continuity
            for( d1 = 0; d1 < d; d1++ )
                if( A.size[d1] > 1 )
                    break;
        }
        else
            CV_Assert( A.size == arrays[i0]->size );

        if( !A.isContinuous() )
        {
            CV_Assert( A.step[d-1] == A.elemSize() );
            for( j = d-1; j > d1; j-- )
                if( A.step[j]*A.size[j] < A.step[j-1] )
                    break;
            iterdepth = std::max(iterdepth, j);
        }
    }

    if( i0 >= 0 )
    {
        size = arrays[i0]->size[d-1];
        for( j = d-1; j > iterdepth; j-- )
        {
            int64 total1 = (int64)size*arrays[i0]->size[j-1];
            if( total1 != (int)total1 )
                break;
            size = (int)total1;
        }

        iterdepth = j;
        if( iterdepth == d1 )
            iterdepth = 0;

        nplanes = 1;
        for( j = iterdepth-1; j >= 0; j-- )
            nplanes *= arrays[i0]->size[j];
    }
    else
        iterdepth = 0;

    idx = 0;

    if( !planes )
        return;

    for( i = 0; i < narrays; i++ )
    {
        CV_Assert(arrays[i] != 0);
        const Mat& A = *arrays[i];

        if( !A.data )
        {
            planes[i] = Mat();
            continue;
        }

        planes[i] = Mat(1, (int)size, A.type(), A.data);
    }
}

好了,答案顯然為時已晚,但這是您的代碼失敗的原因:

由於您的SrcImage是具有多個通道的單個Mat,因此您應該編寫:

mixChannels(&SrcImage, 1, &out, 1, from_to, 1 );

(斷言錯誤與此相關,因為mixChannels預期有3個Mats,是Mat的3倍。)

同樣,opencv MixChannels從0開始標記通道,不確定是否要使用i = 1或只是拼寫錯誤。

干杯!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM