⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dsputil.c

📁 Trolltech公司发布的图形界面操作系统。可在qt-embedded-2.3.7平台上编译为嵌入式图形界面操作系统。
💻 C
📖 第 1 页 / 共 4 页
字号:
/* * DSP utils * Copyright (c) 2000, 2001 Fabrice Bellard. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * gmc & q-pel & 32/64 bit based MC by Michael Niedermayer <michaelni@gmx.at> */#include "avcodec.h"#include "dsputil.h"int ff_bit_exact=0;UINT8 cropTbl[256 + 2 * MAX_NEG_CROP];UINT32 squareTbl[512];const UINT8 ff_zigzag_direct[64] = {    0,   1,  8, 16,  9,  2,  3, 10,    17, 24, 32, 25, 18, 11,  4,  5,    12, 19, 26, 33, 40, 48, 41, 34,    27, 20, 13,  6,  7, 14, 21, 28,    35, 42, 49, 56, 57, 50, 43, 36,    29, 22, 15, 23, 30, 37, 44, 51,    58, 59, 52, 45, 38, 31, 39, 46,    53, 60, 61, 54, 47, 55, 62, 63};/* not permutated inverse zigzag_direct + 1 for MMX quantizer */UINT16 __align8 inv_zigzag_direct16[64];const UINT8 ff_alternate_horizontal_scan[64] = {    0,  1,   2,  3,  8,  9, 16, 17,     10, 11,  4,  5,  6,  7, 15, 14,    13, 12, 19, 18, 24, 25, 32, 33,     26, 27, 20, 21, 22, 23, 28, 29,    30, 31, 34, 35, 40, 41, 48, 49,     42, 43, 36, 37, 38, 39, 44, 45,    46, 47, 50, 51, 56, 57, 58, 59,     52, 53, 54, 55, 60, 61, 62, 63,};const UINT8 ff_alternate_vertical_scan[64] = {    0,  8,  16, 24,  1,  9,  2, 10,     17, 25, 32, 40, 48, 56, 57, 49,    41, 33, 26, 18,  3, 11,  4, 12,     19, 27, 34, 42, 50, 58, 35, 43,    51, 59, 20, 28,  5, 13,  6, 14,     21, 29, 36, 44, 52, 60, 37, 45,    53, 61, 22, 30,  7, 15, 23, 31,     38, 46, 54, 62, 39, 47, 55, 63,};/* a*inverse[b]>>32 == a/b for all 0<=a<=65536 && 2<=b<=255 */const UINT32 inverse[256]={         0, 4294967295U,2147483648U,1431655766, 1073741824,  858993460,  715827883,  613566757,  536870912,  477218589,  429496730,  390451573,  357913942,  330382100,  306783379,  286331154,  268435456,  252645136,  238609295,  226050911,  214748365,  204522253,  195225787,  186737709,  178956971,  171798692,  165191050,  159072863,  153391690,  148102321,  143165577,  138547333,  134217728,  130150525,  126322568,  122713352,  119304648,  116080198,  113025456,  110127367,  107374183,  104755300,  102261127,   99882961,   97612894,   95443718,   93368855,   91382283,   89478486,   87652394,   85899346,   84215046,   82595525,   81037119,   79536432,   78090315,   76695845,   75350304,   74051161,   72796056,   71582789,   70409300,   69273667,   68174085,   67108864,   66076420,   65075263,   64103990,   63161284,   62245903,   61356676,   60492498,   59652324,   58835169,   58040099,   57266231,   56512728,   55778797,   55063684,   54366675,   53687092,   53024288,   52377650,   51746594,   51130564,   50529028,   49941481,   49367441,   48806447,   48258060,   47721859,   47197443,   46684428,   46182445,   45691142,   45210183,   44739243,   44278014,   43826197,   43383509,   42949673,   42524429,   42107523,   41698712,   41297763,   40904451,   40518560,   40139882,   39768216,   39403370,   39045158,   38693400,   38347923,   38008561,   37675152,   37347542,   37025581,   36709123,   36398028,   36092163,   35791395,   35495598,   35204650,   34918434,   34636834,   34359739,   34087043,   33818641,   33554432,   33294321,   33038210,   32786010,   32537632,   32292988,   32051995,   31814573,   31580642,   31350127,   31122952,   30899046,   30678338,   30460761,   30246249,   30034737,   29826162,   29620465,   29417585,   29217465,   29020050,   28825284,   28633116,   28443493,   28256364,   28071682,   27889399,   27709467,   27531842,   27356480,   27183338,   27012373,   26843546,   26676816,   26512144,   26349493,   26188825,   26030105,   25873297,   25718368,   25565282,   25414008,   25264514,   25116768,   24970741,   24826401,   24683721,   24542671,   24403224,   24265352,   24129030,   23994231,   23860930,   23729102,   23598722,   23469767,   23342214,   23216040,   23091223,   22967740,   22845571,   22724695,   22605092,   22486740,   22369622,   22253717,   22139007,   22025474,   21913099,   21801865,   21691755,   21582751,   21474837,   21367997,   21262215,   21157475,   21053762,   20951060,   20849356,   20748635,   20648882,   20550083,   20452226,   20355296,   20259280,   20164166,   20069941,   19976593,   19884108,   19792477,   19701685,   19611723,   19522579,   19434242,   19346700,   19259944,   19173962,   19088744,   19004281,   18920561,   18837576,   18755316,   18673771,   18592933,   18512791,   18433337,   18354562,   18276457,   18199014,   18122225,   18046082,   17970575,   17895698,   17821442,   17747799,   17674763,   17602325,   17530479,   17459217,   17388532,   17318417,   17248865,   17179870,   17111424,   17043522,   16976156,   16909321,   16843010,};static int pix_sum_c(UINT8 * pix, int line_size){    int s, i, j;    s = 0;    for (i = 0; i < 16; i++) {	for (j = 0; j < 16; j += 8) {	    s += pix[0];	    s += pix[1];	    s += pix[2];	    s += pix[3];	    s += pix[4];	    s += pix[5];	    s += pix[6];	    s += pix[7];	    pix += 8;	}	pix += line_size - 16;    }    return s;}static int pix_norm1_c(UINT8 * pix, int line_size){    int s, i, j;    UINT32 *sq = squareTbl + 256;    s = 0;    for (i = 0; i < 16; i++) {	for (j = 0; j < 16; j += 8) {	    s += sq[pix[0]];	    s += sq[pix[1]];	    s += sq[pix[2]];	    s += sq[pix[3]];	    s += sq[pix[4]];	    s += sq[pix[5]];	    s += sq[pix[6]];	    s += sq[pix[7]];	    pix += 8;	}	pix += line_size - 16;    }    return s;}static void get_pixels_c(DCTELEM *restrict block, const UINT8 *pixels, int line_size){    int i;    /* read the pixels */    for(i=0;i<8;i++) {        block[0] = pixels[0];        block[1] = pixels[1];        block[2] = pixels[2];        block[3] = pixels[3];        block[4] = pixels[4];        block[5] = pixels[5];        block[6] = pixels[6];        block[7] = pixels[7];        pixels += line_size;        block += 8;    }}static void diff_pixels_c(DCTELEM *restrict block, const UINT8 *s1,			  const UINT8 *s2, int stride){    int i;    /* read the pixels */    for(i=0;i<8;i++) {        block[0] = s1[0] - s2[0];        block[1] = s1[1] - s2[1];        block[2] = s1[2] - s2[2];        block[3] = s1[3] - s2[3];        block[4] = s1[4] - s2[4];        block[5] = s1[5] - s2[5];        block[6] = s1[6] - s2[6];        block[7] = s1[7] - s2[7];        s1 += stride;        s2 += stride;        block += 8;    }}static void put_pixels_clamped_c(const DCTELEM *block, UINT8 *restrict pixels,				 int line_size){    int i;    UINT8 *cm = cropTbl + MAX_NEG_CROP;        /* read the pixels */    for(i=0;i<8;i++) {        pixels[0] = cm[block[0]];        pixels[1] = cm[block[1]];        pixels[2] = cm[block[2]];        pixels[3] = cm[block[3]];        pixels[4] = cm[block[4]];        pixels[5] = cm[block[5]];        pixels[6] = cm[block[6]];        pixels[7] = cm[block[7]];        pixels += line_size;        block += 8;    }}static void add_pixels_clamped_c(const DCTELEM *block, UINT8 *restrict pixels,                          int line_size){    int i;    UINT8 *cm = cropTbl + MAX_NEG_CROP;        /* read the pixels */    for(i=0;i<8;i++) {        pixels[0] = cm[pixels[0] + block[0]];        pixels[1] = cm[pixels[1] + block[1]];        pixels[2] = cm[pixels[2] + block[2]];        pixels[3] = cm[pixels[3] + block[3]];        pixels[4] = cm[pixels[4] + block[4]];        pixels[5] = cm[pixels[5] + block[5]];        pixels[6] = cm[pixels[6] + block[6]];        pixels[7] = cm[pixels[7] + block[7]];        pixels += line_size;        block += 8;    }}#if 0#define PIXOP2(OPNAME, OP) \static void OPNAME ## _pixels(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\    int i;\    for(i=0; i<h; i++){\        OP(*((uint64_t*)block), LD64(pixels));\        pixels+=line_size;\        block +=line_size;\    }\}\\static void OPNAME ## _no_rnd_pixels_x2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\    int i;\    for(i=0; i<h; i++){\        const uint64_t a= LD64(pixels  );\        const uint64_t b= LD64(pixels+1);\        OP(*((uint64_t*)block), (a&b) + (((a^b)&0xFEFEFEFEFEFEFEFEULL)>>1));\        pixels+=line_size;\        block +=line_size;\    }\}\\static void OPNAME ## _pixels_x2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\    int i;\    for(i=0; i<h; i++){\        const uint64_t a= LD64(pixels  );\        const uint64_t b= LD64(pixels+1);\        OP(*((uint64_t*)block), (a|b) - (((a^b)&0xFEFEFEFEFEFEFEFEULL)>>1));\        pixels+=line_size;\        block +=line_size;\    }\}\\static void OPNAME ## _no_rnd_pixels_y2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\    int i;\    for(i=0; i<h; i++){\        const uint64_t a= LD64(pixels          );\        const uint64_t b= LD64(pixels+line_size);\        OP(*((uint64_t*)block), (a&b) + (((a^b)&0xFEFEFEFEFEFEFEFEULL)>>1));\        pixels+=line_size;\        block +=line_size;\    }\}\\static void OPNAME ## _pixels_y2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\    int i;\    for(i=0; i<h; i++){\        const uint64_t a= LD64(pixels          );\        const uint64_t b= LD64(pixels+line_size);\        OP(*((uint64_t*)block), (a|b) - (((a^b)&0xFEFEFEFEFEFEFEFEULL)>>1));\        pixels+=line_size;\        block +=line_size;\    }\}\\static void OPNAME ## _pixels_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\        int i;\        const uint64_t a= LD64(pixels  );\        const uint64_t b= LD64(pixels+1);\        uint64_t l0=  (a&0x0303030303030303ULL)\                    + (b&0x0303030303030303ULL)\                    + 0x0202020202020202ULL;\        uint64_t h0= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\                   + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\        uint64_t l1,h1;\\        pixels+=line_size;\        for(i=0; i<h; i+=2){\            uint64_t a= LD64(pixels  );\            uint64_t b= LD64(pixels+1);\            l1=  (a&0x0303030303030303ULL)\               + (b&0x0303030303030303ULL);\            h1= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\              + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\            OP(*((uint64_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0F0F0F0F0FULL));\            pixels+=line_size;\            block +=line_size;\            a= LD64(pixels  );\            b= LD64(pixels+1);\            l0=  (a&0x0303030303030303ULL)\               + (b&0x0303030303030303ULL)\               + 0x0202020202020202ULL;\            h0= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\              + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\            OP(*((uint64_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0F0F0F0F0FULL));\            pixels+=line_size;\            block +=line_size;\        }\}\\static void OPNAME ## _no_rnd_pixels_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\{\        int i;\        const uint64_t a= LD64(pixels  );\        const uint64_t b= LD64(pixels+1);\        uint64_t l0=  (a&0x0303030303030303ULL)\                    + (b&0x0303030303030303ULL)\                    + 0x0101010101010101ULL;\        uint64_t h0= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\                   + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\        uint64_t l1,h1;\\        pixels+=line_size;\        for(i=0; i<h; i+=2){\            uint64_t a= LD64(pixels  );\            uint64_t b= LD64(pixels+1);\            l1=  (a&0x0303030303030303ULL)\               + (b&0x0303030303030303ULL);\            h1= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\              + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\            OP(*((uint64_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0F0F0F0F0FULL));\            pixels+=line_size;\            block +=line_size;\            a= LD64(pixels  );\            b= LD64(pixels+1);\            l0=  (a&0x0303030303030303ULL)\               + (b&0x0303030303030303ULL)\               + 0x0101010101010101ULL;\            h0= ((a&0xFCFCFCFCFCFCFCFCULL)>>2)\              + ((b&0xFCFCFCFCFCFCFCFCULL)>>2);\            OP(*((uint64_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0F0F0F0F0FULL));\            pixels+=line_size;\            block +=line_size;\        }\}\\CALL_2X_PIXELS(OPNAME ## _pixels16_c    , OPNAME ## _pixels_c    , 8)\CALL_2X_PIXELS(OPNAME ## _pixels16_x2_c , OPNAME ## _pixels_x2_c , 8)\CALL_2X_PIXELS(OPNAME ## _pixels16_y2_c , OPNAME ## _pixels_y2_c , 8)\CALL_2X_PIXELS(OPNAME ## _pixels16_xy2_c, OPNAME ## _pixels_xy2_c, 8)\CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_x2_c , OPNAME ## _no_rnd_pixels_x2_c , 8)\CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_y2_c , OPNAME ## _no_rnd_pixels_y2_c , 8)\CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_xy2_c, OPNAME ## _no_rnd_pixels_xy2_c, 8)#define op_avg(a, b) a = ( ((a)|(b)) - ((((a)^(b))&0xFEFEFEFEFEFEFEFEULL)>>1) )#else // 64 bit variant#define PIXOP2(OPNAME, OP) \static void OPNAME ## _pixels8_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\    int i;\    for(i=0; i<h; i++){\        OP(*((uint32_t*)(block  )), LD32(pixels  ));\        OP(*((uint32_t*)(block+4)), LD32(pixels+4));\        pixels+=line_size;\        block +=line_size;\    }\}\static inline void OPNAME ## _no_rnd_pixels8_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\    OPNAME ## _pixels8_c(block, pixels, line_size, h);\}\

⌨️ 快捷键说明

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