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

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

?? cxlut.cpp

?? 將OpenCV移植到DSP上
?? CPP
字號:
/*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 "_cxcore.h"

/****************************************************************************************\
*                                    LUT Transform                                       *
\****************************************************************************************/

#define ICV_LUT_CASE_C1( type )             \
    for( i = 0; i <= size.width-4; i += 4 ) \
    {                                       \
        type t0 = lut[src[i]];              \
        type t1 = lut[src[i+1]];            \
        dst[i] = t0;                        \
        dst[i+1] = t1;                      \
                                            \
        t0 = lut[src[i+2]];                 \
        t1 = lut[src[i+3]];                 \
        dst[i+2] = t0;                      \
        dst[i+3] = t1;                      \
    }                                       \
                                            \
    for( ; i < size.width; i++ )            \
    {                                       \
        type t0 = lut[src[i]];              \
        dst[i] = t0;                        \
    }


#define ICV_LUT_CASE_C2( type )             \
    for( i = 0; i < size.width; i += 2 )    \
    {                                       \
        type t0 = lut[src[i]*2];            \
        type t1 = lut[src[i+1]*2 + 1];      \
        dst[i] = t0;                        \
        dst[i+1] = t1;                      \
    }

#define ICV_LUT_CASE_C3( type )             \
    for( i = 0; i < size.width; i += 3 )    \
    {                                       \
        type t0 = lut[src[i]*3];            \
        type t1 = lut[src[i+1]*3 + 1];      \
        type t2 = lut[src[i+2]*3 + 2];      \
        dst[i] = t0;                        \
        dst[i+1] = t1;                      \
        dst[i+2] = t2;                      \
    }

#define ICV_LUT_CASE_C4( type )             \
    for( i = 0; i < size.width; i += 4 )    \
    {                                       \
        type t0 = lut[src[i]*4];            \
        type t1 = lut[src[i+1]*4 + 1];      \
        dst[i] = t0;                        \
        dst[i+1] = t1;                      \
        t0 = lut[src[i+2]*4 + 2];           \
        t1 = lut[src[i+3]*4 + 3];           \
        dst[i+2] = t0;                      \
        dst[i+3] = t1;                      \
    }


#define  ICV_DEF_LUT_FUNC_8U_CN( flavor, dsttype, cn )      \
CvStatus CV_STDCALL icvLUT_Transform8u_##flavor##_C##cn##R( \
    const uchar* src, int srcstep,                          \
    dsttype* dst, int dststep, CvSize size,                 \
    const dsttype* lut )                                    \
{                                                           \
    size.width *= cn;                                       \
    dststep /= sizeof(dst[0]);                              \
    for( ; size.height--; src += srcstep, dst += dststep )  \
    {                                                       \
        int i;                                              \
        ICV_LUT_CASE_C##cn( dsttype )                       \
    }                                                       \
                                                            \
    return CV_OK;                                           \
}


ICV_DEF_LUT_FUNC_8U_CN( 8u, uchar, 1 )
ICV_DEF_LUT_FUNC_8U_CN( 16u, ushort, 1 )
ICV_DEF_LUT_FUNC_8U_CN( 32s, int, 1 )
ICV_DEF_LUT_FUNC_8U_CN( 64f, double, 1 )

ICV_DEF_LUT_FUNC_8U_CN( 8u, uchar, 2 )
ICV_DEF_LUT_FUNC_8U_CN( 8u, uchar, 3 )
ICV_DEF_LUT_FUNC_8U_CN( 8u, uchar, 4 )


#define  ICV_DEF_LUT_FUNC_8U( flavor, dsttype )             \
static CvStatus CV_STDCALL                                  \
icvLUT_Transform8u_##flavor##_CnR(                          \
    const uchar* src, int srcstep,                          \
    dsttype* dst, int dststep, CvSize size,                 \
    const dsttype* _lut, int cn )                           \
{                                                           \
    int max_block_size = (1 << 10)*cn;                      \
    dsttype lutp[1024];                                     \
    int i, k;                                               \
                                                            \
    size.width *= cn;                                       \
    dststep /= sizeof(dst[0]);                              \
                                                            \
    if( size.width*size.height < 256 )                      \
    {                                                       \
        for( ; size.height--; src+=srcstep, dst+=dststep )  \
            for( k = 0; k < cn; k++ )                       \
                for( i = 0; i < size.width; i += cn )       \
                    dst[i+k] = _lut[src[i+k]*cn+k];         \
        return CV_OK;                                       \
    }                                                       \
                                                            \
    /* repack the lut to planar layout */                   \
    for( k = 0; k < cn; k++ )                               \
        for( i = 0; i < 256; i++ )                          \
            lutp[i+k*256] = _lut[i*cn+k];                   \
                                                            \
    for( ; size.height--; src += srcstep, dst += dststep )  \
    {                                                       \
        for( i = 0; i < size.width; )                       \
        {                                                   \
            int j, limit = MIN(size.width,i+max_block_size);\
            for( k=0; k<cn; k++, src++, dst++ )             \
            {                                               \
                const dsttype* lut = lutp + k*256;          \
                for( j = i; j <= limit - cn*2; j += cn*2 )  \
                {                                           \
                    dsttype t0 = lut[src[j]];               \
                    dsttype t1 = lut[src[j+cn]];            \
                    dst[j] = t0; dst[j+cn] = t1;            \
                }                                           \
                                                            \
                for( ; j < limit; j += cn )                 \
                    dst[j] = lut[src[j]];                   \
            }                                               \
            src -= cn;                                      \
            dst -= cn;                                      \
            i += limit;                                     \
        }                                                   \
    }                                                       \
                                                            \
    return CV_OK;                                           \
}

ICV_DEF_LUT_FUNC_8U( 8u, uchar )
ICV_DEF_LUT_FUNC_8U( 16u, ushort )
ICV_DEF_LUT_FUNC_8U( 32s, int )
ICV_DEF_LUT_FUNC_8U( 64f, double )

#undef   icvLUT_Transform8u_8s_C1R
#undef   icvLUT_Transform8u_16s_C1R
#undef   icvLUT_Transform8u_32f_C1R

#define  icvLUT_Transform8u_8s_C1R    icvLUT_Transform8u_8u_C1R
#define  icvLUT_Transform8u_16s_C1R   icvLUT_Transform8u_16u_C1R
#define  icvLUT_Transform8u_32f_C1R   icvLUT_Transform8u_32s_C1R

#define  icvLUT_Transform8u_8s_CnR    icvLUT_Transform8u_8u_CnR
#define  icvLUT_Transform8u_16s_CnR   icvLUT_Transform8u_16u_CnR
#define  icvLUT_Transform8u_32f_CnR   icvLUT_Transform8u_32s_CnR

CV_DEF_INIT_FUNC_TAB_2D( LUT_Transform8u, C1R )
CV_DEF_INIT_FUNC_TAB_2D( LUT_Transform8u, CnR )

typedef CvStatus (CV_STDCALL * CvLUT_TransformCnFunc)(
    const void* src, int srcstep, void* dst,
    int dststep, CvSize size, const void* lut, int cn );

CV_IMPL  void
cvLUT( const void* srcarr, void* dstarr, const void* lutarr )
{
    static CvFuncTable lut_c1_tab, lut_cn_tab;
    static CvLUT_TransformFunc lut_8u_tab[4];
    static int inittab = 0;

    CV_FUNCNAME( "cvLUT" );

    __BEGIN__;

    int  coi1 = 0, coi2 = 0;
    int  depth, cn, lut_cn;
    CvMat  srcstub, *src = (CvMat*)srcarr;
    CvMat  dststub, *dst = (CvMat*)dstarr;
    CvMat  lutstub, *lut = (CvMat*)lutarr;
    uchar* lut_data;
    uchar* shuffled_lut = 0;
    CvSize size;

    if( !inittab )
    {
        icvInitLUT_Transform8uC1RTable( &lut_c1_tab );
        icvInitLUT_Transform8uCnRTable( &lut_cn_tab );
        lut_8u_tab[0] = (CvLUT_TransformFunc)icvLUT_Transform8u_8u_C1R;
        lut_8u_tab[1] = (CvLUT_TransformFunc)icvLUT_Transform8u_8u_C2R;
        lut_8u_tab[2] = (CvLUT_TransformFunc)icvLUT_Transform8u_8u_C3R;
        lut_8u_tab[3] = (CvLUT_TransformFunc)icvLUT_Transform8u_8u_C4R;
        inittab = 1;
    }

    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( !CV_IS_MAT(lut) )
        CV_CALL( lut = cvGetMat( lut, &lutstub ));

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

    if( !CV_ARE_SIZES_EQ( src, dst ))
        CV_ERROR( CV_StsUnmatchedSizes, "" );

    if( !CV_ARE_CNS_EQ( src, dst ))
        CV_ERROR( CV_StsUnmatchedFormats, "" );

    if( CV_MAT_DEPTH( src->type ) > CV_8S )
        CV_ERROR( CV_StsUnsupportedFormat, "" );

    depth = CV_MAT_DEPTH( dst->type );
    cn = CV_MAT_CN( dst->type );
    lut_cn = CV_MAT_CN( lut->type );

    if( !CV_IS_MAT_CONT(lut->type) || (lut_cn != 1 && lut_cn != cn) ||
        !CV_ARE_DEPTHS_EQ( dst, lut ) || lut->width*lut->height != 256 )
        CV_ERROR( CV_StsBadArg, "The LUT must be continuous array \n"
                                "with 256 elements of the same type as destination" );

    size = cvGetMatSize( src );
    if( lut_cn == 1 )
    {
        size.width *= cn;
        cn = 1;
    }

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

    lut_data = lut->data.ptr;

    if( CV_MAT_DEPTH( src->type ) == CV_8S )
    {
        int half_size = CV_ELEM_SIZE1(depth)*cn*128;
        shuffled_lut = (uchar*)cvAlloc(half_size*2);

        // shuffle lut
        memcpy( shuffled_lut, lut_data + half_size, half_size );
        memcpy( shuffled_lut + half_size, lut_data, half_size );

        lut_data = shuffled_lut;
    }

    if( lut_cn == 1 || lut_cn <= 4 && depth == CV_8U )
    {
        CvLUT_TransformFunc func = depth == CV_8U ? lut_8u_tab[cn-1] :
            (CvLUT_TransformFunc)(lut_c1_tab.fn_2d[depth]);
    
        if( !func )
            CV_ERROR( CV_StsUnsupportedFormat, "" );

        IPPI_CALL( func( src->data.ptr, src->step, dst->data.ptr,
                         dst->step, size, lut_data ));
    }
    else
    {
        CvLUT_TransformCnFunc func =
            (CvLUT_TransformCnFunc)(lut_cn_tab.fn_2d[depth]);
    
        if( !func )
            CV_ERROR( CV_StsUnsupportedFormat, "" );

        IPPI_CALL( func( src->data.ptr, src->step, dst->data.ptr,
                         dst->step, size, lut_data, cn ));
    }

    __END__;
}

/* End of file. */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米精品一区二区三区在线观看一| 欧美一区二区三区系列电影| 国产精品久久久久三级| 成人中文字幕在线| 综合av第一页| 欧洲一区二区av| 丝瓜av网站精品一区二区| 日韩一区二区视频在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 欧美日韩成人一区| 亚洲欧美区自拍先锋| 日韩欧美中文一区二区| 国产精品性做久久久久久| 久久精品国产精品亚洲红杏| 日韩欧美电影一二三| 亚洲一区二区美女| 国产精品美女久久久久久久| 国产精品污污网站在线观看| 日日摸夜夜添夜夜添亚洲女人| 亚洲 欧美综合在线网络| 一本久久精品一区二区| 欧美精品乱码久久久久久按摩 | 婷婷国产在线综合| 中文字幕中文字幕一区二区| 一区二区三区鲁丝不卡| 麻豆精品视频在线观看视频| 91丝袜国产在线播放| 精品国产123| 国产乱码精品一品二品| 亚洲四区在线观看| 日韩欧美中文字幕一区| 大白屁股一区二区视频| 亚洲成av人在线观看| 久久精品夜色噜噜亚洲a∨| 色综合一区二区三区| 日韩av网站在线观看| 中文字幕中文字幕一区二区| 欧美久久久久久久久久| 北岛玲一区二区三区四区| 亚洲v精品v日韩v欧美v专区| 国产色一区二区| 欧美精品在线观看一区二区| 成人亚洲精品久久久久软件| 免费欧美在线视频| 亚洲综合无码一区二区| 国产欧美中文在线| 欧美一级片在线观看| 91浏览器在线视频| 国产在线播精品第三| 亚洲图片一区二区| 久久久精品国产免费观看同学| 欧美午夜理伦三级在线观看| 成人一区在线观看| 精品一区二区三区免费毛片爱| 亚洲国产日韩一区二区| 国产精品久久久久桃色tv| 精品国产乱码久久久久久影片| 欧美日韩国产成人在线免费| 91麻豆国产精品久久| 成人的网站免费观看| 国产在线播放一区三区四| 亚洲成人动漫在线免费观看| 一区二区三区四区中文字幕| 一区在线中文字幕| 亚洲国产激情av| 欧美国产日本视频| 国产日产欧美一区二区视频| 精品国产电影一区二区| 日韩一区二区不卡| 日韩一区二区视频| 日韩视频一区二区在线观看| 国产一区二区三区四区在线观看| 国产精品国产精品国产专区不蜜 | 欧美日韩免费电影| 视频一区视频二区中文| 精品久久久三级丝袜| 成人精品gif动图一区| 亚洲在线免费播放| 久久香蕉国产线看观看99| 色乱码一区二区三区88| 国内外成人在线| 亚洲综合色区另类av| 久久精品国产免费| 蜜桃视频在线一区| 秋霞av亚洲一区二区三| 美国毛片一区二区三区| 日本va欧美va精品| 免费在线观看一区| 久久99精品国产91久久来源| 久久99久久99| 久久综合九色综合欧美98| 欧美日韩国产美女| aaa欧美日韩| 99精品国产一区二区三区不卡| 国产一区二区在线视频| 另类小说综合欧美亚洲| 日韩av中文字幕一区二区 | 国产欧美日韩视频一区二区| 在线中文字幕不卡| 777午夜精品视频在线播放| 欧美日韩激情一区二区| 欧美四级电影在线观看| 欧美日韩精品电影| 日韩天堂在线观看| 日韩一区二区电影| 中文字幕欧美激情一区| 亚洲另类在线一区| 午夜av区久久| 国产成人免费xxxxxxxx| 视频一区在线视频| 天堂va蜜桃一区二区三区 | 337p亚洲精品色噜噜狠狠| 亚洲精品成人天堂一二三| 天天做天天摸天天爽国产一区 | 日韩精品中午字幕| 18欧美亚洲精品| 麻豆一区二区三| 91色婷婷久久久久合中文| 日韩亚洲欧美成人一区| 欧美在线999| 欧美精品少妇一区二区三区| 久久久午夜精品理论片中文字幕| 亚洲国产激情av| 国产精品一级片在线观看| 91麻豆成人久久精品二区三区| 91精品国产综合久久久久久| 久久噜噜亚洲综合| 亚洲一区二区三区小说| 精品福利一区二区三区免费视频| 成人开心网精品视频| 亚洲福利视频一区二区| 午夜久久久久久久久| 色婷婷亚洲一区二区三区| 黄一区二区三区| 亚洲一卡二卡三卡四卡| 国产色爱av资源综合区| 欧美日韩免费视频| av在线不卡电影| 国产精品中文字幕日韩精品 | 亚洲超丰满肉感bbw| 国产午夜精品一区二区三区四区| 色综合天天天天做夜夜夜夜做| 337p日本欧洲亚洲大胆精品 | 精品综合免费视频观看| 国产成人精品免费一区二区| 51精品秘密在线观看| 国产成人精品三级麻豆| 日韩欧美不卡一区| 香港成人在线视频| 99久久国产综合精品麻豆| 亚洲精品在线观看网站| 免费观看一级欧美片| 欧美人与禽zozo性伦| 一区二区三区久久| 色综合一区二区| 亚洲同性同志一二三专区| 成人午夜免费av| 国产欧美日韩综合精品一区二区| 亚洲国产日韩a在线播放性色| 国产精品久久久久永久免费观看| 99久久99久久久精品齐齐| 精品国产99国产精品| 毛片av一区二区三区| 欧美大片国产精品| 久久66热偷产精品| 精品国产3级a| 国产精品123区| 国产欧美精品一区二区色综合| 韩国精品主播一区二区在线观看| 日韩一卡二卡三卡四卡| 久久99精品视频| 国产亚洲一二三区| 国产在线视频一区二区| 久久久久久久国产精品影院| 国产精品1区2区3区在线观看| 久久亚洲精精品中文字幕早川悠里| 国产真实乱子伦精品视频| 久久久一区二区三区| 成人动漫一区二区在线| 樱花影视一区二区| 欧美日韩亚洲综合在线 | 韩国三级中文字幕hd久久精品| 欧美一级艳片视频免费观看| 久久91精品国产91久久小草 | 不卡的av网站| 91福利在线观看| 精品捆绑美女sm三区| 国产情人综合久久777777| 五月天欧美精品| 日韩亚洲欧美综合| 国产美女一区二区| 亚洲高清免费在线| 午夜激情久久久| 国产精品456露脸| 国产精品精品国产色婷婷| 一本色道久久综合精品竹菊| 午夜欧美在线一二页| 精品久久五月天| 91在线视频网址| 美女视频黄频大全不卡视频在线播放|