亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cxmathfuncs.cpp

?? 將OpenCV移植到DSP上
?? CPP
?? 第 1 頁 / 共 5 頁
字號:


/****************************************************************************************\
*                                  Cartezian -> Polar                                    *
\****************************************************************************************/

CV_IMPL void
cvCartToPolar( const CvArr* xarr, const CvArr* yarr,
               CvArr* magarr, CvArr* anglearr,
               int angle_in_degrees )
{
    CV_FUNCNAME( "cvCartToPolar" );

    __BEGIN__;

    float* mag_buffer = 0;
    float* x_buffer = 0;
    float* y_buffer = 0;
    int block_size = 0;
    CvMat xstub, *xmat = (CvMat*)xarr;
    CvMat ystub, *ymat = (CvMat*)yarr;
    CvMat magstub, *mag = (CvMat*)magarr;
    CvMat anglestub, *angle = (CvMat*)anglearr;
    int coi1 = 0, coi2 = 0, coi3 = 0, coi4 = 0;
    int depth;
    CvSize size;
    int x, y;
    int cont_flag = CV_MAT_CONT_FLAG;
    
    if( !CV_IS_MAT(xmat))
        CV_CALL( xmat = cvGetMat( xmat, &xstub, &coi1 ));

    if( !CV_IS_MAT(ymat))
        CV_CALL( ymat = cvGetMat( ymat, &ystub, &coi2 ));

    if( !CV_ARE_TYPES_EQ( xmat, ymat ) )
        CV_ERROR_FROM_CODE( CV_StsUnmatchedFormats );

    if( !CV_ARE_SIZES_EQ( xmat, ymat ) )
        CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );

    depth = CV_MAT_DEPTH( xmat->type );
    if( depth < CV_32F )
        CV_ERROR( CV_StsUnsupportedFormat, "" );

    if( mag )
    {
        CV_CALL( mag = cvGetMat( mag, &magstub, &coi3 ));

        if( !CV_ARE_TYPES_EQ( mag, xmat ) )
            CV_ERROR_FROM_CODE( CV_StsUnmatchedFormats );
        
        if( !CV_ARE_SIZES_EQ( mag, xmat ) )
            CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );
        cont_flag = mag->type;
    }

    if( angle )
    {
        CV_CALL( angle = cvGetMat( angle, &anglestub, &coi4 ));

        if( !CV_ARE_TYPES_EQ( angle, xmat ) )
            CV_ERROR_FROM_CODE( CV_StsUnmatchedFormats );
        
        if( !CV_ARE_SIZES_EQ( angle, xmat ) )
            CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );
        cont_flag &= angle->type;
    }

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

    size = cvGetMatSize(xmat);
    size.width *= CV_MAT_CN(xmat->type);

    if( CV_IS_MAT_CONT( xmat->type & ymat->type & cont_flag ))
    {
        size.width *= size.height;
        size.height = 1;
    }

    block_size = MIN( size.width, ICV_MATH_BLOCK_SIZE );
    if( depth == CV_64F && angle )
    {
        x_buffer = (float*)cvAlloc( block_size*sizeof(float));
        y_buffer = (float*)cvAlloc( block_size*sizeof(float));
    }
    else if( depth == CV_32F && mag )
    {
        mag_buffer = (float*)cvAlloc( block_size*sizeof(float));
    }

    if( depth == CV_32F )
    {
        for( y = 0; y < size.height; y++ )
        {
            float* x_data = (float*)(xmat->data.ptr + xmat->step*y);
            float* y_data = (float*)(ymat->data.ptr + ymat->step*y);
            float* mag_data = mag ? (float*)(mag->data.ptr + mag->step*y) : 0;
            float* angle_data = angle ? (float*)(angle->data.ptr + angle->step*y) : 0;

            for( x = 0; x < size.width; x += block_size )
            {
                int len = MIN( size.width - x, block_size );

                if( mag )
                    icvSqrMagnitude_32f( x_data + x, y_data + x, mag_buffer, len );

                if( angle )
                {
                    icvFastArctan_32f( y_data + x, x_data + x, angle_data + x, len );
                    if( !angle_in_degrees )
                        icvScale_32f( angle_data + x, angle_data + x,
                                      len, (float)(CV_PI/180.), 0 );
                }

                if( mag )
                    icvSqrt_32f( mag_buffer, mag_data + x, len );
            }
        }
    }
    else
    {
        for( y = 0; y < size.height; y++ )
        {
            double* x_data = (double*)(xmat->data.ptr + xmat->step*y);
            double* y_data = (double*)(ymat->data.ptr + ymat->step*y);
            double* mag_data = mag ? (double*)(mag->data.ptr + mag->step*y) : 0;
            double* angle_data = angle ? (double*)(angle->data.ptr + angle->step*y) : 0;

            for( x = 0; x < size.width; x += block_size )
            {
                int len = MIN( size.width - x, block_size );

                if( angle )
                {
                    icvCvt_64f32f( x_data + x, x_buffer, len );
                    icvCvt_64f32f( y_data + x, y_buffer, len );
                }

                if( mag )
                {
                    icvSqrMagnitude_64f( x_data + x, y_data + x, mag_data + x, len );
                    icvSqrt_64f( mag_data + x, mag_data + x, len );
                }

                if( angle )
                {
                    icvFastArctan_32f( y_buffer, x_buffer, x_buffer, len );
                    if( !angle_in_degrees )
                        icvScale_32f( x_buffer, x_buffer, len, (float)(CV_PI/180.), 0 );
                    icvCvt_32f64f( x_buffer, angle_data + x, len );
                }
            }
        }
    }

    __END__;
}


/****************************************************************************************\
*                                    P O W E R                                           *
\****************************************************************************************/

#define ICV_DEF_IPOW_OP( flavor, arrtype, worktype, cast_macro )                    \
static CvStatus CV_STDCALL                                                          \
icvIPow_##flavor( const arrtype* src, arrtype* dst, int len, int power )            \
{                                                                                   \
    int i;                                                                          \
                                                                                    \
    for( i = 0; i < len; i++ )                                                      \
    {                                                                               \
        worktype a = 1, b = src[i];                                                 \
        int p = power;                                                              \
        while( p > 1 )                                                              \
        {                                                                           \
            if( p & 1 )                                                             \
                a *= b;                                                             \
            b *= b;                                                                 \
            p >>= 1;                                                                \
        }                                                                           \
                                                                                    \
        a *= b;                                                                     \
        dst[i] = cast_macro(a);                                                     \
    }                                                                               \
                                                                                    \
    return CV_OK;                                                                   \
}


ICV_DEF_IPOW_OP( 8u, uchar, int, CV_CAST_8U )
ICV_DEF_IPOW_OP( 16u, ushort, int, CV_CAST_16U )
ICV_DEF_IPOW_OP( 16s, short, int, CV_CAST_16S )
ICV_DEF_IPOW_OP( 32s, int, int, CV_CAST_32S )
ICV_DEF_IPOW_OP( 32f, float, double, CV_CAST_32F )
ICV_DEF_IPOW_OP( 64f, double, double, CV_CAST_64F )

#define icvIPow_8s 0

CV_DEF_INIT_FUNC_TAB_1D( IPow )

typedef CvStatus (CV_STDCALL * CvIPowFunc)( const void* src, void* dst, int len, int power );
typedef CvStatus (CV_STDCALL * CvSqrtFunc)( const void* src, void* dst, int len );

CV_IMPL void cvPow( const CvArr* srcarr, CvArr* dstarr, double power )
{
    static CvFuncTable ipow_tab;
    static int inittab = 0;
    
    CV_FUNCNAME( "cvPow" );

    __BEGIN__;

    void* temp_buffer = 0;
    int block_size = 0;
    CvMat srcstub, *src = (CvMat*)srcarr;
    CvMat dststub, *dst = (CvMat*)dstarr;
    int coi1 = 0, coi2 = 0;
    int depth;
    CvSize size;
    int x, y;
    int ipower = cvRound( power );
    int is_ipower = 0;
    
    if( !CV_IS_MAT(src))
        CV_CALL( src = cvGetMat( src, &srcstub, &coi1 ));

    if( !CV_IS_MAT(dst))
        CV_CALL( dst = cvGetMat( dst, &dststub, &coi2 ));

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

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

    if( !CV_ARE_SIZES_EQ( src, dst ) )
        CV_ERROR_FROM_CODE( CV_StsUnmatchedSizes );

    depth = CV_MAT_DEPTH( src->type );

    if( fabs(ipower - power) < DBL_EPSILON )
    {
        if( !inittab )
        {
            icvInitIPowTable( &ipow_tab );
            inittab = 1;
        }

        if( ipower < 0 )
        {
            CV_CALL( cvDiv( 0, src, dst ));
            
            if( ipower == -1 )
                EXIT;
            ipower = -ipower;
            src = dst;
        }
        
        switch( ipower )
        {
        case 0:
            cvSet( dst, cvScalarAll(1));
            EXIT;
        case 1:
            cvCopy( src, dst );
            EXIT;
        case 2:
            cvMul( src, src, dst );
            EXIT;
        default:
            is_ipower = 1;
        }
    }
    else if( depth < CV_32F )
        CV_ERROR( CV_StsUnsupportedFormat,
        "Fractional or negative integer power factor can be used "
        "with floating-point types only");

    size = cvGetMatSize(src);
    size.width *= CV_MAT_CN(src->type);

    if( CV_IS_MAT_CONT( src->type & dst->type ))
    {
        size.width *= size.height;
        size.height = 1;
    }

    if( is_ipower )
    {
        CvIPowFunc pow_func = (CvIPowFunc)ipow_tab.fn_2d[depth];
        if( !pow_func )
            CV_ERROR( CV_StsUnsupportedFormat, "The data type is not supported" );
        
        for( y = 0; y < size.height; y++ )
        {
            uchar* src_data = src->data.ptr + src->step*y;
            uchar* dst_data = dst->data.ptr + dst->step*y;

            pow_func( src_data, dst_data, size.width, ipower );
        }
    }
    else if( fabs(fabs(power) - 0.5) < DBL_EPSILON )
    {
        CvSqrtFunc sqrt_func = power < 0 ? 
            (depth == CV_32F ? (CvSqrtFunc)icvInvSqrt_32f : (CvSqrtFunc)icvInvSqrt_64f) :
            (depth == CV_32F ? (CvSqrtFunc)icvSqrt_32f : (CvSqrtFunc)icvSqrt_64f);

        for( y = 0; y < size.height; y++ )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久久蜜桃| 国产一区二区网址| 色女孩综合影院| 日韩av一区二区在线影视| 久久久精品tv| 91精品国产91热久久久做人人 | 欧美成人一区二区三区在线观看| 久久99精品久久久| 亚洲综合在线五月| 亚洲国产精品激情在线观看| 日韩欧美国产麻豆| 欧美综合视频在线观看| 成人永久aaa| 久久国产生活片100| 亚洲成人av一区二区三区| 亚洲图片激情小说| 日韩女同互慰一区二区| 欧美日韩国产乱码电影| 在线观看亚洲成人| 97久久精品人人做人人爽| 国产精品1区二区.| 久久99国产精品免费| 日韩一区精品视频| 狠狠久久亚洲欧美| 日韩一级免费观看| 91视频你懂的| 成人a级免费电影| 国内精品久久久久影院一蜜桃| 亚洲国产va精品久久久不卡综合| 国产精品美女视频| 国产日产欧美一区二区视频| 日韩一区国产二区欧美三区| 欧美军同video69gay| 欧美性高清videossexo| 色哟哟在线观看一区二区三区| jlzzjlzz国产精品久久| 成人免费视频网站在线观看| 盗摄精品av一区二区三区| 国产麻豆成人精品| 精品在线你懂的| 国产一区二区调教| 国产福利精品导航| 欧美亚洲一区二区三区四区| 成人av资源在线| av综合在线播放| 91色在线porny| 欧美性xxxxx极品少妇| 欧美亚洲国产怡红院影院| 欧美视频日韩视频| 欧美乱妇一区二区三区不卡视频| 91极品美女在线| 欧美视频一区二区三区在线观看| 欧美另类videos死尸| 欧美一区二区三区免费视频| 日韩免费在线观看| 久久久久99精品国产片| 国产精品毛片大码女人| 亚洲精品免费看| 亚洲va欧美va人人爽| 免费一级欧美片在线观看| 国产资源精品在线观看| 成人三级伦理片| 在线观看日韩精品| 91精品国产福利| 国产午夜精品久久久久久久| 日韩美女精品在线| 视频一区二区三区在线| 激情深爱一区二区| 成人高清伦理免费影院在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美性色黄大片手机版| 精品美女一区二区三区| 中文字幕亚洲一区二区av在线| 亚洲福利一区二区三区| 美女尤物国产一区| 99国产精品久久久久久久久久久 | 欧美三电影在线| 日韩欧美视频一区| ㊣最新国产の精品bt伙计久久| 亚洲综合免费观看高清完整版 | 精品美女被调教视频大全网站| 国产精品亲子伦对白| 亚洲国产视频直播| 国产一区二区三区观看| 日本韩国一区二区三区| 久久久久久麻豆| 亚洲动漫第一页| 成人免费视频播放| 国产三区在线成人av| 有码一区二区三区| 国产精品中文字幕欧美| 欧美在线视频你懂得| 国产亚洲美州欧州综合国 | 国产白丝精品91爽爽久久| 欧美专区日韩专区| 久久精品亚洲国产奇米99 | 成人av免费在线播放| 91精品国产综合久久久蜜臀图片| 国产精品免费网站在线观看| 青青草精品视频| 欧美午夜精品一区二区蜜桃| 欧美激情在线观看视频免费| 麻豆精品一区二区| 欧美日韩亚洲综合| √…a在线天堂一区| 国产精品一区二区三区四区| 91精品国产乱码| 夜夜嗨av一区二区三区网页| 成人免费毛片高清视频| 精品国产乱码久久久久久久| 亚洲6080在线| 色婷婷av一区二区三区软件 | 国产乱人伦偷精品视频不卡| 欧美日本高清视频在线观看| 成人免费小视频| 国产一区二区三区免费播放| 91精品国产麻豆| 午夜不卡av在线| 91久久精品国产91性色tv| 18成人在线视频| a亚洲天堂av| 国产精品女同一区二区三区| 国产精品亚洲一区二区三区妖精 | 国v精品久久久网| 欧美va亚洲va国产综合| 日韩精品亚洲一区| 欧美日韩色一区| 亚洲成人免费看| 欧美日韩一区二区三区四区| 亚洲午夜影视影院在线观看| 色狠狠桃花综合| 亚洲欧美激情小说另类| 色又黄又爽网站www久久| 亚洲欧美自拍偷拍| av中文一区二区三区| 国产精品色噜噜| 不卡视频免费播放| 亚洲欧美激情一区二区| 91久久久免费一区二区| 一区二区三区美女| 欧美伊人久久久久久久久影院| 夜夜嗨av一区二区三区四季av| 91毛片在线观看| 一级女性全黄久久生活片免费| 色哟哟在线观看一区二区三区| 亚洲自拍偷拍欧美| 精品视频一区二区不卡| 青青草精品视频| 精品国产一二三| 国产**成人网毛片九色 | 国产乱码精品一区二区三区五月婷| 日韩免费在线观看| 国产精品99久久久久久有的能看| 久久久久久一二三区| 成人高清免费观看| 亚洲免费看黄网站| 欧美精品日韩一区| 精品一区二区三区欧美| 中文字幕不卡的av| 色吧成人激情小说| 奇米影视一区二区三区小说| 久久久午夜电影| 色婷婷精品大在线视频| 五月婷婷激情综合| 亚洲精品一区二区三区香蕉| 国产91在线|亚洲| 一区二区日韩av| 欧美一二三区在线观看| 成人动漫视频在线| 香蕉影视欧美成人| 国产三级精品三级在线专区| 色综合激情五月| 老司机精品视频一区二区三区| 国产视频一区二区三区在线观看| 日本道在线观看一区二区| 蜜桃视频一区二区| 中文字幕中文字幕一区| 制服丝袜亚洲色图| 成人免费精品视频| 天天av天天翘天天综合网色鬼国产| 精品国产在天天线2019| 色呦呦日韩精品| 国产一区二区三区电影在线观看| 亚洲精品久久嫩草网站秘色| 日韩午夜激情免费电影| 99re亚洲国产精品| 麻豆精品一区二区综合av| 综合婷婷亚洲小说| 精品国产凹凸成av人导航| 在线观看欧美黄色| 国产麻豆视频精品| 午夜婷婷国产麻豆精品| 中国色在线观看另类| 欧美一级艳片视频免费观看| 99久久精品情趣| 国产乱码精品一区二区三区忘忧草| 亚洲一区二区三区国产| 国产女人水真多18毛片18精品视频| 欧美日韩极品在线观看一区| 成人av资源网站|