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

📄 dsputil.c

📁 FFmpeg is an audio/video conversion tool. It includes libavcodec, the leading open source codec libr
💻 C
📖 第 1 页 / 共 5 页
字号:
static inline void put_tpel_pixels_mc01_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (683*(2*src[j] + src[j+stride] + 1)) >> 11;      }      src += stride;      dst += stride;    }}    static inline void put_tpel_pixels_mc11_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (2731*(4*src[j] + 3*src[j+1] + 3*src[j+stride] + 2*src[j+stride+1] + 6)) >> 15;      }      src += stride;      dst += stride;    }}static inline void put_tpel_pixels_mc12_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (2731*(3*src[j] + 2*src[j+1] + 4*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15;      }      src += stride;      dst += stride;    }}static inline void put_tpel_pixels_mc02_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (683*(src[j] + 2*src[j+stride] + 1)) >> 11;      }      src += stride;      dst += stride;    }}static inline void put_tpel_pixels_mc21_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (2731*(3*src[j] + 4*src[j+1] + 2*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15;      }      src += stride;      dst += stride;    }}static inline void put_tpel_pixels_mc22_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (2731*(2*src[j] + 3*src[j+1] + 3*src[j+stride] + 4*src[j+stride+1] + 6)) >> 15;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc00_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    switch(width){    case 2: avg_pixels2_c (dst, src, stride, height); break;    case 4: avg_pixels4_c (dst, src, stride, height); break;    case 8: avg_pixels8_c (dst, src, stride, height); break;    case 16:avg_pixels16_c(dst, src, stride, height); break;    }}static inline void avg_tpel_pixels_mc10_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((683*(2*src[j] + src[j+1] + 1)) >> 11) + 1) >> 1;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc20_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((683*(src[j] + 2*src[j+1] + 1)) >> 11) + 1) >> 1;      }      src += stride;      dst += stride;    }}    static inline void avg_tpel_pixels_mc01_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((683*(2*src[j] + src[j+stride] + 1)) >> 11) + 1) >> 1;      }      src += stride;      dst += stride;    }}    static inline void avg_tpel_pixels_mc11_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((2731*(4*src[j] + 3*src[j+1] + 3*src[j+stride] + 2*src[j+stride+1] + 6)) >> 15) + 1) >> 1;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc12_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((2731*(3*src[j] + 2*src[j+1] + 4*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15) + 1) >> 1;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc02_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((683*(src[j] + 2*src[j+stride] + 1)) >> 11) + 1) >> 1;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc21_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((2731*(3*src[j] + 4*src[j+1] + 2*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15) + 1) >> 1;      }      src += stride;      dst += stride;    }}static inline void avg_tpel_pixels_mc22_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){    int i,j;    for (i=0; i < height; i++) {      for (j=0; j < width; j++) {	dst[j] = (dst[j] + ((2731*(2*src[j] + 3*src[j+1] + 3*src[j+stride] + 4*src[j+stride+1] + 6)) >> 15) + 1) >> 1;      }      src += stride;      dst += stride;    }}#if 0#define TPEL_WIDTH(width)\static void put_tpel_pixels ## width ## _mc00_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc00_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc10_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc10_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc20_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc20_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc01_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc01_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc11_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc11_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc21_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc21_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc02_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc02_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc12_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc12_c(dst, src, stride, width, height);}\static void put_tpel_pixels ## width ## _mc22_c(uint8_t *dst, const uint8_t *src, int stride, int height){\    void put_tpel_pixels_mc22_c(dst, src, stride, width, height);}#endif#define H264_CHROMA_MC(OPNAME, OP)\static void OPNAME ## h264_chroma_mc2_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\    const int A=(8-x)*(8-y);\    const int B=(  x)*(8-y);\    const int C=(8-x)*(  y);\    const int D=(  x)*(  y);\    int i;\    \    assert(x<8 && y<8 && x>=0 && y>=0);\\    for(i=0; i<h; i++)\    {\        OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\        OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\        dst+= stride;\        src+= stride;\    }\}\\static void OPNAME ## h264_chroma_mc4_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\    const int A=(8-x)*(8-y);\    const int B=(  x)*(8-y);\    const int C=(8-x)*(  y);\    const int D=(  x)*(  y);\    int i;\    \    assert(x<8 && y<8 && x>=0 && y>=0);\\    for(i=0; i<h; i++)\    {\        OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\        OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\        OP(dst[2], (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3]));\        OP(dst[3], (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4]));\        dst+= stride;\        src+= stride;\    }\}\\static void OPNAME ## h264_chroma_mc8_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\    const int A=(8-x)*(8-y);\    const int B=(  x)*(8-y);\    const int C=(8-x)*(  y);\    const int D=(  x)*(  y);\    int i;\    \    assert(x<8 && y<8 && x>=0 && y>=0);\\    for(i=0; i<h; i++)\    {\        OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\        OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\        OP(dst[2], (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3]));\        OP(dst[3], (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4]));\        OP(dst[4], (A*src[4] + B*src[5] + C*src[stride+4] + D*src[stride+5]));\        OP(dst[5], (A*src[5] + B*src[6] + C*src[stride+5] + D*src[stride+6]));\        OP(dst[6], (A*src[6] + B*src[7] + C*src[stride+6] + D*src[stride+7]));\        OP(dst[7], (A*src[7] + B*src[8] + C*src[stride+7] + D*src[stride+8]));\        dst+= stride;\        src+= stride;\    }\}#define op_avg(a, b) a = (((a)+(((b) + 32)>>6)+1)>>1)#define op_put(a, b) a = (((b) + 32)>>6)H264_CHROMA_MC(put_       , op_put)H264_CHROMA_MC(avg_       , op_avg)#undef op_avg#undef op_putstatic inline void copy_block4(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){    int i;    for(i=0; i<h; i++)    {        ST32(dst   , LD32(src   ));        dst+=dstStride;        src+=srcStride;    }}static inline void copy_block8(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){    int i;    for(i=0; i<h; i++)    {        ST32(dst   , LD32(src   ));        ST32(dst+4 , LD32(src+4 ));        dst+=dstStride;        src+=srcStride;    }}static inline void copy_block16(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){    int i;    for(i=0; i<h; i++)    {        ST32(dst   , LD32(src   ));        ST32(dst+4 , LD32(src+4 ));        ST32(dst+8 , LD32(src+8 ));        ST32(dst+12, LD32(src+12));        dst+=dstStride;        src+=srcStride;    }}static inline void copy_block17(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){    int i;    for(i=0; i<h; i++)    {        ST32(dst   , LD32(src   ));        ST32(dst+4 , LD32(src+4 ));        ST32(dst+8 , LD32(src+8 ));        ST32(dst+12, LD32(src+12));        dst[16]= src[16];        dst+=dstStride;        src+=srcStride;    }}static inline void copy_block9(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){    int i;    for(i=0; i<h; i++)    {        ST32(dst   , LD32(src   ));        ST32(dst+4 , LD32(src+4 ));        dst[8]= src[8];        dst+=dstStride;        src+=srcStride;    }}#define QPEL_MC(r, OPNAME, RND, OP) \static void OPNAME ## mpeg4_qpel8_h_lowpass(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){\    uint8_t *cm = cropTbl + MAX_NEG_CROP;\    int i;\    for(i=0; i<h; i++)\    {\        OP(dst[0], (src[0]+src[1])*20 - (src[0]+src[2])*6 + (src[1]+src[3])*3 - (src[2]+src[4]));\        OP(dst[1], (src[1]+src[2])*20 - (src[0]+src[3])*6 + (src[0]+src[4])*3 - (src[1]+src[5]));\        OP(dst[2], (src[2]+src[3])*20 - (src[1]+src[4])*6 + (src[0]+src[5])*3 - (src[0]+src[6]));\        OP(dst[3], (src[3]+src[4])*20 - (src[2]+src[5])*6 + (src[1]+src[6])*3 - (src[0]+src[7]));\        OP(dst[4], (src[4]+src[5])*20 - (src[3]+src[6])*6 + (src[2]+src[7])*3 - (src[1]+src[8]));\        OP(dst[5], (src[5]+src[6])*20 - (src[4]+src[7])*6 + (src[3]+src[8])*3 - (src[2]+src[8]));\        OP(dst[6], (src[6]+src[7])*20 - (src[5]+src[8])*6 + (src[4]+src[8])*3 - (src[3]+src[7]));\        OP(dst[7], (src[7]+src[8])*20 - (src[6]+src[8])*6 + (src[5]+src[7])*3 - (src[4]+src[6]));\        dst+=dstStride;\        src+=srcStride;\    }\}\

⌨️ 快捷键说明

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