2
* H.264/MPEG-4 Part 10 (Base profile) encoder.
6
* Copyright (c) 2006 Expertisecentrum Digitale Media, UHasselt
8
* FFmpeg is free software; you can redistribute it and/or
9
* modify it under the terms of the GNU Lesser General Public
10
* License as published by the Free Software Foundation; either
11
* version 2.1 of the License, or (at your option) any later version.
13
* FFmpeg is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
* Lesser General Public License for more details.
18
* You should have received a copy of the GNU Lesser General Public
19
* License along with FFmpeg; if not, write to the Free Software
20
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
25
* H.264 encoder related DSP utils
31
extern const uint8_t ff_div6[52];
32
extern const uint8_t ff_rem6[52];
34
#define H264_DCT_PART1(X) \
35
a = block[0][X]+block[3][X]; \
36
c = block[0][X]-block[3][X]; \
37
b = block[1][X]+block[2][X]; \
38
d = block[1][X]-block[2][X]; \
41
pieces[1][X] = (c<<1)+d; \
42
pieces[3][X] = c-(d<<1);
44
#define H264_DCT_PART2(X) \
45
a = pieces[X][0]+pieces[X][3]; \
46
c = pieces[X][0]-pieces[X][3]; \
47
b = pieces[X][1]+pieces[X][2]; \
48
d = pieces[X][1]-pieces[X][2]; \
51
block[1][X] = (c<<1)+d; \
52
block[3][X] = c-(d<<1);
55
* Transform the provided matrix using the H.264 modified DCT.
57
* we'll always work with transposed input blocks, to avoid having to make a
58
* distinction between C and mmx implementations.
60
* @param block transposed input block
62
static void h264_dct_c(DCTELEM block[4][4])
77
void ff_h264dspenc_init(DSPContext* c, AVCodecContext *avctx)
79
c->h264_dct = h264_dct_c;