All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.mediaconvert.model.Av1Settings Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Elemental MediaConvert module holds the client classes that are used for communicating with AWS Elemental MediaConvert Service

There is a newer version: 1.12.778
Show newest version
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.mediaconvert.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * Required when you set Codec, under VideoDescription>CodecSettings to the value AV1.
 * 
 * @see AWS API
 *      Documentation
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class Av1Settings implements Serializable, Cloneable, StructuredPojo {

    /**
     * Specify the strength of any adaptive quantization filters that you enable. The value that you choose here applies
     * to Spatial adaptive quantization.
     */
    private String adaptiveQuantization;
    /** Specify the Bit depth. You can choose 8-bit or 10-bit. */
    private String bitDepth;
    /**
     * Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film grain.
     * We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or 8 outputs.
     * For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled. When you include
     * Film grain synthesis, you cannot include the Noise reducer preprocessor.
     */
    private String filmGrainSynthesis;
    /**
     * Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame rate as
     * the input video, choose Follow source. If you want to do frame rate conversion, choose a frame rate from the
     * dropdown list or choose Custom. The framerates shown in the dropdown list are decimal approximations of fractions.
     * If you choose Custom, specify your frame rate as a fraction.
     */
    private String framerateControl;
    /**
     * Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For numerically
     * simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value, Drop duplicate. For
     * numerically complex conversions, to avoid stutter: Choose Interpolate. This results in a smooth picture, but might
     * introduce undesirable video artifacts. For complex frame rate conversions, especially if your source video has
     * already been converted from its original cadence: Choose FrameFormer to do motion-compensated interpolation.
     * FrameFormer uses the best conversion method frame by frame. Note that using FrameFormer increases the transcoding
     * time and incurs a significant add-on cost. When you choose FrameFormer, your input video resolution must be at
     * least 128x96.
     */
    private String framerateConversionAlgorithm;
    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of this fraction. In this
     * example, use 1001 for the value of FramerateDenominator. When you use the console for transcode jobs that use
     * frame rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     */
    private Integer framerateDenominator;
    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this fraction. In this
     * example, use 24000 for the value of FramerateNumerator. When you use the console for transcode jobs that use frame
     * rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     */
    private Integer framerateNumerator;
    /**
     * Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     * seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where x is
     * an integer value.
     */
    private Double gopSize;
    /**
     * Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     * control mode is QVBR.
     */
    private Integer maxBitrate;
    /**
     * Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15. Choose a
     * larger number for a lower bitrate and smaller file size; choose a smaller number for better video quality.
     */
    private Integer numberBFramesBetweenReferenceFrames;
    /**
     * Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when you set
     * QVBR for Rate control mode.
     */
    private Av1QvbrSettings qvbrSettings;
    /**
     * 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate (QVBR). You
     * can''t use CBR or VBR.'
     */
    private String rateControlMode;
    /**
     * Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive pictures,
     * this value must be less than or equal to the number of macroblock rows. For interlaced pictures, this value must
     * be less than or equal to half the number of macroblock rows.
     */
    private Integer slices;
    /**
     * Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of content
     * complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain more distortion
     * with no noticeable visual degradation and uses more bits on areas where any small distortion will be noticeable.
     * For example, complex textured blocks are encoded with fewer bits and smooth textured blocks are encoded with more
     * bits. Enabling this feature will almost always improve your video quality. Note, though, that this feature doesn't
     * take into account where the viewer's attention is likely to be. If viewers are likely to be focusing their
     * attention on a part of the screen with a lot of complex texture, you might choose to disable this feature. Related
     * setting: When you enable spatial adaptive quantization, set the value for Adaptive quantization depending on your
     * content. For homogeneous content, such as cartoons and video games, set it to Low. For content with a wider
     * variety of textures, set it to High or Higher.
     */
    private String spatialAdaptiveQuantization;

    /**
     * Specify the strength of any adaptive quantization filters that you enable. The value that you choose here applies
     * to Spatial adaptive quantization.
     * 
     * @param adaptiveQuantization
     *        Specify the strength of any adaptive quantization filters that you enable. The value that you choose here
     *        applies to Spatial adaptive quantization.
     * @see Av1AdaptiveQuantization
     */

    public void setAdaptiveQuantization(String adaptiveQuantization) {
        this.adaptiveQuantization = adaptiveQuantization;
    }

    /**
     * Specify the strength of any adaptive quantization filters that you enable. The value that you choose here applies
     * to Spatial adaptive quantization.
     * 
     * @return Specify the strength of any adaptive quantization filters that you enable. The value that you choose here
     *         applies to Spatial adaptive quantization.
     * @see Av1AdaptiveQuantization
     */

    public String getAdaptiveQuantization() {
        return this.adaptiveQuantization;
    }

    /**
     * Specify the strength of any adaptive quantization filters that you enable. The value that you choose here applies
     * to Spatial adaptive quantization.
     * 
     * @param adaptiveQuantization
     *        Specify the strength of any adaptive quantization filters that you enable. The value that you choose here
     *        applies to Spatial adaptive quantization.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1AdaptiveQuantization
     */

    public Av1Settings withAdaptiveQuantization(String adaptiveQuantization) {
        setAdaptiveQuantization(adaptiveQuantization);
        return this;
    }

    /**
     * Specify the strength of any adaptive quantization filters that you enable. The value that you choose here applies
     * to Spatial adaptive quantization.
     * 
     * @param adaptiveQuantization
     *        Specify the strength of any adaptive quantization filters that you enable. The value that you choose here
     *        applies to Spatial adaptive quantization.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1AdaptiveQuantization
     */

    public Av1Settings withAdaptiveQuantization(Av1AdaptiveQuantization adaptiveQuantization) {
        this.adaptiveQuantization = adaptiveQuantization.toString();
        return this;
    }

    /**
     * Specify the Bit depth. You can choose 8-bit or 10-bit.
     * 
     * @param bitDepth
     *        Specify the Bit depth. You can choose 8-bit or 10-bit.
     * @see Av1BitDepth
     */

    public void setBitDepth(String bitDepth) {
        this.bitDepth = bitDepth;
    }

    /**
     * Specify the Bit depth. You can choose 8-bit or 10-bit.
     * 
     * @return Specify the Bit depth. You can choose 8-bit or 10-bit.
     * @see Av1BitDepth
     */

    public String getBitDepth() {
        return this.bitDepth;
    }

    /**
     * Specify the Bit depth. You can choose 8-bit or 10-bit.
     * 
     * @param bitDepth
     *        Specify the Bit depth. You can choose 8-bit or 10-bit.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1BitDepth
     */

    public Av1Settings withBitDepth(String bitDepth) {
        setBitDepth(bitDepth);
        return this;
    }

    /**
     * Specify the Bit depth. You can choose 8-bit or 10-bit.
     * 
     * @param bitDepth
     *        Specify the Bit depth. You can choose 8-bit or 10-bit.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1BitDepth
     */

    public Av1Settings withBitDepth(Av1BitDepth bitDepth) {
        this.bitDepth = bitDepth.toString();
        return this;
    }

    /**
     * Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film grain.
     * We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or 8 outputs.
     * For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled. When you include
     * Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * 
     * @param filmGrainSynthesis
     *        Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film
     *        grain. We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or
     *        8 outputs. For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled.
     *        When you include Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * @see Av1FilmGrainSynthesis
     */

    public void setFilmGrainSynthesis(String filmGrainSynthesis) {
        this.filmGrainSynthesis = filmGrainSynthesis;
    }

    /**
     * Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film grain.
     * We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or 8 outputs.
     * For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled. When you include
     * Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * 
     * @return Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1
     *         film grain. We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6,
     *         7, or 8 outputs. For QVBR quality level 9 or 10 outputs we recommend that you keep the default value,
     *         Disabled. When you include Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * @see Av1FilmGrainSynthesis
     */

    public String getFilmGrainSynthesis() {
        return this.filmGrainSynthesis;
    }

    /**
     * Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film grain.
     * We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or 8 outputs.
     * For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled. When you include
     * Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * 
     * @param filmGrainSynthesis
     *        Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film
     *        grain. We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or
     *        8 outputs. For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled.
     *        When you include Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FilmGrainSynthesis
     */

    public Av1Settings withFilmGrainSynthesis(String filmGrainSynthesis) {
        setFilmGrainSynthesis(filmGrainSynthesis);
        return this;
    }

    /**
     * Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film grain.
     * We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or 8 outputs.
     * For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled. When you include
     * Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * 
     * @param filmGrainSynthesis
     *        Film grain synthesis replaces film grain present in your content with similar quality synthesized AV1 film
     *        grain. We recommend that you choose Enabled to reduce the bandwidth of your QVBR quality level 5, 6, 7, or
     *        8 outputs. For QVBR quality level 9 or 10 outputs we recommend that you keep the default value, Disabled.
     *        When you include Film grain synthesis, you cannot include the Noise reducer preprocessor.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FilmGrainSynthesis
     */

    public Av1Settings withFilmGrainSynthesis(Av1FilmGrainSynthesis filmGrainSynthesis) {
        this.filmGrainSynthesis = filmGrainSynthesis.toString();
        return this;
    }

    /**
     * Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame rate as
     * the input video, choose Follow source. If you want to do frame rate conversion, choose a frame rate from the
     * dropdown list or choose Custom. The framerates shown in the dropdown list are decimal approximations of fractions.
     * If you choose Custom, specify your frame rate as a fraction.
     * 
     * @param framerateControl
     *        Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame
     *        rate as the input video, choose Follow source. If you want to do frame rate conversion, choose a frame
     *        rate from the dropdown list or choose Custom. The framerates shown in the dropdown list are decimal
     *        approximations of fractions. If you choose Custom, specify your frame rate as a fraction.
     * @see Av1FramerateControl
     */

    public void setFramerateControl(String framerateControl) {
        this.framerateControl = framerateControl;
    }

    /**
     * Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame rate as
     * the input video, choose Follow source. If you want to do frame rate conversion, choose a frame rate from the
     * dropdown list or choose Custom. The framerates shown in the dropdown list are decimal approximations of fractions.
     * If you choose Custom, specify your frame rate as a fraction.
     * 
     * @return Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame
     *         rate as the input video, choose Follow source. If you want to do frame rate conversion, choose a frame
     *         rate from the dropdown list or choose Custom. The framerates shown in the dropdown list are decimal
     *         approximations of fractions. If you choose Custom, specify your frame rate as a fraction.
     * @see Av1FramerateControl
     */

    public String getFramerateControl() {
        return this.framerateControl;
    }

    /**
     * Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame rate as
     * the input video, choose Follow source. If you want to do frame rate conversion, choose a frame rate from the
     * dropdown list or choose Custom. The framerates shown in the dropdown list are decimal approximations of fractions.
     * If you choose Custom, specify your frame rate as a fraction.
     * 
     * @param framerateControl
     *        Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame
     *        rate as the input video, choose Follow source. If you want to do frame rate conversion, choose a frame
     *        rate from the dropdown list or choose Custom. The framerates shown in the dropdown list are decimal
     *        approximations of fractions. If you choose Custom, specify your frame rate as a fraction.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FramerateControl
     */

    public Av1Settings withFramerateControl(String framerateControl) {
        setFramerateControl(framerateControl);
        return this;
    }

    /**
     * Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame rate as
     * the input video, choose Follow source. If you want to do frame rate conversion, choose a frame rate from the
     * dropdown list or choose Custom. The framerates shown in the dropdown list are decimal approximations of fractions.
     * If you choose Custom, specify your frame rate as a fraction.
     * 
     * @param framerateControl
     *        Use the Framerate setting to specify the frame rate for this output. If you want to keep the same frame
     *        rate as the input video, choose Follow source. If you want to do frame rate conversion, choose a frame
     *        rate from the dropdown list or choose Custom. The framerates shown in the dropdown list are decimal
     *        approximations of fractions. If you choose Custom, specify your frame rate as a fraction.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FramerateControl
     */

    public Av1Settings withFramerateControl(Av1FramerateControl framerateControl) {
        this.framerateControl = framerateControl.toString();
        return this;
    }

    /**
     * Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For numerically
     * simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value, Drop duplicate. For
     * numerically complex conversions, to avoid stutter: Choose Interpolate. This results in a smooth picture, but might
     * introduce undesirable video artifacts. For complex frame rate conversions, especially if your source video has
     * already been converted from its original cadence: Choose FrameFormer to do motion-compensated interpolation.
     * FrameFormer uses the best conversion method frame by frame. Note that using FrameFormer increases the transcoding
     * time and incurs a significant add-on cost. When you choose FrameFormer, your input video resolution must be at
     * least 128x96.
     * 
     * @param framerateConversionAlgorithm
     *        Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For
     *        numerically simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value,
     *        Drop duplicate. For numerically complex conversions, to avoid stutter: Choose Interpolate. This results in
     *        a smooth picture, but might introduce undesirable video artifacts. For complex frame rate conversions,
     *        especially if your source video has already been converted from its original cadence: Choose FrameFormer
     *        to do motion-compensated interpolation. FrameFormer uses the best conversion method frame by frame. Note
     *        that using FrameFormer increases the transcoding time and incurs a significant add-on cost. When you
     *        choose FrameFormer, your input video resolution must be at least 128x96.
     * @see Av1FramerateConversionAlgorithm
     */

    public void setFramerateConversionAlgorithm(String framerateConversionAlgorithm) {
        this.framerateConversionAlgorithm = framerateConversionAlgorithm;
    }

    /**
     * Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For numerically
     * simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value, Drop duplicate. For
     * numerically complex conversions, to avoid stutter: Choose Interpolate. This results in a smooth picture, but might
     * introduce undesirable video artifacts. For complex frame rate conversions, especially if your source video has
     * already been converted from its original cadence: Choose FrameFormer to do motion-compensated interpolation.
     * FrameFormer uses the best conversion method frame by frame. Note that using FrameFormer increases the transcoding
     * time and incurs a significant add-on cost. When you choose FrameFormer, your input video resolution must be at
     * least 128x96.
     * 
     * @return Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For
     *         numerically simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value,
     *         Drop duplicate. For numerically complex conversions, to avoid stutter: Choose Interpolate. This results
     *         in a smooth picture, but might introduce undesirable video artifacts. For complex frame rate conversions,
     *         especially if your source video has already been converted from its original cadence: Choose FrameFormer
     *         to do motion-compensated interpolation. FrameFormer uses the best conversion method frame by frame. Note
     *         that using FrameFormer increases the transcoding time and incurs a significant add-on cost. When you
     *         choose FrameFormer, your input video resolution must be at least 128x96.
     * @see Av1FramerateConversionAlgorithm
     */

    public String getFramerateConversionAlgorithm() {
        return this.framerateConversionAlgorithm;
    }

    /**
     * Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For numerically
     * simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value, Drop duplicate. For
     * numerically complex conversions, to avoid stutter: Choose Interpolate. This results in a smooth picture, but might
     * introduce undesirable video artifacts. For complex frame rate conversions, especially if your source video has
     * already been converted from its original cadence: Choose FrameFormer to do motion-compensated interpolation.
     * FrameFormer uses the best conversion method frame by frame. Note that using FrameFormer increases the transcoding
     * time and incurs a significant add-on cost. When you choose FrameFormer, your input video resolution must be at
     * least 128x96.
     * 
     * @param framerateConversionAlgorithm
     *        Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For
     *        numerically simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value,
     *        Drop duplicate. For numerically complex conversions, to avoid stutter: Choose Interpolate. This results in
     *        a smooth picture, but might introduce undesirable video artifacts. For complex frame rate conversions,
     *        especially if your source video has already been converted from its original cadence: Choose FrameFormer
     *        to do motion-compensated interpolation. FrameFormer uses the best conversion method frame by frame. Note
     *        that using FrameFormer increases the transcoding time and incurs a significant add-on cost. When you
     *        choose FrameFormer, your input video resolution must be at least 128x96.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FramerateConversionAlgorithm
     */

    public Av1Settings withFramerateConversionAlgorithm(String framerateConversionAlgorithm) {
        setFramerateConversionAlgorithm(framerateConversionAlgorithm);
        return this;
    }

    /**
     * Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For numerically
     * simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value, Drop duplicate. For
     * numerically complex conversions, to avoid stutter: Choose Interpolate. This results in a smooth picture, but might
     * introduce undesirable video artifacts. For complex frame rate conversions, especially if your source video has
     * already been converted from its original cadence: Choose FrameFormer to do motion-compensated interpolation.
     * FrameFormer uses the best conversion method frame by frame. Note that using FrameFormer increases the transcoding
     * time and incurs a significant add-on cost. When you choose FrameFormer, your input video resolution must be at
     * least 128x96.
     * 
     * @param framerateConversionAlgorithm
     *        Choose the method that you want MediaConvert to use when increasing or decreasing the frame rate. For
     *        numerically simple conversions, such as 60 fps to 30 fps: We recommend that you keep the default value,
     *        Drop duplicate. For numerically complex conversions, to avoid stutter: Choose Interpolate. This results in
     *        a smooth picture, but might introduce undesirable video artifacts. For complex frame rate conversions,
     *        especially if your source video has already been converted from its original cadence: Choose FrameFormer
     *        to do motion-compensated interpolation. FrameFormer uses the best conversion method frame by frame. Note
     *        that using FrameFormer increases the transcoding time and incurs a significant add-on cost. When you
     *        choose FrameFormer, your input video resolution must be at least 128x96.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1FramerateConversionAlgorithm
     */

    public Av1Settings withFramerateConversionAlgorithm(Av1FramerateConversionAlgorithm framerateConversionAlgorithm) {
        this.framerateConversionAlgorithm = framerateConversionAlgorithm.toString();
        return this;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of this fraction. In this
     * example, use 1001 for the value of FramerateDenominator. When you use the console for transcode jobs that use
     * frame rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @param framerateDenominator
     *        When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *        fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of
     *        this fraction. In this example, use 1001 for the value of FramerateDenominator. When you use the console
     *        for transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate. In
     *        this example, specify 23.976.
     */

    public void setFramerateDenominator(Integer framerateDenominator) {
        this.framerateDenominator = framerateDenominator;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of this fraction. In this
     * example, use 1001 for the value of FramerateDenominator. When you use the console for transcode jobs that use
     * frame rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @return When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *         fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of
     *         this fraction. In this example, use 1001 for the value of FramerateDenominator. When you use the console
     *         for transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate.
     *         In this example, specify 23.976.
     */

    public Integer getFramerateDenominator() {
        return this.framerateDenominator;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of this fraction. In this
     * example, use 1001 for the value of FramerateDenominator. When you use the console for transcode jobs that use
     * frame rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @param framerateDenominator
     *        When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *        fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateDenominator to specify the denominator of
     *        this fraction. In this example, use 1001 for the value of FramerateDenominator. When you use the console
     *        for transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate. In
     *        this example, specify 23.976.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withFramerateDenominator(Integer framerateDenominator) {
        setFramerateDenominator(framerateDenominator);
        return this;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this fraction. In this
     * example, use 24000 for the value of FramerateNumerator. When you use the console for transcode jobs that use frame
     * rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @param framerateNumerator
     *        When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *        fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this
     *        fraction. In this example, use 24000 for the value of FramerateNumerator. When you use the console for
     *        transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate. In
     *        this example, specify 23.976.
     */

    public void setFramerateNumerator(Integer framerateNumerator) {
        this.framerateNumerator = framerateNumerator;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this fraction. In this
     * example, use 24000 for the value of FramerateNumerator. When you use the console for transcode jobs that use frame
     * rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @return When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *         fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this
     *         fraction. In this example, use 24000 for the value of FramerateNumerator. When you use the console for
     *         transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate. In
     *         this example, specify 23.976.
     */

    public Integer getFramerateNumerator() {
        return this.framerateNumerator;
    }

    /**
     * When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a fraction. For
     * example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this fraction. In this
     * example, use 24000 for the value of FramerateNumerator. When you use the console for transcode jobs that use frame
     * rate conversion, provide the value as a decimal number for Framerate. In this example, specify 23.976.
     * 
     * @param framerateNumerator
     *        When you use the API for transcode jobs that use frame rate conversion, specify the frame rate as a
     *        fraction. For example, 24000 / 1001 = 23.976 fps. Use FramerateNumerator to specify the numerator of this
     *        fraction. In this example, use 24000 for the value of FramerateNumerator. When you use the console for
     *        transcode jobs that use frame rate conversion, provide the value as a decimal number for Framerate. In
     *        this example, specify 23.976.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withFramerateNumerator(Integer framerateNumerator) {
        setFramerateNumerator(framerateNumerator);
        return this;
    }

    /**
     * Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     * seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where x is
     * an integer value.
     * 
     * @param gopSize
     *        Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     *        seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where
     *        x is an integer value.
     */

    public void setGopSize(Double gopSize) {
        this.gopSize = gopSize;
    }

    /**
     * Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     * seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where x is
     * an integer value.
     * 
     * @return Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length
     *         in seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x),
     *         where x is an integer value.
     */

    public Double getGopSize() {
        return this.gopSize;
    }

    /**
     * Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     * seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where x is
     * an integer value.
     * 
     * @param gopSize
     *        Specify the GOP length (keyframe interval) in frames. With AV1, MediaConvert doesn't support GOP length in
     *        seconds. This value must be greater than zero and preferably equal to 1 + ((numberBFrames + 1) * x), where
     *        x is an integer value.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withGopSize(Double gopSize) {
        setGopSize(gopSize);
        return this;
    }

    /**
     * Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     * control mode is QVBR.
     * 
     * @param maxBitrate
     *        Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     *        control mode is QVBR.
     */

    public void setMaxBitrate(Integer maxBitrate) {
        this.maxBitrate = maxBitrate;
    }

    /**
     * Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     * control mode is QVBR.
     * 
     * @return Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when
     *         Rate control mode is QVBR.
     */

    public Integer getMaxBitrate() {
        return this.maxBitrate;
    }

    /**
     * Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     * control mode is QVBR.
     * 
     * @param maxBitrate
     *        Maximum bitrate in bits/second. For example, enter five megabits per second as 5000000. Required when Rate
     *        control mode is QVBR.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withMaxBitrate(Integer maxBitrate) {
        setMaxBitrate(maxBitrate);
        return this;
    }

    /**
     * Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15. Choose a
     * larger number for a lower bitrate and smaller file size; choose a smaller number for better video quality.
     * 
     * @param numberBFramesBetweenReferenceFrames
     *        Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15.
     *        Choose a larger number for a lower bitrate and smaller file size; choose a smaller number for better video
     *        quality.
     */

    public void setNumberBFramesBetweenReferenceFrames(Integer numberBFramesBetweenReferenceFrames) {
        this.numberBFramesBetweenReferenceFrames = numberBFramesBetweenReferenceFrames;
    }

    /**
     * Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15. Choose a
     * larger number for a lower bitrate and smaller file size; choose a smaller number for better video quality.
     * 
     * @return Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15.
     *         Choose a larger number for a lower bitrate and smaller file size; choose a smaller number for better
     *         video quality.
     */

    public Integer getNumberBFramesBetweenReferenceFrames() {
        return this.numberBFramesBetweenReferenceFrames;
    }

    /**
     * Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15. Choose a
     * larger number for a lower bitrate and smaller file size; choose a smaller number for better video quality.
     * 
     * @param numberBFramesBetweenReferenceFrames
     *        Specify from the number of B-frames, in the range of 0-15. For AV1 encoding, we recommend using 7 or 15.
     *        Choose a larger number for a lower bitrate and smaller file size; choose a smaller number for better video
     *        quality.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withNumberBFramesBetweenReferenceFrames(Integer numberBFramesBetweenReferenceFrames) {
        setNumberBFramesBetweenReferenceFrames(numberBFramesBetweenReferenceFrames);
        return this;
    }

    /**
     * Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when you set
     * QVBR for Rate control mode.
     * 
     * @param qvbrSettings
     *        Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when
     *        you set QVBR for Rate control mode.
     */

    public void setQvbrSettings(Av1QvbrSettings qvbrSettings) {
        this.qvbrSettings = qvbrSettings;
    }

    /**
     * Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when you set
     * QVBR for Rate control mode.
     * 
     * @return Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when
     *         you set QVBR for Rate control mode.
     */

    public Av1QvbrSettings getQvbrSettings() {
        return this.qvbrSettings;
    }

    /**
     * Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when you set
     * QVBR for Rate control mode.
     * 
     * @param qvbrSettings
     *        Settings for quality-defined variable bitrate encoding with the H.265 codec. Use these settings only when
     *        you set QVBR for Rate control mode.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withQvbrSettings(Av1QvbrSettings qvbrSettings) {
        setQvbrSettings(qvbrSettings);
        return this;
    }

    /**
     * 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate (QVBR). You
     * can''t use CBR or VBR.'
     * 
     * @param rateControlMode
     *        'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate
     *        (QVBR). You can''t use CBR or VBR.'
     * @see Av1RateControlMode
     */

    public void setRateControlMode(String rateControlMode) {
        this.rateControlMode = rateControlMode;
    }

    /**
     * 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate (QVBR). You
     * can''t use CBR or VBR.'
     * 
     * @return 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate
     *         (QVBR). You can''t use CBR or VBR.'
     * @see Av1RateControlMode
     */

    public String getRateControlMode() {
        return this.rateControlMode;
    }

    /**
     * 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate (QVBR). You
     * can''t use CBR or VBR.'
     * 
     * @param rateControlMode
     *        'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate
     *        (QVBR). You can''t use CBR or VBR.'
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1RateControlMode
     */

    public Av1Settings withRateControlMode(String rateControlMode) {
        setRateControlMode(rateControlMode);
        return this;
    }

    /**
     * 'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate (QVBR). You
     * can''t use CBR or VBR.'
     * 
     * @param rateControlMode
     *        'With AV1 outputs, for rate control mode, MediaConvert supports only quality-defined variable bitrate
     *        (QVBR). You can''t use CBR or VBR.'
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1RateControlMode
     */

    public Av1Settings withRateControlMode(Av1RateControlMode rateControlMode) {
        this.rateControlMode = rateControlMode.toString();
        return this;
    }

    /**
     * Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive pictures,
     * this value must be less than or equal to the number of macroblock rows. For interlaced pictures, this value must
     * be less than or equal to half the number of macroblock rows.
     * 
     * @param slices
     *        Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive
     *        pictures, this value must be less than or equal to the number of macroblock rows. For interlaced pictures,
     *        this value must be less than or equal to half the number of macroblock rows.
     */

    public void setSlices(Integer slices) {
        this.slices = slices;
    }

    /**
     * Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive pictures,
     * this value must be less than or equal to the number of macroblock rows. For interlaced pictures, this value must
     * be less than or equal to half the number of macroblock rows.
     * 
     * @return Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive
     *         pictures, this value must be less than or equal to the number of macroblock rows. For interlaced
     *         pictures, this value must be less than or equal to half the number of macroblock rows.
     */

    public Integer getSlices() {
        return this.slices;
    }

    /**
     * Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive pictures,
     * this value must be less than or equal to the number of macroblock rows. For interlaced pictures, this value must
     * be less than or equal to half the number of macroblock rows.
     * 
     * @param slices
     *        Specify the number of slices per picture. This value must be 1, 2, 4, 8, 16, or 32. For progressive
     *        pictures, this value must be less than or equal to the number of macroblock rows. For interlaced pictures,
     *        this value must be less than or equal to half the number of macroblock rows.
     * @return Returns a reference to this object so that method calls can be chained together.
     */

    public Av1Settings withSlices(Integer slices) {
        setSlices(slices);
        return this;
    }

    /**
     * Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of content
     * complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain more distortion
     * with no noticeable visual degradation and uses more bits on areas where any small distortion will be noticeable.
     * For example, complex textured blocks are encoded with fewer bits and smooth textured blocks are encoded with more
     * bits. Enabling this feature will almost always improve your video quality. Note, though, that this feature doesn't
     * take into account where the viewer's attention is likely to be. If viewers are likely to be focusing their
     * attention on a part of the screen with a lot of complex texture, you might choose to disable this feature. Related
     * setting: When you enable spatial adaptive quantization, set the value for Adaptive quantization depending on your
     * content. For homogeneous content, such as cartoons and video games, set it to Low. For content with a wider
     * variety of textures, set it to High or Higher.
     * 
     * @param spatialAdaptiveQuantization
     *        Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of
     *        content complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain
     *        more distortion with no noticeable visual degradation and uses more bits on areas where any small
     *        distortion will be noticeable. For example, complex textured blocks are encoded with fewer bits and smooth
     *        textured blocks are encoded with more bits. Enabling this feature will almost always improve your video
     *        quality. Note, though, that this feature doesn't take into account where the viewer's attention is likely
     *        to be. If viewers are likely to be focusing their attention on a part of the screen with a lot of complex
     *        texture, you might choose to disable this feature. Related setting: When you enable spatial adaptive
     *        quantization, set the value for Adaptive quantization depending on your content. For homogeneous content,
     *        such as cartoons and video games, set it to Low. For content with a wider variety of textures, set it to
     *        High or Higher.
     * @see Av1SpatialAdaptiveQuantization
     */

    public void setSpatialAdaptiveQuantization(String spatialAdaptiveQuantization) {
        this.spatialAdaptiveQuantization = spatialAdaptiveQuantization;
    }

    /**
     * Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of content
     * complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain more distortion
     * with no noticeable visual degradation and uses more bits on areas where any small distortion will be noticeable.
     * For example, complex textured blocks are encoded with fewer bits and smooth textured blocks are encoded with more
     * bits. Enabling this feature will almost always improve your video quality. Note, though, that this feature doesn't
     * take into account where the viewer's attention is likely to be. If viewers are likely to be focusing their
     * attention on a part of the screen with a lot of complex texture, you might choose to disable this feature. Related
     * setting: When you enable spatial adaptive quantization, set the value for Adaptive quantization depending on your
     * content. For homogeneous content, such as cartoons and video games, set it to Low. For content with a wider
     * variety of textures, set it to High or Higher.
     * 
     * @return Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of
     *         content complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain
     *         more distortion with no noticeable visual degradation and uses more bits on areas where any small
     *         distortion will be noticeable. For example, complex textured blocks are encoded with fewer bits and
     *         smooth textured blocks are encoded with more bits. Enabling this feature will almost always improve your
     *         video quality. Note, though, that this feature doesn't take into account where the viewer's attention is
     *         likely to be. If viewers are likely to be focusing their attention on a part of the screen with a lot of
     *         complex texture, you might choose to disable this feature. Related setting: When you enable spatial
     *         adaptive quantization, set the value for Adaptive quantization depending on your content. For homogeneous
     *         content, such as cartoons and video games, set it to Low. For content with a wider variety of textures,
     *         set it to High or Higher.
     * @see Av1SpatialAdaptiveQuantization
     */

    public String getSpatialAdaptiveQuantization() {
        return this.spatialAdaptiveQuantization;
    }

    /**
     * Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of content
     * complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain more distortion
     * with no noticeable visual degradation and uses more bits on areas where any small distortion will be noticeable.
     * For example, complex textured blocks are encoded with fewer bits and smooth textured blocks are encoded with more
     * bits. Enabling this feature will almost always improve your video quality. Note, though, that this feature doesn't
     * take into account where the viewer's attention is likely to be. If viewers are likely to be focusing their
     * attention on a part of the screen with a lot of complex texture, you might choose to disable this feature. Related
     * setting: When you enable spatial adaptive quantization, set the value for Adaptive quantization depending on your
     * content. For homogeneous content, such as cartoons and video games, set it to Low. For content with a wider
     * variety of textures, set it to High or Higher.
     * 
     * @param spatialAdaptiveQuantization
     *        Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of
     *        content complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain
     *        more distortion with no noticeable visual degradation and uses more bits on areas where any small
     *        distortion will be noticeable. For example, complex textured blocks are encoded with fewer bits and smooth
     *        textured blocks are encoded with more bits. Enabling this feature will almost always improve your video
     *        quality. Note, though, that this feature doesn't take into account where the viewer's attention is likely
     *        to be. If viewers are likely to be focusing their attention on a part of the screen with a lot of complex
     *        texture, you might choose to disable this feature. Related setting: When you enable spatial adaptive
     *        quantization, set the value for Adaptive quantization depending on your content. For homogeneous content,
     *        such as cartoons and video games, set it to Low. For content with a wider variety of textures, set it to
     *        High or Higher.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1SpatialAdaptiveQuantization
     */

    public Av1Settings withSpatialAdaptiveQuantization(String spatialAdaptiveQuantization) {
        setSpatialAdaptiveQuantization(spatialAdaptiveQuantization);
        return this;
    }

    /**
     * Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of content
     * complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain more distortion
     * with no noticeable visual degradation and uses more bits on areas where any small distortion will be noticeable.
     * For example, complex textured blocks are encoded with fewer bits and smooth textured blocks are encoded with more
     * bits. Enabling this feature will almost always improve your video quality. Note, though, that this feature doesn't
     * take into account where the viewer's attention is likely to be. If viewers are likely to be focusing their
     * attention on a part of the screen with a lot of complex texture, you might choose to disable this feature. Related
     * setting: When you enable spatial adaptive quantization, set the value for Adaptive quantization depending on your
     * content. For homogeneous content, such as cartoons and video games, set it to Low. For content with a wider
     * variety of textures, set it to High or Higher.
     * 
     * @param spatialAdaptiveQuantization
     *        Keep the default value, Enabled, to adjust quantization within each frame based on spatial variation of
     *        content complexity. When you enable this feature, the encoder uses fewer bits on areas that can sustain
     *        more distortion with no noticeable visual degradation and uses more bits on areas where any small
     *        distortion will be noticeable. For example, complex textured blocks are encoded with fewer bits and smooth
     *        textured blocks are encoded with more bits. Enabling this feature will almost always improve your video
     *        quality. Note, though, that this feature doesn't take into account where the viewer's attention is likely
     *        to be. If viewers are likely to be focusing their attention on a part of the screen with a lot of complex
     *        texture, you might choose to disable this feature. Related setting: When you enable spatial adaptive
     *        quantization, set the value for Adaptive quantization depending on your content. For homogeneous content,
     *        such as cartoons and video games, set it to Low. For content with a wider variety of textures, set it to
     *        High or Higher.
     * @return Returns a reference to this object so that method calls can be chained together.
     * @see Av1SpatialAdaptiveQuantization
     */

    public Av1Settings withSpatialAdaptiveQuantization(Av1SpatialAdaptiveQuantization spatialAdaptiveQuantization) {
        this.spatialAdaptiveQuantization = spatialAdaptiveQuantization.toString();
        return this;
    }

    /**
     * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
     * redacted from this string using a placeholder value.
     *
     * @return A string representation of this object.
     *
     * @see java.lang.Object#toString()
     */
    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("{");
        if (getAdaptiveQuantization() != null)
            sb.append("AdaptiveQuantization: ").append(getAdaptiveQuantization()).append(",");
        if (getBitDepth() != null)
            sb.append("BitDepth: ").append(getBitDepth()).append(",");
        if (getFilmGrainSynthesis() != null)
            sb.append("FilmGrainSynthesis: ").append(getFilmGrainSynthesis()).append(",");
        if (getFramerateControl() != null)
            sb.append("FramerateControl: ").append(getFramerateControl()).append(",");
        if (getFramerateConversionAlgorithm() != null)
            sb.append("FramerateConversionAlgorithm: ").append(getFramerateConversionAlgorithm()).append(",");
        if (getFramerateDenominator() != null)
            sb.append("FramerateDenominator: ").append(getFramerateDenominator()).append(",");
        if (getFramerateNumerator() != null)
            sb.append("FramerateNumerator: ").append(getFramerateNumerator()).append(",");
        if (getGopSize() != null)
            sb.append("GopSize: ").append(getGopSize()).append(",");
        if (getMaxBitrate() != null)
            sb.append("MaxBitrate: ").append(getMaxBitrate()).append(",");
        if (getNumberBFramesBetweenReferenceFrames() != null)
            sb.append("NumberBFramesBetweenReferenceFrames: ").append(getNumberBFramesBetweenReferenceFrames()).append(",");
        if (getQvbrSettings() != null)
            sb.append("QvbrSettings: ").append(getQvbrSettings()).append(",");
        if (getRateControlMode() != null)
            sb.append("RateControlMode: ").append(getRateControlMode()).append(",");
        if (getSlices() != null)
            sb.append("Slices: ").append(getSlices()).append(",");
        if (getSpatialAdaptiveQuantization() != null)
            sb.append("SpatialAdaptiveQuantization: ").append(getSpatialAdaptiveQuantization());
        sb.append("}");
        return sb.toString();
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;

        if (obj instanceof Av1Settings == false)
            return false;
        Av1Settings other = (Av1Settings) obj;
        if (other.getAdaptiveQuantization() == null ^ this.getAdaptiveQuantization() == null)
            return false;
        if (other.getAdaptiveQuantization() != null && other.getAdaptiveQuantization().equals(this.getAdaptiveQuantization()) == false)
            return false;
        if (other.getBitDepth() == null ^ this.getBitDepth() == null)
            return false;
        if (other.getBitDepth() != null && other.getBitDepth().equals(this.getBitDepth()) == false)
            return false;
        if (other.getFilmGrainSynthesis() == null ^ this.getFilmGrainSynthesis() == null)
            return false;
        if (other.getFilmGrainSynthesis() != null && other.getFilmGrainSynthesis().equals(this.getFilmGrainSynthesis()) == false)
            return false;
        if (other.getFramerateControl() == null ^ this.getFramerateControl() == null)
            return false;
        if (other.getFramerateControl() != null && other.getFramerateControl().equals(this.getFramerateControl()) == false)
            return false;
        if (other.getFramerateConversionAlgorithm() == null ^ this.getFramerateConversionAlgorithm() == null)
            return false;
        if (other.getFramerateConversionAlgorithm() != null && other.getFramerateConversionAlgorithm().equals(this.getFramerateConversionAlgorithm()) == false)
            return false;
        if (other.getFramerateDenominator() == null ^ this.getFramerateDenominator() == null)
            return false;
        if (other.getFramerateDenominator() != null && other.getFramerateDenominator().equals(this.getFramerateDenominator()) == false)
            return false;
        if (other.getFramerateNumerator() == null ^ this.getFramerateNumerator() == null)
            return false;
        if (other.getFramerateNumerator() != null && other.getFramerateNumerator().equals(this.getFramerateNumerator()) == false)
            return false;
        if (other.getGopSize() == null ^ this.getGopSize() == null)
            return false;
        if (other.getGopSize() != null && other.getGopSize().equals(this.getGopSize()) == false)
            return false;
        if (other.getMaxBitrate() == null ^ this.getMaxBitrate() == null)
            return false;
        if (other.getMaxBitrate() != null && other.getMaxBitrate().equals(this.getMaxBitrate()) == false)
            return false;
        if (other.getNumberBFramesBetweenReferenceFrames() == null ^ this.getNumberBFramesBetweenReferenceFrames() == null)
            return false;
        if (other.getNumberBFramesBetweenReferenceFrames() != null
                && other.getNumberBFramesBetweenReferenceFrames().equals(this.getNumberBFramesBetweenReferenceFrames()) == false)
            return false;
        if (other.getQvbrSettings() == null ^ this.getQvbrSettings() == null)
            return false;
        if (other.getQvbrSettings() != null && other.getQvbrSettings().equals(this.getQvbrSettings()) == false)
            return false;
        if (other.getRateControlMode() == null ^ this.getRateControlMode() == null)
            return false;
        if (other.getRateControlMode() != null && other.getRateControlMode().equals(this.getRateControlMode()) == false)
            return false;
        if (other.getSlices() == null ^ this.getSlices() == null)
            return false;
        if (other.getSlices() != null && other.getSlices().equals(this.getSlices()) == false)
            return false;
        if (other.getSpatialAdaptiveQuantization() == null ^ this.getSpatialAdaptiveQuantization() == null)
            return false;
        if (other.getSpatialAdaptiveQuantization() != null && other.getSpatialAdaptiveQuantization().equals(this.getSpatialAdaptiveQuantization()) == false)
            return false;
        return true;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int hashCode = 1;

        hashCode = prime * hashCode + ((getAdaptiveQuantization() == null) ? 0 : getAdaptiveQuantization().hashCode());
        hashCode = prime * hashCode + ((getBitDepth() == null) ? 0 : getBitDepth().hashCode());
        hashCode = prime * hashCode + ((getFilmGrainSynthesis() == null) ? 0 : getFilmGrainSynthesis().hashCode());
        hashCode = prime * hashCode + ((getFramerateControl() == null) ? 0 : getFramerateControl().hashCode());
        hashCode = prime * hashCode + ((getFramerateConversionAlgorithm() == null) ? 0 : getFramerateConversionAlgorithm().hashCode());
        hashCode = prime * hashCode + ((getFramerateDenominator() == null) ? 0 : getFramerateDenominator().hashCode());
        hashCode = prime * hashCode + ((getFramerateNumerator() == null) ? 0 : getFramerateNumerator().hashCode());
        hashCode = prime * hashCode + ((getGopSize() == null) ? 0 : getGopSize().hashCode());
        hashCode = prime * hashCode + ((getMaxBitrate() == null) ? 0 : getMaxBitrate().hashCode());
        hashCode = prime * hashCode + ((getNumberBFramesBetweenReferenceFrames() == null) ? 0 : getNumberBFramesBetweenReferenceFrames().hashCode());
        hashCode = prime * hashCode + ((getQvbrSettings() == null) ? 0 : getQvbrSettings().hashCode());
        hashCode = prime * hashCode + ((getRateControlMode() == null) ? 0 : getRateControlMode().hashCode());
        hashCode = prime * hashCode + ((getSlices() == null) ? 0 : getSlices().hashCode());
        hashCode = prime * hashCode + ((getSpatialAdaptiveQuantization() == null) ? 0 : getSpatialAdaptiveQuantization().hashCode());
        return hashCode;
    }

    @Override
    public Av1Settings clone() {
        try {
            return (Av1Settings) super.clone();
        } catch (CloneNotSupportedException e) {
            throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
        }
    }

    @com.amazonaws.annotation.SdkInternalApi
    @Override
    public void marshall(ProtocolMarshaller protocolMarshaller) {
        com.amazonaws.services.mediaconvert.model.transform.Av1SettingsMarshaller.getInstance().marshall(this, protocolMarshaller);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy