123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- /*
- * 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 AVUTIL_FILM_GRAIN_PARAMS_H
- #define AVUTIL_FILM_GRAIN_PARAMS_H
- #include "frame.h"
- enum AVFilmGrainParamsType {
- AV_FILM_GRAIN_PARAMS_NONE = 0,
- /**
- * The union is valid when interpreted as AVFilmGrainAOMParams (codec.aom)
- */
- AV_FILM_GRAIN_PARAMS_AV1,
- };
- /**
- * This structure describes how to handle film grain synthesis for AOM codecs.
- *
- * @note The struct must be allocated as part of AVFilmGrainParams using
- * av_film_grain_params_alloc(). Its size is not a part of the public ABI.
- */
- typedef struct AVFilmGrainAOMParams {
- /**
- * Number of points, and the scale and value for each point of the
- * piecewise linear scaling function for the uma plane.
- */
- int num_y_points;
- uint8_t y_points[14][2 /* value, scaling */];
- /**
- * Signals whether to derive the chroma scaling function from the luma.
- * Not equivalent to copying the luma values and scales.
- */
- int chroma_scaling_from_luma;
- /**
- * If chroma_scaling_from_luma is set to 0, signals the chroma scaling
- * function parameters.
- */
- int num_uv_points[2 /* cb, cr */];
- uint8_t uv_points[2 /* cb, cr */][10][2 /* value, scaling */];
- /**
- * Specifies the shift applied to the chroma components. For AV1, its within
- * [8; 11] and determines the range and quantization of the film grain.
- */
- int scaling_shift;
- /**
- * Specifies the auto-regression lag.
- */
- int ar_coeff_lag;
- /**
- * Luma auto-regression coefficients. The number of coefficients is given by
- * 2 * ar_coeff_lag * (ar_coeff_lag + 1).
- */
- int8_t ar_coeffs_y[24];
- /**
- * Chroma auto-regression coefficients. The number of coefficients is given by
- * 2 * ar_coeff_lag * (ar_coeff_lag + 1) + !!num_y_points.
- */
- int8_t ar_coeffs_uv[2 /* cb, cr */][25];
- /**
- * Specifies the range of the auto-regressive coefficients. Values of 6,
- * 7, 8 and so on represent a range of [-2, 2), [-1, 1), [-0.5, 0.5) and
- * so on. For AV1 must be between 6 and 9.
- */
- int ar_coeff_shift;
- /**
- * Signals the down shift applied to the generated gaussian numbers during
- * synthesis.
- */
- int grain_scale_shift;
- /**
- * Specifies the luma/chroma multipliers for the index to the component
- * scaling function.
- */
- int uv_mult[2 /* cb, cr */];
- int uv_mult_luma[2 /* cb, cr */];
- /**
- * Offset used for component scaling function. For AV1 its a 9-bit value
- * with a range [-256, 255]
- */
- int uv_offset[2 /* cb, cr */];
- /**
- * Signals whether to overlap film grain blocks.
- */
- int overlap_flag;
- /**
- * Signals to clip to limited color levels after film grain application.
- */
- int limit_output_range;
- } AVFilmGrainAOMParams;
- /**
- * This structure describes how to handle film grain synthesis in video
- * for specific codecs. Must be present on every frame where film grain is
- * meant to be synthesised for correct presentation.
- *
- * @note The struct must be allocated with av_film_grain_params_alloc() and
- * its size is not a part of the public ABI.
- */
- typedef struct AVFilmGrainParams {
- /**
- * Specifies the codec for which this structure is valid.
- */
- enum AVFilmGrainParamsType type;
- /**
- * Seed to use for the synthesis process, if the codec allows for it.
- */
- uint64_t seed;
- /**
- * Additional fields may be added both here and in any structure included.
- * If a codec's film grain structure differs slightly over another
- * codec's, fields within may change meaning depending on the type.
- */
- union {
- AVFilmGrainAOMParams aom;
- } codec;
- } AVFilmGrainParams;
- /**
- * Allocate an AVFilmGrainParams structure and set its fields to
- * default values. The resulting struct can be freed using av_freep().
- * If size is not NULL it will be set to the number of bytes allocated.
- *
- * @return An AVFilmGrainParams filled with default values or NULL
- * on failure.
- */
- AVFilmGrainParams *av_film_grain_params_alloc(size_t *size);
- /**
- * Allocate a complete AVFilmGrainParams and add it to the frame.
- *
- * @param frame The frame which side data is added to.
- *
- * @return The AVFilmGrainParams structure to be filled by caller.
- */
- AVFilmGrainParams *av_film_grain_params_create_side_data(AVFrame *frame);
- #endif /* AVUTIL_FILM_GRAIN_PARAMS_H */
|