mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
cf37c3fb6c
From SMPTE RDD 5-2006, the grain seed is to be computed from the following definition of `pic_offset`: > When decoding H.264 | MPEG-4 AVC bitstreams, pic_offset is defined as > follows: > - pic_offset = PicOrderCnt(CurrPic) + (PicOrderCnt_offset << 5) > where: > - PicOrderCnt(CurrPic) is the picture order count of the current frame, > which shall be derived from [the video stream]. > > - PicOrderCnt_offset is set to idr_pic_id on IDR frames. idr_pic_id > shall be read from the slice header of [the video stream]. On non-IDR I > frames, PicOrderCnt_offset is set to 0. A frame shall be classified as I > frame when all its slices are I slices, which may be optionally > designated by setting primary_pic_type to 0 in the access delimiter NAL > unit. Otherwise, PicOrderCnt_offset it not changed. PicOrderCnt_offset is > updated in decoding order. Co-authored-by: James Almer <jamrial@gmail.com> Signed-off-by: Niklas Haas <git@haasn.dev> Signed-off-by: James Almer <jamrial@gmail.com>
261 lines
8.3 KiB
C
261 lines
8.3 KiB
C
/*
|
|
* 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,
|
|
|
|
/**
|
|
* The union is valid when interpreted as AVFilmGrainH274Params (codec.h274)
|
|
*/
|
|
AV_FILM_GRAIN_PARAMS_H274,
|
|
};
|
|
|
|
/**
|
|
* 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 for codecs using
|
|
* the ITU-T H.274 Versatile suplemental enhancement information message.
|
|
*
|
|
* @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 AVFilmGrainH274Params {
|
|
/**
|
|
* Specifies the film grain simulation mode.
|
|
* 0 = Frequency filtering, 1 = Auto-regression
|
|
*/
|
|
int model_id;
|
|
|
|
/**
|
|
* Specifies the bit depth used for the luma component.
|
|
*/
|
|
int bit_depth_luma;
|
|
|
|
/**
|
|
* Specifies the bit depth used for the chroma components.
|
|
*/
|
|
int bit_depth_chroma;
|
|
|
|
enum AVColorRange color_range;
|
|
enum AVColorPrimaries color_primaries;
|
|
enum AVColorTransferCharacteristic color_trc;
|
|
enum AVColorSpace color_space;
|
|
|
|
/**
|
|
* Specifies the blending mode used to blend the simulated film grain
|
|
* with the decoded images.
|
|
*
|
|
* 0 = Additive, 1 = Multiplicative
|
|
*/
|
|
int blending_mode_id;
|
|
|
|
/**
|
|
* Specifies a scale factor used in the film grain characterization equations.
|
|
*/
|
|
int log2_scale_factor;
|
|
|
|
/**
|
|
* Indicates if the modelling of film grain for a given component is present.
|
|
*/
|
|
int component_model_present[3 /* y, cb, cr */];
|
|
|
|
/**
|
|
* Specifies the number of intensity intervals for which a specific set of
|
|
* model values has been estimated, with a range of [1, 256].
|
|
*/
|
|
uint16_t num_intensity_intervals[3 /* y, cb, cr */];
|
|
|
|
/**
|
|
* Specifies the number of model values present for each intensity interval
|
|
* in which the film grain has been modelled, with a range of [1, 6].
|
|
*/
|
|
uint8_t num_model_values[3 /* y, cb, cr */];
|
|
|
|
/**
|
|
* Specifies the lower ounds of each intensity interval for whichthe set of
|
|
* model values applies for the component.
|
|
*/
|
|
uint8_t intensity_interval_lower_bound[3 /* y, cb, cr */][256 /* intensity interval */];
|
|
|
|
/**
|
|
* Specifies the upper bound of each intensity interval for which the set of
|
|
* model values applies for the component.
|
|
*/
|
|
uint8_t intensity_interval_upper_bound[3 /* y, cb, cr */][256 /* intensity interval */];
|
|
|
|
/**
|
|
* Specifies the model values for the component for each intensity interval.
|
|
* - When model_id == 0, the following applies:
|
|
* For comp_model_value[y], the range of values is [0, 2^bit_depth_luma - 1]
|
|
* For comp_model_value[cb..cr], the range of values is [0, 2^bit_depth_chroma - 1]
|
|
* - Otherwise, the following applies:
|
|
* For comp_model_value[y], the range of values is [-2^(bit_depth_luma - 1), 2^(bit_depth_luma - 1) - 1]
|
|
* For comp_model_value[cb..cr], the range of values is [-2^(bit_depth_chroma - 1), 2^(bit_depth_chroma - 1) - 1]
|
|
*/
|
|
int16_t comp_model_value[3 /* y, cb, cr */][256 /* intensity interval */][6 /* model value */];
|
|
} AVFilmGrainH274Params;
|
|
|
|
/**
|
|
* 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.
|
|
*
|
|
* @note For H.264, this refers to `pic_offset` as defined in
|
|
* SMPTE RDD 5-2006.
|
|
*/
|
|
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;
|
|
AVFilmGrainH274Params h274;
|
|
} 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 */
|