/* * Copyright 2010-2023 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.rekognition.model; import java.io.Serializable; /** *
* A filter that allows you to control the black frame detection by specifying * the black levels and pixel coverage of black pixels in a frame. As videos can * come from multiple sources, formats, and time periods, they may contain * different standards and varying noise levels for black frames that need to be * accounted for. For more information, see StartSegmentDetection. *
*/ public class BlackFrame implements Serializable { /** ** A threshold used to determine the maximum luminance value for a pixel to * be considered black. In a full color range video, luminance values range * from 0-255. A pixel value of 0 is pure black, and the most strict filter. * The maximum black pixel value is computed as follows: * max_black_pixel_value = minimum_luminance + MaxPixelThreshold * *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = 0.1, * max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can lower this * threshold to be more strict on black levels. *
*
* Constraints:
* Length: 0.0 - 1.0
*/
private Float maxPixelThreshold;
/**
*
* The minimum percentage of pixels in a frame that need to have a luminance * below the max_black_pixel_value for a frame to be considered a black * frame. Luminance is calculated using the BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all pixels in the
* frame are black pixels as per the MaxPixelThreshold
set. You
* can reduce this value to allow more noise on the black frame.
*
* Constraints:
* Length: 0.0 - 100.0
*/
private Float minCoveragePercentage;
/**
*
* A threshold used to determine the maximum luminance value for a pixel to * be considered black. In a full color range video, luminance values range * from 0-255. A pixel value of 0 is pure black, and the most strict filter. * The maximum black pixel value is computed as follows: * max_black_pixel_value = minimum_luminance + MaxPixelThreshold * *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = 0.1, * max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can lower this * threshold to be more strict on black levels. *
*
* Constraints:
* Length: 0.0 - 1.0
*
* @return
* A threshold used to determine the maximum luminance value for a * pixel to be considered black. In a full color range video, * luminance values range from 0-255. A pixel value of 0 is pure * black, and the most strict filter. The maximum black pixel value * is computed as follows: max_black_pixel_value = minimum_luminance * + MaxPixelThreshold *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = * 0.1, max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can lower * this threshold to be more strict on black levels. *
*/ public Float getMaxPixelThreshold() { return maxPixelThreshold; } /** ** A threshold used to determine the maximum luminance value for a pixel to * be considered black. In a full color range video, luminance values range * from 0-255. A pixel value of 0 is pure black, and the most strict filter. * The maximum black pixel value is computed as follows: * max_black_pixel_value = minimum_luminance + MaxPixelThreshold * *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = 0.1, * max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can lower this * threshold to be more strict on black levels. *
*
* Constraints:
* Length: 0.0 - 1.0
*
* @param maxPixelThreshold
* A threshold used to determine the maximum luminance value for * a pixel to be considered black. In a full color range video, * luminance values range from 0-255. A pixel value of 0 is pure * black, and the most strict filter. The maximum black pixel * value is computed as follows: max_black_pixel_value = * minimum_luminance + MaxPixelThreshold *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = * 0.1, max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can * lower this threshold to be more strict on black levels. *
*/ public void setMaxPixelThreshold(Float maxPixelThreshold) { this.maxPixelThreshold = maxPixelThreshold; } /** ** A threshold used to determine the maximum luminance value for a pixel to * be considered black. In a full color range video, luminance values range * from 0-255. A pixel value of 0 is pure black, and the most strict filter. * The maximum black pixel value is computed as follows: * max_black_pixel_value = minimum_luminance + MaxPixelThreshold * *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = 0.1, * max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can lower this * threshold to be more strict on black levels. *
** Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: 0.0 - 1.0
*
* @param maxPixelThreshold
* A threshold used to determine the maximum luminance value for * a pixel to be considered black. In a full color range video, * luminance values range from 0-255. A pixel value of 0 is pure * black, and the most strict filter. The maximum black pixel * value is computed as follows: max_black_pixel_value = * minimum_luminance + MaxPixelThreshold *luminance_range. *
** For example, for a full range video with BlackPixelThreshold = * 0.1, max_black_pixel_value is 0 + 0.1 * (255-0) = 25.5. *
** The default value of MaxPixelThreshold is 0.2, which maps to a * max_black_pixel_value of 51 for a full range video. You can * lower this threshold to be more strict on black levels. *
* @return A reference to this updated object so that method calls can be * chained together. */ public BlackFrame withMaxPixelThreshold(Float maxPixelThreshold) { this.maxPixelThreshold = maxPixelThreshold; return this; } /** ** The minimum percentage of pixels in a frame that need to have a luminance * below the max_black_pixel_value for a frame to be considered a black * frame. Luminance is calculated using the BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all pixels in the
* frame are black pixels as per the MaxPixelThreshold
set. You
* can reduce this value to allow more noise on the black frame.
*
* Constraints:
* Length: 0.0 - 100.0
*
* @return
* The minimum percentage of pixels in a frame that need to have a * luminance below the max_black_pixel_value for a frame to be * considered a black frame. Luminance is calculated using the * BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all pixels
* in the frame are black pixels as per the
* MaxPixelThreshold
set. You can reduce this value to
* allow more noise on the black frame.
*
* The minimum percentage of pixels in a frame that need to have a luminance * below the max_black_pixel_value for a frame to be considered a black * frame. Luminance is calculated using the BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all pixels in the
* frame are black pixels as per the MaxPixelThreshold
set. You
* can reduce this value to allow more noise on the black frame.
*
* Constraints:
* Length: 0.0 - 100.0
*
* @param minCoveragePercentage
* The minimum percentage of pixels in a frame that need to have * a luminance below the max_black_pixel_value for a frame to be * considered a black frame. Luminance is calculated using the * BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all
* pixels in the frame are black pixels as per the
* MaxPixelThreshold
set. You can reduce this value
* to allow more noise on the black frame.
*
* The minimum percentage of pixels in a frame that need to have a luminance * below the max_black_pixel_value for a frame to be considered a black * frame. Luminance is calculated using the BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all pixels in the
* frame are black pixels as per the MaxPixelThreshold
set. You
* can reduce this value to allow more noise on the black frame.
*
* Returns a reference to this object so that method calls can be chained * together. *
* Constraints:
* Length: 0.0 - 100.0
*
* @param minCoveragePercentage
* The minimum percentage of pixels in a frame that need to have * a luminance below the max_black_pixel_value for a frame to be * considered a black frame. Luminance is calculated using the * BT.709 matrix. *
*
* The default value is 99, which means at least 99% of all
* pixels in the frame are black pixels as per the
* MaxPixelThreshold
set. You can reduce this value
* to allow more noise on the black frame.
*