Esempio n. 1
0
static void
icvCornerEigenValsVecs( const CvMat* src, CvMat* eigenv, int block_size,
                        int aperture_size, int op_type, double k=0. )
{
    CvFilterState* dxstate = 0;
    CvFilterState* dystate = 0;
    CvFilterState* blurstate = 0;
    CvMat *tempsrc = 0;
    CvMat *Dx = 0, *Dy = 0, *cov = 0;
    CvMat *sqrt_buf = 0;

    int buf_size = 1 << 12;
    
    CV_FUNCNAME( "icvCornerEigenValsVecs" );

    __BEGIN__;

    int i, j, y, dst_y = 0, max_dy, delta = 0;
    int aperture_size0 = aperture_size;
    int temp_step = 0, d_step;
    uchar* shifted_ptr = 0;
    int depth, d_depth, datatype;
    int stage = CV_START;
    CvSobelFixedIPPFunc ipp_sobel_vert = 0, ipp_sobel_horiz = 0;
    CvFilterFixedIPPFunc ipp_scharr_vert = 0, ipp_scharr_horiz = 0;
    CvFilterFunc opencv_derv_func = 0;
    CvSize el_size, size, stripe_size;
    int aligned_width;
    CvPoint el_anchor;
    double factorx, factory;

    if( block_size < 3 || !(block_size & 1) )
        CV_ERROR( CV_StsOutOfRange, "averaging window size must be an odd number >= 3" );
        
    if( aperture_size < 3 && aperture_size != CV_SCHARR || !(aperture_size & 1) )
        CV_ERROR( CV_StsOutOfRange,
        "Derivative filter aperture size must be a positive odd number >=3 or CV_SCHARR" );
    
    depth = CV_MAT_DEPTH(src->type);
    d_depth = depth == CV_8U ? CV_16S : CV_32F;
    datatype = depth == CV_8U ? cv8u : cv32f;

    size = cvGetMatSize(src);
    aligned_width = cvAlign(size.width, 4);

    aperture_size = aperture_size == CV_SCHARR ? 3 : aperture_size;
    el_size = cvSize( aperture_size, aperture_size );
    el_anchor = cvPoint( aperture_size/2, aperture_size/2 );

    if( aperture_size <= 5 && icvFilterSobelVert_8u16s_C1R_p )
    {
        if( depth == CV_8U && aperture_size0 == CV_SCHARR )
        {
            ipp_scharr_vert = icvFilterScharrVert_8u16s_C1R_p;
            ipp_scharr_horiz = icvFilterScharrHoriz_8u16s_C1R_p;
        }
        else if( depth == CV_32F && aperture_size0 == CV_SCHARR )
        {
            ipp_scharr_vert = icvFilterScharrVert_32f_C1R_p;
            ipp_scharr_horiz = icvFilterScharrHoriz_32f_C1R_p;
        }
        else if( depth == CV_8U )
        {
            ipp_sobel_vert = icvFilterSobelVert_8u16s_C1R_p;
            ipp_sobel_horiz = icvFilterSobelHoriz_8u16s_C1R_p;
        }
        else if( depth == CV_32F )
        {
            ipp_sobel_vert = icvFilterSobelVert_32f_C1R_p;
            ipp_sobel_horiz = icvFilterSobelHoriz_32f_C1R_p;
        }
    }
    
    if( ipp_sobel_vert && ipp_sobel_horiz ||
        ipp_scharr_vert && ipp_scharr_horiz )
    {
        CV_CALL( tempsrc = icvIPPFilterInit( src, buf_size,
            cvSize(el_size.width,el_size.height + block_size)));
        shifted_ptr = tempsrc->data.ptr + el_anchor.y*tempsrc->step +
                      el_anchor.x*CV_ELEM_SIZE(depth);
        temp_step = tempsrc->step ? tempsrc->step : CV_STUB_STEP;
        max_dy = tempsrc->rows - aperture_size + 1;
    }
    else
    {
        ipp_sobel_vert = ipp_sobel_horiz = 0;
        ipp_scharr_vert = ipp_scharr_horiz = 0;
        CV_CALL( dxstate = icvSobelInitAlloc( size.width, datatype, aperture_size0,
                                              CV_ORIGIN_TL, 1, 0 ));
        CV_CALL( dystate = icvSobelInitAlloc( size.width, datatype, aperture_size0,
                                              CV_ORIGIN_TL, 0, 1 ));
        max_dy = buf_size / src->cols;
        max_dy = MAX( max_dy, aperture_size + block_size );
        opencv_derv_func = depth == CV_8U ? (CvFilterFunc)icvSobel_8u16s_C1R :
                                            (CvFilterFunc)icvSobel_32f_C1R;
    }

    CV_CALL( Dx = cvCreateMat( max_dy, aligned_width, d_depth ));
    CV_CALL( Dy = cvCreateMat( max_dy, aligned_width, d_depth ));
    CV_CALL( cov = cvCreateMat( max_dy + block_size + 1, size.width, CV_32FC3 ));
    CV_CALL( sqrt_buf = cvCreateMat( 2, size.width, CV_32F ));

    if( opencv_derv_func )
        max_dy -= aperture_size - 1;
    d_step = Dx->step ? Dx->step : CV_STUB_STEP;

    CV_CALL( blurstate = icvBlurInitAlloc( size.width, cv32f, 3, block_size ));
    blurstate->divisor = 1; // avoid scaling
    stripe_size = size;

    factorx = (double)(1 << (aperture_size - 1)) * block_size;
    if( aperture_size0 == CV_SCHARR )
        factorx *= 2;
    if( depth == CV_8U )
        factorx *= 255.;
    factory = factorx = 1./factorx;
    if( ipp_sobel_vert )
        factory = -factory;

    for( y = 0; y < size.height; y += delta )
    {
        if( opencv_derv_func )
        {
            delta = MIN( size.height - y, max_dy );
            if( y + delta == size.height )
                stage = stage & CV_START ? CV_START + CV_END : CV_END;
            
            stripe_size.height = delta;
            IPPI_CALL( opencv_derv_func( src->data.ptr + y*src->step, src->step, Dx->data.ptr,
                                         Dx->step, &stripe_size, dxstate, stage ));
            stripe_size.height = delta;
            IPPI_CALL( opencv_derv_func( src->data.ptr + y*src->step, src->step, Dy->data.ptr,
                                         Dy->step, &stripe_size, dystate, stage ));
        }
        else
        {
            delta = icvIPPFilterNextStripe( src, tempsrc, y, el_size, el_anchor );
            stripe_size.height = delta;

            if( ipp_sobel_vert )
            {
                IPPI_CALL( ipp_sobel_vert( shifted_ptr, temp_step,
                        Dx->data.ptr, d_step, stripe_size,
                        aperture_size*10 + aperture_size ));
                IPPI_CALL( ipp_sobel_horiz( shifted_ptr, temp_step,
                        Dy->data.ptr, d_step, stripe_size,
                        aperture_size*10 + aperture_size ));
            }
            else /*if( ipp_scharr_vert )*/
            {
                IPPI_CALL( ipp_scharr_vert( shifted_ptr, temp_step,
                        Dx->data.ptr, d_step, stripe_size ));
                IPPI_CALL( ipp_scharr_horiz( shifted_ptr, temp_step,
                        Dy->data.ptr, d_step, stripe_size ));
            }
        }

        for( i = 0; i < stripe_size.height; i++ )
        {
            float* cov_data = (float*)(cov->data.ptr + i*cov->step);
            if( d_depth == CV_16S )
            {
                const short* dxdata = (const short*)(Dx->data.ptr + i*Dx->step);
                const short* dydata = (const short*)(Dy->data.ptr + i*Dy->step);

                for( j = 0; j < size.width; j++ )
                {
                    double dx = dxdata[j]*factorx;
                    double dy = dydata[j]*factory;

                    cov_data[j*3] = (float)(dx*dx);
                    cov_data[j*3+1] = (float)(dx*dy);
                    cov_data[j*3+2] = (float)(dy*dy);
                }
            }
            else
            {
                const float* dxdata = (const float*)(Dx->data.ptr + i*Dx->step);
                const float* dydata = (const float*)(Dy->data.ptr + i*Dy->step);

                for( j = 0; j < size.width; j++ )
                {
                    double dx = dxdata[j]*factorx;
                    double dy = dydata[j]*factory;

                    cov_data[j*3] = (float)(dx*dx);
                    cov_data[j*3+1] = (float)(dx*dy);
                    cov_data[j*3+2] = (float)(dy*dy);
                }
            }
        }

        if( y + stripe_size.height >= size.height )
            stage = stage & CV_START ? CV_START + CV_END : CV_END;

        IPPI_CALL( icvBlur_32f_CnR( cov->data.fl, cov->step,
                                    cov->data.fl, cov->step,
                                    &stripe_size, blurstate, stage ));

        if( op_type == ICV_MINEIGENVAL )
            icvCalcMinEigenVal( cov->data.fl, cov->step,
                (float*)(eigenv->data.ptr + dst_y*eigenv->step), eigenv->step,
                stripe_size, sqrt_buf );
        else if( op_type == ICV_HARRIS )
            icvCalcHarris( cov->data.fl, cov->step,
                (float*)(eigenv->data.ptr + dst_y*eigenv->step), eigenv->step,
                stripe_size, sqrt_buf, k );
        else if( op_type == ICV_EIGENVALSVECS )
            icvCalcEigenValsVecs( cov->data.fl, cov->step,
                (float*)(eigenv->data.ptr + dst_y*eigenv->step), eigenv->step,
                stripe_size, sqrt_buf );

        dst_y += stripe_size.height;

        stage = CV_MIDDLE;
    }

    __END__;

    icvFilterFree( &dxstate );
    icvFilterFree( &dystate );
    icvFilterFree( &blurstate );
    cvReleaseMat( &Dx );
    cvReleaseMat( &Dy );
    cvReleaseMat( &cov );
    cvReleaseMat( &sqrt_buf );
    cvReleaseMat( &tempsrc );
}
Esempio n. 2
0
CvStatus
_CalcDispMean( const CvMat* srcIm, CvMat* dispIm, CvMat* meanIm, int size )
{
    //////////// check input parametrs ///////////////////
    if( (srcIm == NULL) || (dispIm == NULL) || (meanIm == NULL) )
    {
        return CV_NULLPTR_ERR;
    }

    //////////// variables ///////////////
    uchar *src;
    int step_srcIm;
    int number = 2 * size + 1;
    CvSize roi_srcIm;

    IplImage*     AverageIm_f;
    IplImage*     Temp1_f;
    IplImage*     Temp2_f;
    _CvConvState* convState;

    /////////////// initialising /////////////////////////
    cvGetRawData( srcIm, &src, &step_srcIm, &roi_srcIm );

    //////////// creating images ///////////////////////
    Temp2_f = cvCreateImage( roi_srcIm, IPL_DEPTH_32F, 1 );
    AverageIm_f = cvCreateImage( roi_srcIm, IPL_DEPTH_32F, 1 );
    Temp1_f = cvCreateImage( roi_srcIm, IPL_DEPTH_32F, 1 );
    icvBlurInitAlloc( roi_srcIm.width, cv32f, number, &convState );

    if( (Temp2_f == NULL) || (AverageIm_f == NULL) || (Temp1_f == NULL) || !convState )
    {
        cvReleaseImage( &Temp2_f );
        cvReleaseImage( &AverageIm_f );
        cvReleaseImage( &Temp1_f );
        icvConvolFree( &convState );
        return CV_OUTOFMEM_ERR;
    }

    ////////////// calculating //////////////////////
    cvConvertScale( srcIm, Temp2_f, 1, 0 );
    icvBlur_32f_C1R( (float*)Temp2_f->imageData,     Temp2_f->widthStep,
                     (float*)AverageIm_f->imageData, AverageIm_f->widthStep,
                     &roi_srcIm, convState, 0 );
    cvMul( Temp2_f, Temp2_f, Temp1_f );      // square
    icvBlur_32f_C1R( (float*)Temp1_f->imageData, Temp1_f->widthStep,
                     (float*)Temp2_f->imageData, Temp2_f->widthStep,
                     &roi_srcIm, convState, 0 );

    cvSub( Temp2_f, AverageIm_f, Temp1_f );       // dispersion powered 2

    cvConvertScale( Temp2_f, dispIm, 1.0 / (number * number), 0 );    // convert to IPL_DEPTH_8U
    cvConvertScale( AverageIm_f, meanIm, 1.0 / (number * number), 0 );

    ///////////// relesing memory ///////////////////////////
    cvReleaseImage( &Temp1_f );
    cvReleaseImage( &Temp2_f );
    cvReleaseImage( &AverageIm_f );
    icvConvolFree( &convState );

    return CV_NO_ERR;

} // CvStatus _CalcDispMean( IplImage* srcIm, IplImage* dispIm, IplImage* meanIm , int size )