cvabsdiff.cpp.svn-base

来自「非结构化路识别」· SVN-BASE 代码 · 共 639 行 · 第 1/2 页

SVN-BASE
639
字号
/*M///////////////////////////////////////////////////////////////////////////////////////
//
//  IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
//  By downloading, copying, installing or using the software you agree to this license.
//  If you do not agree to this license, do not download, install,
//  copy or use the software.
//
//
//                        Intel License Agreement
//                For Open Source Computer Vision Library
//
// Copyright (C) 2000, Intel Corporation, all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
//   * Redistribution's of source code must retain the above copyright notice,
//     this list of conditions and the following disclaimer.
//
//   * Redistribution's in binary form must reproduce the above copyright notice,
//     this list of conditions and the following disclaimer in the documentation
//     and/or other materials provided with the distribution.
//
//   * The name of Intel Corporation may not be used to endorse or promote products
//     derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/

#include "_cv.h"
#include <assert.h>

#define  ICV_DEF_BIN_ABS_DIFF_2D(name, arrtype, temptype, abs_macro, cast_macro)\
IPCVAPI_IMPL( CvStatus,                                                         \
name,( const arrtype* src1, int step1, const arrtype* src2, int step2,          \
      arrtype* dst, int step, CvSize size ))                                    \
{                                                                               \
    for( ; size.height--; (char*&)src1 += step1, (char*&)src2 += step2,         \
                          (char*&)dst += step )                                 \
    {                                                                           \
        int i;                                                                  \
                                                                                \
        for( i = 0; i <= size.width - 4; i += 4 )                               \
        {                                                                       \
            temptype t0 = src1[i] - src2[i];                                    \
            temptype t1 = src1[i+1] - src2[i+1];                                \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[i] = cast_macro(t0);                                            \
            dst[i+1] = cast_macro(t1);                                          \
                                                                                \
            t0 = src1[i+2] - src2[i+2];                                         \
            t1 = src1[i+3] - src2[i+3];                                         \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[i+2] = cast_macro(t0);                                          \
            dst[i+3] = cast_macro(t1);                                          \
        }                                                                       \
                                                                                \
        for( ; i < size.width; i++ )                                            \
        {                                                                       \
            temptype t0 = src1[i] - src2[i];                                    \
            t0 = (temptype)abs_macro(t0);                                       \
            dst[i] = cast_macro(t0);                                            \
        }                                                                       \
    }                                                                           \
                                                                                \
    return  CV_OK;                                                              \
}


#define  ICV_DEF_UN_ABS_DIFF_2D( name, arrtype, temptype, abs_macro, cast_macro)\
IPCVAPI_IMPL( CvStatus,                                                         \
name,( const arrtype* src0, int step1, arrtype* dst0, int step,                 \
      CvSize size, const temptype* scalar ))                                    \
{                                                                               \
    for( ; size.height--; (char*&)src0 += step1, (char*&)dst0 += step )         \
    {                                                                           \
        int i, len = size.width;                                                \
        const arrtype* src = src0;                                              \
        arrtype* dst = dst0;                                                    \
                                                                                \
        for( ; (len -= 12) >= 0; dst += 12, src += 12 )                         \
        {                                                                       \
            temptype t0 = src[0] - scalar[0];                                   \
            temptype t1 = src[1] - scalar[1];                                   \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[0] = cast_macro( t0 );                                          \
            dst[1] = cast_macro( t1 );                                          \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            t0 = src[2] - scalar[2];                                            \
            t1 = src[3] - scalar[3];                                            \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[2] = cast_macro( t0 );                                          \
            dst[3] = cast_macro( t1 );                                          \
                                                                                \
            t0 = src[4] - scalar[4];                                            \
            t1 = src[5] - scalar[5];                                            \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[4] = cast_macro( t0 );                                          \
            dst[5] = cast_macro( t1 );                                          \
                                                                                \
            t0 = src[6] - scalar[6];                                            \
            t1 = src[7] - scalar[7];                                            \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[6] = cast_macro( t0 );                                          \
            dst[7] = cast_macro( t1 );                                          \
                                                                                \
            t0 = src[8] - scalar[8];                                            \
            t1 = src[9] - scalar[9];                                            \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[8] = cast_macro( t0 );                                          \
            dst[9] = cast_macro( t1 );                                          \
                                                                                \
            t0 = src[10] - scalar[10];                                          \
            t1 = src[11] - scalar[11];                                          \
                                                                                \
            t0 = (temptype)abs_macro(t0);                                       \
            t1 = (temptype)abs_macro(t1);                                       \
                                                                                \
            dst[10] = cast_macro( t0 );                                         \
            dst[11] = cast_macro( t1 );                                         \
        }                                                                       \
                                                                                \
        for( (len) += 12, i = 0; i < (len); i++ )                               \
        {                                                                       \
            temptype t0 = src[i] - scalar[i];                                   \
            t0 = (temptype)abs_macro(t0);                                       \
            dst[i] = cast_macro( t0 );                                          \
        }                                                                       \
    }                                                                           \
                                                                                \
    return CV_OK;                                                               \
}


static const uchar icvAbsTable8u[] = {
255,254,253,252,251,250,249,248,247,246,245,244,243,242,241,
240,239,238,237,236,235,234,233,232,231,230,229,228,227,226,225,
224,223,222,221,220,219,218,217,216,215,214,213,212,211,210,209,
208,207,206,205,204,203,202,201,200,199,198,197,196,195,194,193,
192,191,190,189,188,187,186,185,184,183,182,181,180,179,178,177,
176,175,174,173,172,171,170,169,168,167,166,165,164,163,162,161,
160,159,158,157,156,155,154,153,152,151,150,149,148,147,146,145,
144,143,142,141,140,139,138,137,136,135,134,133,132,131,130,129,
128,127,126,125,124,123,122,121,120,119,118,117,116,115,114,113,
112,111,110,109,108,107,106,105,104,103,102,101,100,99,98,97,
96,95,94,93,92,91,90,89,88,87,86,85,84,83,82,81,
80,79,78,77,76,75,74,73,72,71,70,69,68,67,66,65,
64,63,62,61,60,59,58,57,56,55,54,53,52,51,50,49,
48,47,46,45,44,43,42,41,40,39,38,37,36,35,34,33,
32,31,30,29,28,27,26,25,24,23,22,21,20,19,18,17,
16,15,14,13,12,11,10,9,8,7,6,5,4,3,2,1,
0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,
16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,
32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,
48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,
64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,
80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,
96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,
112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,
128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,
144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,
160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,
176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,
192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,
208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,
224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,
240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255};

#define  ICV_IABS_8U(x)   icvAbsTable8u[(x)+255]
#define  ICV_TO_8U(x)     ((uchar)(x))

ICV_DEF_BIN_ABS_DIFF_2D( icvAbsDiff_8u_C1R, uchar, int, ICV_IABS_8U, ICV_TO_8U )
ICV_DEF_BIN_ABS_DIFF_2D( icvAbsDiff_32f_C1R, float, float, fabs, CV_CAST_32F )
ICV_DEF_BIN_ABS_DIFF_2D( icvAbsDiff_64f_C1R, double, double, fabs, CV_CAST_64F )

ICV_DEF_UN_ABS_DIFF_2D( icvAbsDiffC_8u_C1R, uchar, int, CV_IABS, CV_CAST_8U )
ICV_DEF_UN_ABS_DIFF_2D( icvAbsDiffC_32f_C1R, float, float, fabs, CV_CAST_32F )
ICV_DEF_UN_ABS_DIFF_2D( icvAbsDiffC_64f_C1R, double, double, fabs, CV_CAST_64F )


#define  ICV_INIT_MINI_FUNC_TAB_2D( FUNCNAME )          \
static void icvInit##FUNCNAME##Table( CvFuncTable* tab )\
{                                                       \
    tab->fn_2d[CV_8U] = (void*)icv##FUNCNAME##_8u_C1R;         \
    tab->fn_2d[CV_32F] = (void*)icv##FUNCNAME##_32f_C1R;       \
    tab->fn_2d[CV_64F] = (void*)icv##FUNCNAME##_64f_C1R;       \
}


ICV_INIT_MINI_FUNC_TAB_2D( AbsDiff )
ICV_INIT_MINI_FUNC_TAB_2D( AbsDiffC )


CV_IMPL  void
cvAbsDiff( const void* srcarr1, const void* srcarr2, void* dstarr )
{
    static CvFuncTable adiff_tab;
    static int inittab = 0;

    CV_FUNCNAME( "cvAbsDiff" );

    __BEGIN__;

    int coi1 = 0, coi2 = 0, coi3 = 0;
    CvMat srcstub1, *src1 = (CvMat*)srcarr1;
    CvMat srcstub2, *src2 = (CvMat*)srcarr2;
    CvMat dststub,  *dst = (CvMat*)dstarr;
    int src1_step, src2_step, dst_step;
    CvSize size;
    int type;

    if( !inittab )
    {
        icvInitAbsDiffTable( &adiff_tab );
        inittab = 1;
    }

    CV_CALL( src1 = cvGetMat( src1, &srcstub1, &coi1 ));
    CV_CALL( src2 = cvGetMat( src2, &srcstub2, &coi2 ));
    CV_CALL( dst = cvGetMat( dst, &dststub, &coi3 ));

    if( coi1 != 0 || coi2 != 0 || coi3 != 0 )
        CV_ERROR( CV_BadCOI, "" );

    if( !CV_ARE_SIZES_EQ( src1, src2 ) )
        CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );

    size = icvGetMatSize( src1 );
    type = CV_MAT_TYPE(src1->type);

    if( !CV_ARE_SIZES_EQ( src1, dst ))
        CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );
    
    if( !CV_ARE_TYPES_EQ( src1, src2 ))
        CV_ERROR_FROM_CODE( CV_StsUnmatchedFormats );

    if( !CV_ARE_TYPES_EQ( src1, dst ))
        CV_ERROR_FROM_CODE( CV_StsUnmatchedFormats );

    size.width *= CV_MAT_CN( type );

    src1_step = src1->step;
    src2_step = src2->step;
    dst_step = dst->step;

    if( CV_IS_MAT_CONT( src1->type & src2->type & dst->type ))
    {
        size.width *= size.height;
        size.height = 1;
        src1_step = src2_step = dst_step = CV_STUB_STEP;
    }

    {
        CvFunc2D_3A func = (CvFunc2D_3A)
            (adiff_tab.fn_2d[CV_MAT_DEPTH(type)]);

        if( !func )
            CV_ERROR( CV_StsUnsupportedFormat, "" );

        IPPI_CALL( func( src1->data.ptr, src1_step, src2->data.ptr, src2_step,
                         dst->data.ptr, dst_step, size ));
    }

    __END__;
}


CV_IMPL void
cvAbsDiffS( const void* srcarr, void* dstarr, CvScalar scalar )
{
    static CvFuncTable adiffs_tab;
    static int inittab = 0;

    CV_FUNCNAME( "cvAbsDiffS" );

    __BEGIN__;

    int coi1 = 0, coi2 = 0;
    int type, sctype;
    CvMat srcstub, *src = (CvMat*)srcarr;
    CvMat dststub, *dst = (CvMat*)dstarr;
    int src_step = src->step;
    int dst_step = dst->step;
    double buf[12];

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?