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

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

?? cxmatmul.cpp

?? 將OpenCV移植到DSP上
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
    else if( d_size.width*sizeof(d_data[0]) <= 1600 )                       \
    {                                                                       \
        for( i = 0; i < drows; i++, _a_data += a_step0,                     \
                                    _c_data += c_step0,                     \
                                    d_data += d_step )                      \
        {                                                                   \
            a_data = _a_data, c_data = _c_data;                             \
                                                                            \
            if( a_buf )                                                     \
            {                                                               \
                for( k = 0; k < n; k++ )                                    \
                    a_buf[k] = a_data[a_step1*k];                           \
                a_data = a_buf;                                             \
            }                                                               \
                                                                            \
            for( j = 0; j <= m - 4; j += 4, c_data += 4*c_step1 )           \
            {                                                               \
                const arrtype* b = _b_data + j;                             \
                worktype s0(0), s1(0), s2(0), s3(0);                        \
                                                                            \
                for( k = 0; k < n; k++, b += b_step )                       \
                {                                                           \
                    worktype a(a_data[k]);                                  \
                    s0 += a * b[0]; s1 += a * b[1];                         \
                    s2 += a * b[2]; s3 += a * b[3];                         \
                }                                                           \
                                                                            \
                if( !c_data )                                               \
                {                                                           \
                    d_data[j] = arrtype(s0*alpha);                          \
                    d_data[j+1] = arrtype(s1*alpha);                        \
                    d_data[j+2] = arrtype(s2*alpha);                        \
                    d_data[j+3] = arrtype(s3*alpha);                        \
                }                                                           \
                else                                                        \
                {                                                           \
                    s0 = s0*alpha; s1 = s1*alpha;                           \
                    s2 = s2*alpha; s3 = s3*alpha;                           \
                    d_data[j] = arrtype(s0 + c_data[0]*beta);               \
                    d_data[j+1] = arrtype(s1 + c_data[c_step1]*beta);       \
                    d_data[j+2] = arrtype(s2 + c_data[c_step1*2]*beta);     \
                    d_data[j+3] = arrtype(s3 + c_data[c_step1*3]*beta);     \
                }                                                           \
            }                                                               \
                                                                            \
            for( ; j < m; j++, c_data += c_step1 )                          \
            {                                                               \
                const arrtype* b = _b_data + j;                             \
                worktype s0(0);                                             \
                                                                            \
                for( k = 0; k < n; k++, b += b_step )                       \
                    s0 += worktype(a_data[k]) * b[0];                       \
                                                                            \
                s0 = s0*alpha;                                              \
                if( !c_data )                                               \
                    d_data[j] = arrtype(s0);                                \
                else                                                        \
                    d_data[j] = arrtype(s0 + c_data[0]*beta);               \
            }                                                               \
        }                                                                   \
    }                                                                       \
    else                                                                    \
    {                                                                       \
        worktype* d_buf = (worktype*)cvAlloc(m*sizeof(d_buf[0]));      \
                                                                            \
        for( i = 0; i < drows; i++, _a_data += a_step0,                     \
                                            _c_data += c_step0,             \
                                            d_data += d_step )              \
        {                                                                   \
            a_data = _a_data;                                               \
            b_data = _b_data;                                               \
            c_data = _c_data;                                               \
                                                                            \
            if( a_buf )                                                     \
            {                                                               \
                for( k = 0; k < n; k++ )                                    \
                    a_buf[k] = _a_data[a_step1*k];                          \
                a_data = a_buf;                                             \
            }                                                               \
                                                                            \
            for( j = 0; j < m; j++ )                                        \
                d_buf[j] = worktype(0);                                     \
                                                                            \
            for( k = 0; k < n; k++, b_data += b_step )                      \
            {                                                               \
                worktype al(a_data[k]);                                     \
                                                                            \
                for( j = 0; j <= m - 4; j += 4 )                            \
                {                                                           \
                    worktype t0 = d_buf[j] + b_data[j]*al;                  \
                    worktype t1 = d_buf[j+1] + b_data[j+1]*al;              \
                    d_buf[j] = t0;                                          \
                    d_buf[j+1] = t1;                                        \
                    t0 = d_buf[j+2] + b_data[j+2]*al;                       \
                    t1 = d_buf[j+3] + b_data[j+3]*al;                       \
                    d_buf[j+2] = t0;                                        \
                    d_buf[j+3] = t1;                                        \
                }                                                           \
                                                                            \
                for( ; j < m; j++ )                                         \
                    d_buf[j] += b_data[j]*al;                               \
            }                                                               \
                                                                            \
            if( !c_data )                                                   \
                for( j = 0; j < m; j++ )                                    \
                    d_data[j] = arrtype(d_buf[j]*alpha);                    \
            else                                                            \
                for( j = 0; j < m; j++, c_data += c_step1 )                 \
                {                                                           \
                    worktype t = d_buf[j]*alpha;                            \
                    d_data[j] = arrtype(t + c_data[0]*beta);                \
                }                                                           \
        }                                                                   \
    }                                                                       \
    return CV_OK;                                                           \
}


#define ICV_DEF_GEMM_BLOCK_MUL( flavor, arrtype, worktype )         \
static CvStatus CV_STDCALL                                          \
icvGEMMBlockMul_##flavor( const arrtype* a_data, size_t a_step,     \
                        const arrtype* b_data, size_t b_step,       \
                        worktype* d_data, size_t d_step,            \
                        CvSize a_size, CvSize d_size, int flags )   \
{                                                                   \
    int i, j, k, n = a_size.width, m = d_size.width;                \
    const arrtype *_a_data = a_data, *_b_data = b_data;             \
    arrtype* a_buf = 0;                                             \
    size_t a_step0, a_step1, t_step;                                \
    int do_acc = flags & 16;                                        \
                                                                    \
    a_step /= sizeof(a_data[0]);                                    \
    b_step /= sizeof(b_data[0]);                                    \
    d_step /= sizeof(d_data[0]);                                    \
                                                                    \
    a_step0 = a_step;                                               \
    a_step1 = 1;                                                    \
                                                                    \
    if( flags & CV_GEMM_A_T )                                       \
    {                                                               \
        CV_SWAP( a_step0, a_step1, t_step );                        \
        n = a_size.height;                                          \
        a_buf = (arrtype*)cvAlloc(n*sizeof(a_data[0]));        \
    }                                                               \
                                                                    \
    if( flags & CV_GEMM_B_T )                                       \
    {                                                               \
        /* second operand is transposed */                          \
        for( i = 0; i < d_size.height; i++, _a_data += a_step0,     \
                                            d_data += d_step )      \
        {                                                           \
            a_data = _a_data; b_data = _b_data;                     \
                                                                    \
            if( a_buf )                                             \
            {                                                       \
                for( k = 0; k < n; k++ )                            \
                    a_buf[k] = a_data[a_step1*k];                   \
                a_data = a_buf;                                     \
            }                                                       \
                                                                    \
            for( j = 0; j < d_size.width; j++, b_data += b_step )   \
            {                                                       \
                worktype s0 = do_acc ? d_data[j]:worktype(0), s1(0);\
                for( k = 0; k <= n - 2; k += 2 )                    \
                {                                                   \
                    s0 += worktype(a_data[k])*b_data[k];            \
                    s1 += worktype(a_data[k+1])*b_data[k+1];        \
                }                                                   \
                                                                    \
                for( ; k < n; k++ )                                 \
                    s0 += worktype(a_data[k])*b_data[k];            \
                                                                    \
                d_data[j] = s0 + s1;                                \
            }                                                       \
        }                                                           \
    }                                                               \
    else                                                            \
    {                                                               \
        for( i = 0; i < d_size.height; i++, _a_data += a_step0,     \
                                            d_data += d_step )      \
        {                                                           \
            a_data = _a_data, b_data = _b_data;                     \
                                                                    \
            if( a_buf )                                             \
            {                                                       \
                for( k = 0; k < n; k++ )                            \
                    a_buf[k] = a_data[a_step1*k];                   \
                a_data = a_buf;                                     \
            }                                                       \
                                                                    \
            for( j = 0; j <= m - 4; j += 4 )                        \
            {                                                       \
                worktype s0, s1, s2, s3;                            \
                const arrtype* b = b_data + j;                      \
                                                                    \
                if( do_acc )                                        \
                {                                                   \
                    s0 = d_data[j]; s1 = d_data[j+1];               \
                    s2 = d_data[j+2]; s3 = d_data[j+3];             \
                }                                                   \
                else                                                \
                    s0 = s1 = s2 = s3 = worktype(0);                \
                                                                    \
                for( k = 0; k < n; k++, b += b_step )               \
                {                                                   \
                    worktype a(a_data[k]);                          \
                    s0 += a * b[0]; s1 += a * b[1];                 \
                    s2 += a * b[2]; s3 += a * b[3];                 \
                }                                                   \
                                                                    \
                d_data[j] = s0; d_data[j+1] = s1;                   \
                d_data[j+2] = s2; d_data[j+3] = s3;                 \
            }                                                       \
                                                                    \
            for( ; j < m; j++ )                                     \
            {                                                       \
                const arrtype* b = b_data + j;                      \
                worktype s0 = do_acc ? d_data[j] : worktype(0);     \
                                                                    \
                for( k = 0; k < n; k++, b += b_step )               \
                    s0 += worktype(a_data[k]) * b[0];               \
                                                                    \
                d_data[j] = s0;                                     \
            }                                                       \
        }                                                           \
    }                                                               \
                                                                    \
    return CV_OK;                                                   \
}


#define ICV_DEF_GEMM_STORE( flavor, arrtype, worktype )             \
static CvStatus CV_STDCALL                                          \
icvGEMMStore_##flavor( const arrtype* c_data, size_t c_step,        \
                       const worktype* d_buf, size_t d_buf_step,    \
                       arrtype* d_data, size_t d_step, CvSize d_size,\
                       double alpha, double beta, int flags )       \
{                                                                   \
    const arrtype* _c_data = c_data;                                \
    int j;                                                          \
    size_t c_step0, c_step1;                                        \
                                                                    \
    c_step /= sizeof(c_data[0]);                                    \
    d_buf_step /= sizeof(d_buf[0]);                                 \
    d_step /= sizeof(d_data[0]);                                    \
                                                                    \
    if( !c_data )                                                   \
        c_step0 = c_step1 = 0;                                      \
    else if( !(flags & CV_GEMM_C_T) )                               \
        c_step0 = c_step, c_step1 = 1;                              \
    else                                                            \
        c_step0 = 1, c_step1 = c_step;                              \

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电影免费观看高清完整版在线 | 久久精品一二三| 91麻豆视频网站| 玖玖九九国产精品| 亚洲免费在线观看视频| 久久免费视频色| 欧美肥妇bbw| 色丁香久综合在线久综合在线观看| 久久99这里只有精品| 亚洲黄色小视频| 国产精品沙发午睡系列990531| 欧美一区二区三区色| 色综合久久精品| 懂色av中文一区二区三区| 久久爱www久久做| 午夜成人免费视频| 一区二区三区日韩| 亚洲美女电影在线| 中文字幕一区二区三区乱码在线| 日韩一级高清毛片| 欧美日韩视频在线观看一区二区三区 | 韩国三级电影一区二区| 午夜精品久久久久久久| 亚洲三级在线播放| 日本一区二区综合亚洲| 日韩精品专区在线影院观看| 欧美男生操女生| 欧美在线小视频| 在线观看视频一区二区欧美日韩| 成人av网站在线观看免费| 丰满少妇在线播放bd日韩电影| 日本欧美大码aⅴ在线播放| 亚洲国产精品久久艾草纯爱| 亚洲激情网站免费观看| 一区二区三区不卡在线观看| 亚洲欧美日韩人成在线播放| 中文字幕中文字幕一区二区 | 中文字幕一区二区三| 亚洲一线二线三线视频| 欧美日韩精品一区二区| 欧美在线小视频| 97精品久久久午夜一区二区三区| 成人福利视频网站| proumb性欧美在线观看| 91视频观看视频| 色综合久久久久久久久| 欧美怡红院视频| 欧美日韩国产免费| 日韩免费视频一区| 精品999在线播放| 久久精品亚洲精品国产欧美| 日本一区二区三区视频视频| 一区二区中文视频| 亚洲电影视频在线| 美女在线视频一区| 国产精品自在欧美一区| 成人精品国产一区二区4080| 一本一本大道香蕉久在线精品| 色吧成人激情小说| 欧美日韩中字一区| 日韩精品自拍偷拍| 国产精品天干天干在观线| 亚洲欧美另类图片小说| 亚洲成av人片一区二区梦乃 | 国产精品久久久久影视| 亚洲一区二区免费视频| 蜜桃一区二区三区在线| 国产成人av影院| 色综合色综合色综合| 这里只有精品视频在线观看| 精品成人免费观看| 亚洲婷婷国产精品电影人久久| 亚洲国产精品精华液网站| 九一久久久久久| 99久久久国产精品| 91精品欧美久久久久久动漫| 久久久五月婷婷| 亚洲精品乱码久久久久久久久 | 裸体歌舞表演一区二区| 成人av午夜影院| 678五月天丁香亚洲综合网| 国产视频不卡一区| 亚洲一二三四在线| 国产999精品久久久久久| 欧美日韩精品一区视频| 国产农村妇女毛片精品久久麻豆| 亚洲午夜久久久久久久久电影网 | 97久久久精品综合88久久| 欧美一级在线观看| 亚洲欧洲日韩在线| 激情图片小说一区| 在线观看日韩电影| 亚洲精品一区二区三区香蕉| 亚洲免费看黄网站| 国产一区二区三区久久久| 欧美综合视频在线观看| 国产女主播一区| 美女mm1313爽爽久久久蜜臀| 在线观看视频欧美| 国产精品网友自拍| 久久精品国产久精国产爱| 在线欧美日韩精品| 国产精品美女久久久久久久久 | 国产日韩欧美精品综合| 婷婷开心久久网| 91亚洲大成网污www| 国产亚洲综合性久久久影院| 视频一区二区国产| 精品欧美一区二区在线观看| 高清久久久久久| 宅男在线国产精品| 亚洲国产一区视频| 91麻豆免费观看| 国产精品嫩草影院com| 久久99精品国产麻豆婷婷洗澡| 欧美日韩视频不卡| 亚洲激情校园春色| 一本到一区二区三区| 国产精品拍天天在线| 国产成人免费视| 久久久久国产成人精品亚洲午夜| 青青草原综合久久大伊人精品 | 欧美亚洲另类激情小说| 亚洲蜜臀av乱码久久精品蜜桃| 成人动漫av在线| 国产欧美日韩综合| 国产精品影视天天线| 精品国精品自拍自在线| 久久超碰97中文字幕| 精品精品国产高清a毛片牛牛 | 91国产成人在线| 亚洲日本成人在线观看| 91一区二区三区在线观看| 中文字幕一区二区不卡| 9l国产精品久久久久麻豆| 日韩理论片一区二区| 91网页版在线| 一区二区三区在线影院| 欧美吻胸吃奶大尺度电影| 亚洲国产成人91porn| 欧美精品v日韩精品v韩国精品v| 亚洲成人先锋电影| 欧美一卡二卡三卡四卡| 国内精品写真在线观看| 国产欧美中文在线| 91在线播放网址| 一区二区三区成人| 欧美电影一区二区| 激情综合五月天| 国产亚洲精品aa| 99久久久无码国产精品| 亚洲综合久久久久| 欧美日韩成人综合| 精品一区二区在线免费观看| 国产丝袜美腿一区二区三区| 国产91露脸合集magnet| 国产精品二区一区二区aⅴ污介绍| 99re这里都是精品| 亚洲电影在线播放| 欧美刺激午夜性久久久久久久| 国产一区二区三区精品视频| 国产精品福利影院| 欧美三级日韩三级国产三级| 久久国产欧美日韩精品| 国产精品久久久久久久午夜片 | 石原莉奈在线亚洲二区| 精品国产一二三| 成人激情校园春色| 亚洲精品一二三| 欧美一级二级在线观看| 在线电影欧美成精品| 欧美一卡在线观看| 欧美高清一级片在线| 国产一区二区三区综合| 1024亚洲合集| 91精品国产综合久久精品性色| 国产精品资源在线| 一区二区不卡在线播放| 精品国产1区2区3区| 99这里都是精品| 麻豆精品国产传媒mv男同| 亚洲欧美乱综合| 日韩欧美一区二区视频| 成人福利视频网站| 免费一级片91| 亚洲视频在线一区观看| 欧美电影免费观看高清完整版在线 | 国产精品一区二区你懂的| 亚洲人成网站色在线观看| 欧美大白屁股肥臀xxxxxx| 日本精品一级二级| 国产一区二区91| 日日夜夜免费精品视频| 亚洲视频一二三区| 久久久亚洲综合| 日韩一区二区电影在线| 欧美在线短视频| 成人免费高清视频在线观看| 日韩成人一区二区| 亚洲自拍与偷拍|