mirror of
https://github.com/RPCS3/ffmpeg-core.git
synced 2026-01-31 01:25:19 +01:00
Contains the following squashed commits from the old branch: Initial commit Fix link order Add option to link against system ffmpeg, disable precompiled binaries for mingw Update macOS files for XCode 12 Update ffmpeg to 5.1.2 Add mjpeg encoder (#7) Add mjpeg2jpeg bitstream filter Add macOS-arm64 builds Add macOS arm64 to CMakeLists Add arm64-osx-release to build.yml dummy commit to trigger workflow Properly split macOS builds in build.yml Try to fix actions uploads Rename the builds Fix build.yml Fix typo in build.yml Amend CMakeLists using the correct check ci: change upload path to directly upload libraries ci: build and use universal binary on macOS ci: set macOS deployment target to macOS 11.0 ci: build FFMPEG prebuilt for each OS/architecture Add linux arm64 prebuilt. Add both x86_64 and arm64 prebuilts for macOS. ci: create release for pre-built FFMPEG cmake: download and use only necessary prebuilt FFMPEG Add arm64 windows prebuilt Co-authored-by: Seungyun Lee <khora.lee.0@gmail.com> Co-authored-by: shinra-electric <50119606+shinra-electric@users.noreply.github.com> Co-authored-by: SaturnSky <ikadro@gmail.com>
119 lines
3.0 KiB
C
Executable File
119 lines
3.0 KiB
C
Executable File
/*
|
|
* This file is part of FFmpeg.
|
|
*
|
|
* FFmpeg 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.1 of the License, or (at your option) any later version.
|
|
*
|
|
* FFmpeg 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 FFmpeg; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef AVCODEC_AVFFT_H
|
|
#define AVCODEC_AVFFT_H
|
|
|
|
/**
|
|
* @file
|
|
* @ingroup lavc_fft
|
|
* FFT functions
|
|
*/
|
|
|
|
/**
|
|
* @defgroup lavc_fft FFT functions
|
|
* @ingroup lavc_misc
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
typedef float FFTSample;
|
|
|
|
typedef struct FFTComplex {
|
|
FFTSample re, im;
|
|
} FFTComplex;
|
|
|
|
typedef struct FFTContext FFTContext;
|
|
|
|
/**
|
|
* Set up a complex FFT.
|
|
* @param nbits log2 of the length of the input array
|
|
* @param inverse if 0 perform the forward transform, if 1 perform the inverse
|
|
*/
|
|
FFTContext *av_fft_init(int nbits, int inverse);
|
|
|
|
/**
|
|
* Do the permutation needed BEFORE calling ff_fft_calc().
|
|
*/
|
|
void av_fft_permute(FFTContext *s, FFTComplex *z);
|
|
|
|
/**
|
|
* Do a complex FFT with the parameters defined in av_fft_init(). The
|
|
* input data must be permuted before. No 1.0/sqrt(n) normalization is done.
|
|
*/
|
|
void av_fft_calc(FFTContext *s, FFTComplex *z);
|
|
|
|
void av_fft_end(FFTContext *s);
|
|
|
|
FFTContext *av_mdct_init(int nbits, int inverse, double scale);
|
|
void av_imdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
|
|
void av_imdct_half(FFTContext *s, FFTSample *output, const FFTSample *input);
|
|
void av_mdct_calc(FFTContext *s, FFTSample *output, const FFTSample *input);
|
|
void av_mdct_end(FFTContext *s);
|
|
|
|
/* Real Discrete Fourier Transform */
|
|
|
|
enum RDFTransformType {
|
|
DFT_R2C,
|
|
IDFT_C2R,
|
|
IDFT_R2C,
|
|
DFT_C2R,
|
|
};
|
|
|
|
typedef struct RDFTContext RDFTContext;
|
|
|
|
/**
|
|
* Set up a real FFT.
|
|
* @param nbits log2 of the length of the input array
|
|
* @param trans the type of transform
|
|
*/
|
|
RDFTContext *av_rdft_init(int nbits, enum RDFTransformType trans);
|
|
void av_rdft_calc(RDFTContext *s, FFTSample *data);
|
|
void av_rdft_end(RDFTContext *s);
|
|
|
|
/* Discrete Cosine Transform */
|
|
|
|
typedef struct DCTContext DCTContext;
|
|
|
|
enum DCTTransformType {
|
|
DCT_II = 0,
|
|
DCT_III,
|
|
DCT_I,
|
|
DST_I,
|
|
};
|
|
|
|
/**
|
|
* Set up DCT.
|
|
*
|
|
* @param nbits size of the input array:
|
|
* (1 << nbits) for DCT-II, DCT-III and DST-I
|
|
* (1 << nbits) + 1 for DCT-I
|
|
* @param type the type of transform
|
|
*
|
|
* @note the first element of the input of DST-I is ignored
|
|
*/
|
|
DCTContext *av_dct_init(int nbits, enum DCTTransformType type);
|
|
void av_dct_calc(DCTContext *s, FFTSample *data);
|
|
void av_dct_end (DCTContext *s);
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#endif /* AVCODEC_AVFFT_H */
|