1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * (I)DCT Transforms 3cabdff1aSopenharmony_ci * Copyright (c) 2009 Peter Ross <pross@xvid.org> 4cabdff1aSopenharmony_ci * Copyright (c) 2010 Alex Converse <alex.converse@gmail.com> 5cabdff1aSopenharmony_ci * Copyright (c) 2010 Vitor Sessak 6cabdff1aSopenharmony_ci * 7cabdff1aSopenharmony_ci * This file is part of FFmpeg. 8cabdff1aSopenharmony_ci * 9cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 10cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 11cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 12cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 13cabdff1aSopenharmony_ci * 14cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 15cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 16cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 17cabdff1aSopenharmony_ci * Lesser General Public License for more details. 18cabdff1aSopenharmony_ci * 19cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 20cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 21cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 22cabdff1aSopenharmony_ci */ 23cabdff1aSopenharmony_ci 24cabdff1aSopenharmony_ci#if !defined(AVCODEC_DCT_H) && (!defined(FFT_FLOAT) || FFT_FLOAT) 25cabdff1aSopenharmony_ci#define AVCODEC_DCT_H 26cabdff1aSopenharmony_ci 27cabdff1aSopenharmony_ci#include <stddef.h> 28cabdff1aSopenharmony_ci#include <stdint.h> 29cabdff1aSopenharmony_ci 30cabdff1aSopenharmony_ci#include "rdft.h" 31cabdff1aSopenharmony_ci 32cabdff1aSopenharmony_cistruct DCTContext { 33cabdff1aSopenharmony_ci int nbits; 34cabdff1aSopenharmony_ci int inverse; 35cabdff1aSopenharmony_ci RDFTContext rdft; 36cabdff1aSopenharmony_ci const float *costab; 37cabdff1aSopenharmony_ci FFTSample *csc2; 38cabdff1aSopenharmony_ci void (*dct_calc)(struct DCTContext *s, FFTSample *data); 39cabdff1aSopenharmony_ci void (*dct32)(FFTSample *out, const FFTSample *in); 40cabdff1aSopenharmony_ci}; 41cabdff1aSopenharmony_ci 42cabdff1aSopenharmony_ci/** 43cabdff1aSopenharmony_ci * Set up DCT. 44cabdff1aSopenharmony_ci * @param nbits size of the input array: 45cabdff1aSopenharmony_ci * (1 << nbits) for DCT-II, DCT-III and DST-I 46cabdff1aSopenharmony_ci * (1 << nbits) + 1 for DCT-I 47cabdff1aSopenharmony_ci * 48cabdff1aSopenharmony_ci * @note the first element of the input of DST-I is ignored 49cabdff1aSopenharmony_ci */ 50cabdff1aSopenharmony_ciint ff_dct_init(DCTContext *s, int nbits, enum DCTTransformType type); 51cabdff1aSopenharmony_civoid ff_dct_end (DCTContext *s); 52cabdff1aSopenharmony_ci 53cabdff1aSopenharmony_civoid ff_dct_init_x86(DCTContext *s); 54cabdff1aSopenharmony_ci 55cabdff1aSopenharmony_civoid ff_fdct_ifast(int16_t *data); 56cabdff1aSopenharmony_civoid ff_fdct_ifast248(int16_t *data); 57cabdff1aSopenharmony_civoid ff_jpeg_fdct_islow_8(int16_t *data); 58cabdff1aSopenharmony_civoid ff_jpeg_fdct_islow_10(int16_t *data); 59cabdff1aSopenharmony_civoid ff_fdct248_islow_8(int16_t *data); 60cabdff1aSopenharmony_civoid ff_fdct248_islow_10(int16_t *data); 61cabdff1aSopenharmony_ci 62cabdff1aSopenharmony_civoid ff_j_rev_dct(int16_t *data); 63cabdff1aSopenharmony_civoid ff_j_rev_dct4(int16_t *data); 64cabdff1aSopenharmony_civoid ff_j_rev_dct2(int16_t *data); 65cabdff1aSopenharmony_civoid ff_j_rev_dct1(int16_t *data); 66cabdff1aSopenharmony_civoid ff_jref_idct_put(uint8_t *dest, ptrdiff_t line_size, int16_t *block); 67cabdff1aSopenharmony_civoid ff_jref_idct_add(uint8_t *dest, ptrdiff_t line_size, int16_t *block); 68cabdff1aSopenharmony_ci 69cabdff1aSopenharmony_ci#endif /* AVCODEC_DCT_H */ 70