# frozen_string_literal: true
# WARNING ABOUT GENERATED CODE
#
# This file is generated. See the contributing guide for more information:
# https://github.com/aws/aws-sdk-ruby/blob/version-3/CONTRIBUTING.md
#
# WARNING ABOUT GENERATED CODE
module Aws::Rekognition
module Types
# You are not authorized to perform the action.
#
class AccessDeniedException < Aws::EmptyStructure; end
# Structure containing the estimated age range, in years, for a face.
#
# Amazon Rekognition estimates an age range for faces detected in the
# input image. Estimated age ranges can overlap. A face of a 5-year-old
# might have an estimated range of 4-6, while the face of a 6-year-old
# might have an estimated range of 4-8.
#
# @!attribute [rw] low
# The lowest estimated age.
# @return [Integer]
#
# @!attribute [rw] high
# The highest estimated age.
# @return [Integer]
#
class AgeRange < Struct.new(
:low,
:high)
SENSITIVE = []
include Aws::Structure
end
# Assets are the images that you use to train and evaluate a model
# version. Assets can also contain validation information that you use
# to debug a failed model training.
#
# @note When making an API call, you may pass Asset
# data as a hash:
#
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# }
#
# @!attribute [rw] ground_truth_manifest
# The S3 bucket that contains an Amazon Sagemaker Ground Truth format
# manifest file.
# @return [Types::GroundTruthManifest]
#
class Asset < Struct.new(
:ground_truth_manifest)
SENSITIVE = []
include Aws::Structure
end
# Metadata information about an audio stream. An array of
# `AudioMetadata` objects for the audio streams found in a stored video
# is returned by GetSegmentDetection.
#
# @!attribute [rw] codec
# The audio codec used to encode or decode the audio stream.
# @return [String]
#
# @!attribute [rw] duration_millis
# The duration of the audio stream in milliseconds.
# @return [Integer]
#
# @!attribute [rw] sample_rate
# The sample rate for the audio stream.
# @return [Integer]
#
# @!attribute [rw] number_of_channels
# The number of audio channels in the segment.
# @return [Integer]
#
class AudioMetadata < Struct.new(
:codec,
:duration_millis,
:sample_rate,
:number_of_channels)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the face has a beard, and the confidence
# level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the face has beard or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Beard < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# 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.
#
# @note When making an API call, you may pass BlackFrame
# data as a hash:
#
# {
# max_pixel_threshold: 1.0,
# min_coverage_percentage: 1.0,
# }
#
# @!attribute [rw] max_pixel_threshold
# 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 [Float]
#
# @!attribute [rw] min_coverage_percentage
# 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.
# @return [Float]
#
class BlackFrame < Struct.new(
:max_pixel_threshold,
:min_coverage_percentage)
SENSITIVE = []
include Aws::Structure
end
# Identifies the bounding box around the label, face, text, object of
# interest, or personal protective equipment. The `left` (x-coordinate)
# and `top` (y-coordinate) are coordinates representing the top and left
# sides of the bounding box. Note that the upper-left corner of the
# image is the origin (0,0).
#
# The `top` and `left` values returned are ratios of the overall image
# size. For example, if the input image is 700x200 pixels, and the
# top-left coordinate of the bounding box is 350x50 pixels, the API
# returns a `left` value of 0.5 (350/700) and a `top` value of 0.25
# (50/200).
#
# The `width` and `height` values represent the dimensions of the
# bounding box as a ratio of the overall image dimension. For example,
# if the input image is 700x200 pixels, and the bounding box width is 70
# pixels, the width returned is 0.1.
#
# The bounding box coordinates can have negative values. For example, if
# Amazon Rekognition is able to detect a face that is at the image edge
# and is only partially visible, the service can return coordinates that
# are outside the image bounds and, depending on the image edge, you
# might get negative values or values greater than 1 for the `left` or
# `top` values.
#
#
#
# @note When making an API call, you may pass BoundingBox
# data as a hash:
#
# {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# }
#
# @!attribute [rw] width
# Width of the bounding box as a ratio of the overall image width.
# @return [Float]
#
# @!attribute [rw] height
# Height of the bounding box as a ratio of the overall image height.
# @return [Float]
#
# @!attribute [rw] left
# Left coordinate of the bounding box as a ratio of overall image
# width.
# @return [Float]
#
# @!attribute [rw] top
# Top coordinate of the bounding box as a ratio of overall image
# height.
# @return [Float]
#
class BoundingBox < Struct.new(
:width,
:height,
:left,
:top)
SENSITIVE = []
include Aws::Structure
end
# Provides information about a celebrity recognized by the
# RecognizeCelebrities operation.
#
# @!attribute [rw] urls
# An array of URLs pointing to additional information about the
# celebrity. If there is no additional information about the
# celebrity, this list is empty.
# @return [Array]
#
# @!attribute [rw] name
# The name of the celebrity.
# @return [String]
#
# @!attribute [rw] id
# A unique identifier for the celebrity.
# @return [String]
#
# @!attribute [rw] face
# Provides information about the celebrity's face, such as its
# location on the image.
# @return [Types::ComparedFace]
#
# @!attribute [rw] match_confidence
# The confidence, in percentage, that Amazon Rekognition has that the
# recognized face is the celebrity.
# @return [Float]
#
# @!attribute [rw] known_gender
# The known gender identity for the celebrity that matches the
# provided ID. The known gender identity can be Male, Female,
# Nonbinary, or Unlisted.
# @return [Types::KnownGender]
#
class Celebrity < Struct.new(
:urls,
:name,
:id,
:face,
:match_confidence,
:known_gender)
SENSITIVE = []
include Aws::Structure
end
# Information about a recognized celebrity.
#
# @!attribute [rw] urls
# An array of URLs pointing to additional celebrity information.
# @return [Array]
#
# @!attribute [rw] name
# The name of the celebrity.
# @return [String]
#
# @!attribute [rw] id
# The unique identifier for the celebrity.
# @return [String]
#
# @!attribute [rw] confidence
# The confidence, in percentage, that Amazon Rekognition has that the
# recognized face is the celebrity.
# @return [Float]
#
# @!attribute [rw] bounding_box
# Bounding box around the body of a celebrity.
# @return [Types::BoundingBox]
#
# @!attribute [rw] face
# Face details for the recognized celebrity.
# @return [Types::FaceDetail]
#
# @!attribute [rw] known_gender
# Retrieves the known gender for the celebrity.
# @return [Types::KnownGender]
#
class CelebrityDetail < Struct.new(
:urls,
:name,
:id,
:confidence,
:bounding_box,
:face,
:known_gender)
SENSITIVE = []
include Aws::Structure
end
# Information about a detected celebrity and the time the celebrity was
# detected in a stored video. For more information, see
# GetCelebrityRecognition in the Amazon Rekognition Developer Guide.
#
# @!attribute [rw] timestamp
# The time, in milliseconds from the start of the video, that the
# celebrity was recognized.
# @return [Integer]
#
# @!attribute [rw] celebrity
# Information about a recognized celebrity.
# @return [Types::CelebrityDetail]
#
class CelebrityRecognition < Struct.new(
:timestamp,
:celebrity)
SENSITIVE = []
include Aws::Structure
end
# Provides information about a face in a target image that matches the
# source image face analyzed by `CompareFaces`. The `Face` property
# contains the bounding box of the face in the target image. The
# `Similarity` property is the confidence that the source image face
# matches the face in the bounding box.
#
# @!attribute [rw] similarity
# Level of confidence that the faces match.
# @return [Float]
#
# @!attribute [rw] face
# Provides face metadata (bounding box and confidence that the
# bounding box actually contains a face).
# @return [Types::ComparedFace]
#
class CompareFacesMatch < Struct.new(
:similarity,
:face)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CompareFacesRequest
# data as a hash:
#
# {
# source_image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# target_image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# similarity_threshold: 1.0,
# quality_filter: "NONE", # accepts NONE, AUTO, LOW, MEDIUM, HIGH
# }
#
# @!attribute [rw] source_image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] target_image
# The target image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] similarity_threshold
# The minimum level of confidence in the face matches that a match
# must meet to be included in the `FaceMatches` array.
# @return [Float]
#
# @!attribute [rw] quality_filter
# A filter that specifies a quality bar for how much filtering is done
# to identify faces. Filtered faces aren't compared. If you specify
# `AUTO`, Amazon Rekognition chooses the quality bar. If you specify
# `LOW`, `MEDIUM`, or `HIGH`, filtering removes all faces that don’t
# meet the chosen quality bar. The quality bar is based on a variety
# of common use cases. Low-quality detections can occur for a number
# of reasons. Some examples are an object that's misidentified as a
# face, a face that's too blurry, or a face with a pose that's too
# extreme to use. If you specify `NONE`, no filtering is performed.
# The default value is `NONE`.
#
# To use quality filtering, the collection you are using must be
# associated with version 3 of the face model or higher.
# @return [String]
#
class CompareFacesRequest < Struct.new(
:source_image,
:target_image,
:similarity_threshold,
:quality_filter)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] source_image_face
# The face in the source image that was used for comparison.
# @return [Types::ComparedSourceImageFace]
#
# @!attribute [rw] face_matches
# An array of faces in the target image that match the source image
# face. Each `CompareFacesMatch` object provides the bounding box, the
# confidence level that the bounding box contains a face, and the
# similarity score for the face in the bounding box and the face in
# the source image.
# @return [Array]
#
# @!attribute [rw] unmatched_faces
# An array of faces in the target image that did not match the source
# image face.
# @return [Array]
#
# @!attribute [rw] source_image_orientation_correction
# The value of `SourceImageOrientationCorrection` is always null.
#
# If the input image is in .jpeg format, it might contain exchangeable
# image file format (Exif) metadata that includes the image's
# orientation. Amazon Rekognition uses this orientation information to
# perform image correction. The bounding box coordinates are
# translated to represent object locations after the orientation
# information in the Exif metadata is used to correct the image
# orientation. Images in .png format don't contain Exif metadata.
#
# Amazon Rekognition doesn’t perform image correction for images in
# .png format and .jpeg images without orientation information in the
# image Exif metadata. The bounding box coordinates aren't translated
# and represent the object locations before the image is rotated.
# @return [String]
#
# @!attribute [rw] target_image_orientation_correction
# The value of `TargetImageOrientationCorrection` is always null.
#
# If the input image is in .jpeg format, it might contain exchangeable
# image file format (Exif) metadata that includes the image's
# orientation. Amazon Rekognition uses this orientation information to
# perform image correction. The bounding box coordinates are
# translated to represent object locations after the orientation
# information in the Exif metadata is used to correct the image
# orientation. Images in .png format don't contain Exif metadata.
#
# Amazon Rekognition doesn’t perform image correction for images in
# .png format and .jpeg images without orientation information in the
# image Exif metadata. The bounding box coordinates aren't translated
# and represent the object locations before the image is rotated.
# @return [String]
#
class CompareFacesResponse < Struct.new(
:source_image_face,
:face_matches,
:unmatched_faces,
:source_image_orientation_correction,
:target_image_orientation_correction)
SENSITIVE = []
include Aws::Structure
end
# Provides face metadata for target image faces that are analyzed by
# `CompareFaces` and `RecognizeCelebrities`.
#
# @!attribute [rw] bounding_box
# Bounding box of the face.
# @return [Types::BoundingBox]
#
# @!attribute [rw] confidence
# Level of confidence that what the bounding box contains is a face.
# @return [Float]
#
# @!attribute [rw] landmarks
# An array of facial landmarks.
# @return [Array]
#
# @!attribute [rw] pose
# Indicates the pose of the face as determined by its pitch, roll, and
# yaw.
# @return [Types::Pose]
#
# @!attribute [rw] quality
# Identifies face image brightness and sharpness.
# @return [Types::ImageQuality]
#
# @!attribute [rw] emotions
# The emotions that appear to be expressed on the face, and the
# confidence level in the determination. Valid values include
# "Happy", "Sad", "Angry", "Confused", "Disgusted",
# "Surprised", "Calm", "Unknown", and "Fear".
# @return [Array]
#
# @!attribute [rw] smile
# Indicates whether or not the face is smiling, and the confidence
# level in the determination.
# @return [Types::Smile]
#
class ComparedFace < Struct.new(
:bounding_box,
:confidence,
:landmarks,
:pose,
:quality,
:emotions,
:smile)
SENSITIVE = []
include Aws::Structure
end
# Type that describes the face Amazon Rekognition chose to compare with
# the faces in the target. This contains a bounding box for the selected
# face and confidence level that the bounding box contains a face. Note
# that Amazon Rekognition selects the largest face in the source image
# for this comparison.
#
# @!attribute [rw] bounding_box
# Bounding box of the face.
# @return [Types::BoundingBox]
#
# @!attribute [rw] confidence
# Confidence level that the selected bounding box contains a face.
# @return [Float]
#
class ComparedSourceImageFace < Struct.new(
:bounding_box,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Label detection settings to use on a streaming video. Defining the
# settings is required in the request parameter for
# CreateStreamProcessor. Including this setting in the
# `CreateStreamProcessor` request enables you to use the stream
# processor for label detection. You can then select what you want the
# stream processor to detect, such as people or pets. When the stream
# processor has started, one notification is sent for each object class
# specified. For example, if packages and pets are selected, one SNS
# notification is published the first time a package is detected and one
# SNS notification is published the first time a pet is detected, as
# well as an end-of-session summary.
#
# @note When making an API call, you may pass ConnectedHomeSettings
# data as a hash:
#
# {
# labels: ["ConnectedHomeLabel"], # required
# min_confidence: 1.0,
# }
#
# @!attribute [rw] labels
# Specifies what you want to detect in the video, such as people,
# packages, or pets. The current valid labels you can include in this
# list are: "PERSON", "PET", "PACKAGE", and "ALL".
# @return [Array]
#
# @!attribute [rw] min_confidence
# The minimum confidence required to label an object in the video.
# @return [Float]
#
class ConnectedHomeSettings < Struct.new(
:labels,
:min_confidence)
SENSITIVE = []
include Aws::Structure
end
# The label detection settings you want to use in your stream processor.
# This includes the labels you want the stream processor to detect and
# the minimum confidence level allowed to label objects.
#
# @note When making an API call, you may pass ConnectedHomeSettingsForUpdate
# data as a hash:
#
# {
# labels: ["ConnectedHomeLabel"],
# min_confidence: 1.0,
# }
#
# @!attribute [rw] labels
# Specifies what you want to detect in the video, such as people,
# packages, or pets. The current valid labels you can include in this
# list are: "PERSON", "PET", "PACKAGE", and "ALL".
# @return [Array]
#
# @!attribute [rw] min_confidence
# The minimum confidence required to label an object in the video.
# @return [Float]
#
class ConnectedHomeSettingsForUpdate < Struct.new(
:labels,
:min_confidence)
SENSITIVE = []
include Aws::Structure
end
# Information about an inappropriate, unwanted, or offensive content
# label detection in a stored video.
#
# @!attribute [rw] timestamp
# Time, in milliseconds from the beginning of the video, that the
# content moderation label was detected.
# @return [Integer]
#
# @!attribute [rw] moderation_label
# The content moderation label detected by in the stored video.
# @return [Types::ModerationLabel]
#
class ContentModerationDetection < Struct.new(
:timestamp,
:moderation_label)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CopyProjectVersionRequest
# data as a hash:
#
# {
# source_project_arn: "ProjectArn", # required
# source_project_version_arn: "ProjectVersionArn", # required
# destination_project_arn: "ProjectArn", # required
# version_name: "VersionName", # required
# output_config: { # required
# s3_bucket: "S3Bucket",
# s3_key_prefix: "S3KeyPrefix",
# },
# tags: {
# "TagKey" => "TagValue",
# },
# kms_key_id: "KmsKeyId",
# }
#
# @!attribute [rw] source_project_arn
# The ARN of the source project in the trusting AWS account.
# @return [String]
#
# @!attribute [rw] source_project_version_arn
# The ARN of the model version in the source project that you want to
# copy to a destination project.
# @return [String]
#
# @!attribute [rw] destination_project_arn
# The ARN of the project in the trusted AWS account that you want to
# copy the model version to.
# @return [String]
#
# @!attribute [rw] version_name
# A name for the version of the model that's copied to the
# destination project.
# @return [String]
#
# @!attribute [rw] output_config
# The S3 bucket and folder location where the training output for the
# source model version is placed.
# @return [Types::OutputConfig]
#
# @!attribute [rw] tags
# The key-value tags to assign to the model version.
# @return [Hash]
#
# @!attribute [rw] kms_key_id
# The identifier for your AWS Key Management Service key (AWS KMS
# key). You can supply the Amazon Resource Name (ARN) of your KMS key,
# the ID of your KMS key, an alias for your KMS key, or an alias ARN.
# The key is used to encrypt training results and manifest files
# written to the output Amazon S3 bucket (`OutputConfig`).
#
# If you choose to use your own KMS key, you need the following
# permissions on the KMS key.
#
# * kms:CreateGrant
#
# * kms:DescribeKey
#
# * kms:GenerateDataKey
#
# * kms:Decrypt
#
# If you don't specify a value for `KmsKeyId`, images copied into the
# service are encrypted using a key that AWS owns and manages.
# @return [String]
#
class CopyProjectVersionRequest < Struct.new(
:source_project_arn,
:source_project_version_arn,
:destination_project_arn,
:version_name,
:output_config,
:tags,
:kms_key_id)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_version_arn
# The ARN of the copied model version in the destination project.
# @return [String]
#
class CopyProjectVersionResponse < Struct.new(
:project_version_arn)
SENSITIVE = []
include Aws::Structure
end
# Information about an item of Personal Protective Equipment covering a
# corresponding body part. For more information, see
# DetectProtectiveEquipment.
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has in the value of `Value`.
# @return [Float]
#
# @!attribute [rw] value
# True if the PPE covers the corresponding body part, otherwise false.
# @return [Boolean]
#
class CoversBodyPart < Struct.new(
:confidence,
:value)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CreateCollectionRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# tags: {
# "TagKey" => "TagValue",
# },
# }
#
# @!attribute [rw] collection_id
# ID for the collection that you are creating.
# @return [String]
#
# @!attribute [rw] tags
# A set of tags (key-value pairs) that you want to attach to the
# collection.
# @return [Hash]
#
class CreateCollectionRequest < Struct.new(
:collection_id,
:tags)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status_code
# HTTP status code indicating the result of the operation.
# @return [Integer]
#
# @!attribute [rw] collection_arn
# Amazon Resource Name (ARN) of the collection. You can use this to
# manage permissions on your resources.
# @return [String]
#
# @!attribute [rw] face_model_version
# Version number of the face detection model associated with the
# collection you are creating.
# @return [String]
#
class CreateCollectionResponse < Struct.new(
:status_code,
:collection_arn,
:face_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CreateDatasetRequest
# data as a hash:
#
# {
# dataset_source: {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# dataset_arn: "DatasetArn",
# },
# dataset_type: "TRAIN", # required, accepts TRAIN, TEST
# project_arn: "ProjectArn", # required
# }
#
# @!attribute [rw] dataset_source
# The source files for the dataset. You can specify the ARN of an
# existing dataset or specify the Amazon S3 bucket location of an
# Amazon Sagemaker format manifest file. If you don't specify
# `datasetSource`, an empty dataset is created. To add labeled images
# to the dataset, You can use the console or call
# UpdateDatasetEntries.
# @return [Types::DatasetSource]
#
# @!attribute [rw] dataset_type
# The type of the dataset. Specify `train` to create a training
# dataset. Specify `test` to create a test dataset.
# @return [String]
#
# @!attribute [rw] project_arn
# The ARN of the Amazon Rekognition Custom Labels project to which you
# want to asssign the dataset.
# @return [String]
#
class CreateDatasetRequest < Struct.new(
:dataset_source,
:dataset_type,
:project_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] dataset_arn
# The ARN of the created Amazon Rekognition Custom Labels dataset.
# @return [String]
#
class CreateDatasetResponse < Struct.new(
:dataset_arn)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CreateProjectRequest
# data as a hash:
#
# {
# project_name: "ProjectName", # required
# }
#
# @!attribute [rw] project_name
# The name of the project to create.
# @return [String]
#
class CreateProjectRequest < Struct.new(
:project_name)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the new project. You can use the
# ARN to configure IAM access to the project.
# @return [String]
#
class CreateProjectResponse < Struct.new(
:project_arn)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CreateProjectVersionRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# version_name: "VersionName", # required
# output_config: { # required
# s3_bucket: "S3Bucket",
# s3_key_prefix: "S3KeyPrefix",
# },
# training_data: {
# assets: [
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# },
# ],
# },
# testing_data: {
# assets: [
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# },
# ],
# auto_create: false,
# },
# tags: {
# "TagKey" => "TagValue",
# },
# kms_key_id: "KmsKeyId",
# }
#
# @!attribute [rw] project_arn
# The ARN of the Amazon Rekognition Custom Labels project that manages
# the model that you want to train.
# @return [String]
#
# @!attribute [rw] version_name
# A name for the version of the model. This value must be unique.
# @return [String]
#
# @!attribute [rw] output_config
# The Amazon S3 bucket location to store the results of training. The
# S3 bucket can be in any AWS account as long as the caller has
# `s3:PutObject` permissions on the S3 bucket.
# @return [Types::OutputConfig]
#
# @!attribute [rw] training_data
# Specifies an external manifest that the services uses to train the
# model. If you specify `TrainingData` you must also specify
# `TestingData`. The project must not have any associated datasets.
# @return [Types::TrainingData]
#
# @!attribute [rw] testing_data
# Specifies an external manifest that the service uses to test the
# model. If you specify `TestingData` you must also specify
# `TrainingData`. The project must not have any associated datasets.
# @return [Types::TestingData]
#
# @!attribute [rw] tags
# A set of tags (key-value pairs) that you want to attach to the
# model.
# @return [Hash]
#
# @!attribute [rw] kms_key_id
# The identifier for your AWS Key Management Service key (AWS KMS
# key). You can supply the Amazon Resource Name (ARN) of your KMS key,
# the ID of your KMS key, an alias for your KMS key, or an alias ARN.
# The key is used to encrypt training and test images copied into the
# service for model training. Your source images are unaffected. The
# key is also used to encrypt training results and manifest files
# written to the output Amazon S3 bucket (`OutputConfig`).
#
# If you choose to use your own KMS key, you need the following
# permissions on the KMS key.
#
# * kms:CreateGrant
#
# * kms:DescribeKey
#
# * kms:GenerateDataKey
#
# * kms:Decrypt
#
# If you don't specify a value for `KmsKeyId`, images copied into the
# service are encrypted using a key that AWS owns and manages.
# @return [String]
#
class CreateProjectVersionRequest < Struct.new(
:project_arn,
:version_name,
:output_config,
:training_data,
:testing_data,
:tags,
:kms_key_id)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_version_arn
# The ARN of the model version that was created. Use
# `DescribeProjectVersion` to get the current status of the training
# operation.
# @return [String]
#
class CreateProjectVersionResponse < Struct.new(
:project_version_arn)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass CreateStreamProcessorRequest
# data as a hash:
#
# {
# input: { # required
# kinesis_video_stream: {
# arn: "KinesisVideoArn",
# },
# },
# output: { # required
# kinesis_data_stream: {
# arn: "KinesisDataArn",
# },
# s3_destination: {
# bucket: "S3Bucket",
# key_prefix: "S3KeyPrefix",
# },
# },
# name: "StreamProcessorName", # required
# settings: { # required
# face_search: {
# collection_id: "CollectionId",
# face_match_threshold: 1.0,
# },
# connected_home: {
# labels: ["ConnectedHomeLabel"], # required
# min_confidence: 1.0,
# },
# },
# role_arn: "RoleArn", # required
# tags: {
# "TagKey" => "TagValue",
# },
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# },
# kms_key_id: "KmsKeyId",
# regions_of_interest: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# data_sharing_preference: {
# opt_in: false, # required
# },
# }
#
# @!attribute [rw] input
# Kinesis video stream stream that provides the source streaming
# video. If you are using the AWS CLI, the parameter name is
# `StreamProcessorInput`. This is required for both face search and
# label detection stream processors.
# @return [Types::StreamProcessorInput]
#
# @!attribute [rw] output
# Kinesis data stream stream or Amazon S3 bucket location to which
# Amazon Rekognition Video puts the analysis results. If you are using
# the AWS CLI, the parameter name is `StreamProcessorOutput`. This
# must be a S3Destination of an Amazon S3 bucket that you own for a
# label detection stream processor or a Kinesis data stream ARN for a
# face search stream processor.
# @return [Types::StreamProcessorOutput]
#
# @!attribute [rw] name
# An identifier you assign to the stream processor. You can use `Name`
# to manage the stream processor. For example, you can get the current
# status of the stream processor by calling DescribeStreamProcessor.
# `Name` is idempotent. This is required for both face search and
# label detection stream processors.
# @return [String]
#
# @!attribute [rw] settings
# Input parameters used in a streaming video analyzed by a stream
# processor. You can use `FaceSearch` to recognize faces in a
# streaming video, or you can use `ConnectedHome` to detect labels.
# @return [Types::StreamProcessorSettings]
#
# @!attribute [rw] role_arn
# The Amazon Resource Number (ARN) of the IAM role that allows access
# to the stream processor. The IAM role provides Rekognition read
# permissions for a Kinesis stream. It also provides write permissions
# to an Amazon S3 bucket and Amazon Simple Notification Service topic
# for a label detection stream processor. This is required for both
# face search and label detection stream processors.
# @return [String]
#
# @!attribute [rw] tags
# A set of tags (key-value pairs) that you want to attach to the
# stream processor.
# @return [Hash]
#
# @!attribute [rw] notification_channel
# The Amazon Simple Notification Service topic to which Amazon
# Rekognition publishes the object detection results and completion
# status of a video analysis operation.
#
# Amazon Rekognition publishes a notification the first time an object
# of interest or a person is detected in the video stream. For
# example, if Amazon Rekognition detects a person at second 2, a pet
# at second 4, and a person again at second 5, Amazon Rekognition
# sends 2 object class detected notifications, one for a person at
# second 2 and one for a pet at second 4.
#
# Amazon Rekognition also publishes an an end-of-session notification
# with a summary when the stream processing session is complete.
# @return [Types::StreamProcessorNotificationChannel]
#
# @!attribute [rw] kms_key_id
# The identifier for your AWS Key Management Service key (AWS KMS
# key). This is an optional parameter for label detection stream
# processors and should not be used to create a face search stream
# processor. You can supply the Amazon Resource Name (ARN) of your KMS
# key, the ID of your KMS key, an alias for your KMS key, or an alias
# ARN. The key is used to encrypt results and data published to your
# Amazon S3 bucket, which includes image frames and hero images. Your
# source images are unaffected.
# @return [String]
#
# @!attribute [rw] regions_of_interest
# Specifies locations in the frames where Amazon Rekognition checks
# for objects or people. You can specify up to 10 regions of interest,
# and each region has either a polygon or a bounding box. This is an
# optional parameter for label detection stream processors and should
# not be used to create a face search stream processor.
# @return [Array]
#
# @!attribute [rw] data_sharing_preference
# Shows whether you are sharing data with Rekognition to improve model
# performance. You can choose this option at the account level or on a
# per-stream basis. Note that if you opt out at the account level this
# setting is ignored on individual streams.
# @return [Types::StreamProcessorDataSharingPreference]
#
class CreateStreamProcessorRequest < Struct.new(
:input,
:output,
:name,
:settings,
:role_arn,
:tags,
:notification_channel,
:kms_key_id,
:regions_of_interest,
:data_sharing_preference)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] stream_processor_arn
# Amazon Resource Number for the newly created stream processor.
# @return [String]
#
class CreateStreamProcessorResponse < Struct.new(
:stream_processor_arn)
SENSITIVE = []
include Aws::Structure
end
# A custom label detected in an image by a call to DetectCustomLabels.
#
# @!attribute [rw] name
# The name of the custom label.
# @return [String]
#
# @!attribute [rw] confidence
# The confidence that the model has in the detection of the custom
# label. The range is 0-100. A higher value indicates a higher
# confidence.
# @return [Float]
#
# @!attribute [rw] geometry
# The location of the detected object on the image that corresponds to
# the custom label. Includes an axis aligned coarse bounding box
# surrounding the object and a finer grain polygon for more accurate
# spatial information.
# @return [Types::Geometry]
#
class CustomLabel < Struct.new(
:name,
:confidence,
:geometry)
SENSITIVE = []
include Aws::Structure
end
# Describes updates or additions to a dataset. A Single update or
# addition is an entry (JSON Line) that provides information about a
# single image. To update an existing entry, you match the `source-ref`
# field of the update entry with the `source-ref` filed of the entry
# that you want to update. If the `source-ref` field doesn't match an
# existing entry, the entry is added to dataset as a new entry.
#
# @note When making an API call, you may pass DatasetChanges
# data as a hash:
#
# {
# ground_truth: "data", # required
# }
#
# @!attribute [rw] ground_truth
# A Base64-encoded binary data object containing one or JSON lines
# that either update the dataset or are additions to the dataset. You
# change a dataset by calling UpdateDatasetEntries. If you are using
# an AWS SDK to call `UpdateDatasetEntries`, you don't need to encode
# `Changes` as the SDK encodes the data for you.
#
# For example JSON lines, see Image-Level labels in manifest files and
# and Object localization in manifest files in the *Amazon Rekognition
# Custom Labels Developer Guide*.
# @return [String]
#
class DatasetChanges < Struct.new(
:ground_truth)
SENSITIVE = []
include Aws::Structure
end
# A description for a dataset. For more information, see
# DescribeDataset.
#
# The status fields `Status`, `StatusMessage`, and `StatusMessageCode`
# reflect the last operation on the dataset.
#
# @!attribute [rw] creation_timestamp
# The Unix timestamp for the time and date that the dataset was
# created.
# @return [Time]
#
# @!attribute [rw] last_updated_timestamp
# The Unix timestamp for the date and time that the dataset was last
# updated.
# @return [Time]
#
# @!attribute [rw] status
# The status of the dataset.
# @return [String]
#
# @!attribute [rw] status_message
# The status message for the dataset.
# @return [String]
#
# @!attribute [rw] status_message_code
# The status message code for the dataset operation. If a service
# error occurs, try the API call again later. If a client error
# occurs, check the input parameters to the dataset API call that
# failed.
# @return [String]
#
# @!attribute [rw] dataset_stats
# The status message code for the dataset.
# @return [Types::DatasetStats]
#
class DatasetDescription < Struct.new(
:creation_timestamp,
:last_updated_timestamp,
:status,
:status_message,
:status_message_code,
:dataset_stats)
SENSITIVE = []
include Aws::Structure
end
# Describes a dataset label. For more information, see
# ListDatasetLabels.
#
# @!attribute [rw] label_name
# The name of the label.
# @return [String]
#
# @!attribute [rw] label_stats
# Statistics about the label.
# @return [Types::DatasetLabelStats]
#
class DatasetLabelDescription < Struct.new(
:label_name,
:label_stats)
SENSITIVE = []
include Aws::Structure
end
# Statistics about a label used in a dataset. For more information, see
# DatasetLabelDescription.
#
# @!attribute [rw] entry_count
# The total number of images that use the label.
# @return [Integer]
#
# @!attribute [rw] bounding_box_count
# The total number of images that have the label assigned to a
# bounding box.
# @return [Integer]
#
class DatasetLabelStats < Struct.new(
:entry_count,
:bounding_box_count)
SENSITIVE = []
include Aws::Structure
end
# Summary information for an Amazon Rekognition Custom Labels dataset.
# For more information, see ProjectDescription.
#
# @!attribute [rw] creation_timestamp
# The Unix timestamp for the date and time that the dataset was
# created.
# @return [Time]
#
# @!attribute [rw] dataset_type
# The type of the dataset.
# @return [String]
#
# @!attribute [rw] dataset_arn
# The Amazon Resource Name (ARN) for the dataset.
# @return [String]
#
# @!attribute [rw] status
# The status for the dataset.
# @return [String]
#
# @!attribute [rw] status_message
# The status message for the dataset.
# @return [String]
#
# @!attribute [rw] status_message_code
# The status message code for the dataset operation. If a service
# error occurs, try the API call again later. If a client error
# occurs, check the input parameters to the dataset API call that
# failed.
# @return [String]
#
class DatasetMetadata < Struct.new(
:creation_timestamp,
:dataset_type,
:dataset_arn,
:status,
:status_message,
:status_message_code)
SENSITIVE = []
include Aws::Structure
end
# The source that Amazon Rekognition Custom Labels uses to create a
# dataset. To use an Amazon Sagemaker format manifest file, specify the
# S3 bucket location in the `GroundTruthManifest` field. The S3 bucket
# must be in your AWS account. To create a copy of an existing dataset,
# specify the Amazon Resource Name (ARN) of an existing dataset in
# `DatasetArn`.
#
# You need to specify a value for `DatasetArn` or `GroundTruthManifest`,
# but not both. if you supply both values, or if you don't specify any
# values, an InvalidParameterException exception occurs.
#
# For more information, see CreateDataset.
#
# @note When making an API call, you may pass DatasetSource
# data as a hash:
#
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# dataset_arn: "DatasetArn",
# }
#
# @!attribute [rw] ground_truth_manifest
# The S3 bucket that contains an Amazon Sagemaker Ground Truth format
# manifest file.
# @return [Types::GroundTruthManifest]
#
# @!attribute [rw] dataset_arn
# The ARN of an Amazon Rekognition Custom Labels dataset that you want
# to copy.
# @return [String]
#
class DatasetSource < Struct.new(
:ground_truth_manifest,
:dataset_arn)
SENSITIVE = []
include Aws::Structure
end
# Provides statistics about a dataset. For more information, see
# DescribeDataset.
#
# @!attribute [rw] labeled_entries
# The total number of images in the dataset that have labels.
# @return [Integer]
#
# @!attribute [rw] total_entries
# The total number of images in the dataset.
# @return [Integer]
#
# @!attribute [rw] total_labels
# The total number of labels declared in the dataset.
# @return [Integer]
#
# @!attribute [rw] error_entries
# The total number of entries that contain at least one error.
# @return [Integer]
#
class DatasetStats < Struct.new(
:labeled_entries,
:total_entries,
:total_labels,
:error_entries)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DeleteCollectionRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# }
#
# @!attribute [rw] collection_id
# ID of the collection to delete.
# @return [String]
#
class DeleteCollectionRequest < Struct.new(
:collection_id)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status_code
# HTTP status code that indicates the result of the operation.
# @return [Integer]
#
class DeleteCollectionResponse < Struct.new(
:status_code)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DeleteDatasetRequest
# data as a hash:
#
# {
# dataset_arn: "DatasetArn", # required
# }
#
# @!attribute [rw] dataset_arn
# The ARN of the Amazon Rekognition Custom Labels dataset that you
# want to delete.
# @return [String]
#
class DeleteDatasetRequest < Struct.new(
:dataset_arn)
SENSITIVE = []
include Aws::Structure
end
class DeleteDatasetResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass DeleteFacesRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# face_ids: ["FaceId"], # required
# }
#
# @!attribute [rw] collection_id
# Collection from which to remove the specific faces.
# @return [String]
#
# @!attribute [rw] face_ids
# An array of face IDs to delete.
# @return [Array]
#
class DeleteFacesRequest < Struct.new(
:collection_id,
:face_ids)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] deleted_faces
# An array of strings (face IDs) of the faces that were deleted.
# @return [Array]
#
class DeleteFacesResponse < Struct.new(
:deleted_faces)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DeleteProjectPolicyRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# policy_name: "ProjectPolicyName", # required
# policy_revision_id: "ProjectPolicyRevisionId",
# }
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project that the project
# policy you want to delete is attached to.
# @return [String]
#
# @!attribute [rw] policy_name
# The name of the policy that you want to delete.
# @return [String]
#
# @!attribute [rw] policy_revision_id
# The ID of the project policy revision that you want to delete.
# @return [String]
#
class DeleteProjectPolicyRequest < Struct.new(
:project_arn,
:policy_name,
:policy_revision_id)
SENSITIVE = []
include Aws::Structure
end
class DeleteProjectPolicyResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass DeleteProjectRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# }
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project that you want to
# delete.
# @return [String]
#
class DeleteProjectRequest < Struct.new(
:project_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status
# The current status of the delete project operation.
# @return [String]
#
class DeleteProjectResponse < Struct.new(
:status)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DeleteProjectVersionRequest
# data as a hash:
#
# {
# project_version_arn: "ProjectVersionArn", # required
# }
#
# @!attribute [rw] project_version_arn
# The Amazon Resource Name (ARN) of the model version that you want to
# delete.
# @return [String]
#
class DeleteProjectVersionRequest < Struct.new(
:project_version_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status
# The status of the deletion operation.
# @return [String]
#
class DeleteProjectVersionResponse < Struct.new(
:status)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DeleteStreamProcessorRequest
# data as a hash:
#
# {
# name: "StreamProcessorName", # required
# }
#
# @!attribute [rw] name
# The name of the stream processor you want to delete.
# @return [String]
#
class DeleteStreamProcessorRequest < Struct.new(
:name)
SENSITIVE = []
include Aws::Structure
end
class DeleteStreamProcessorResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass DescribeCollectionRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# }
#
# @!attribute [rw] collection_id
# The ID of the collection to describe.
# @return [String]
#
class DescribeCollectionRequest < Struct.new(
:collection_id)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] face_count
# The number of faces that are indexed into the collection. To index
# faces into a collection, use IndexFaces.
# @return [Integer]
#
# @!attribute [rw] face_model_version
# The version of the face model that's used by the collection for
# face detection.
#
# For more information, see Model versioning in the Amazon Rekognition
# Developer Guide.
# @return [String]
#
# @!attribute [rw] collection_arn
# The Amazon Resource Name (ARN) of the collection.
# @return [String]
#
# @!attribute [rw] creation_timestamp
# The number of milliseconds since the Unix epoch time until the
# creation of the collection. The Unix epoch time is 00:00:00
# Coordinated Universal Time (UTC), Thursday, 1 January 1970.
# @return [Time]
#
class DescribeCollectionResponse < Struct.new(
:face_count,
:face_model_version,
:collection_arn,
:creation_timestamp)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DescribeDatasetRequest
# data as a hash:
#
# {
# dataset_arn: "DatasetArn", # required
# }
#
# @!attribute [rw] dataset_arn
# The Amazon Resource Name (ARN) of the dataset that you want to
# describe.
# @return [String]
#
class DescribeDatasetRequest < Struct.new(
:dataset_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] dataset_description
# The description for the dataset.
# @return [Types::DatasetDescription]
#
class DescribeDatasetResponse < Struct.new(
:dataset_description)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DescribeProjectVersionsRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# version_names: ["VersionName"],
# next_token: "ExtendedPaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project that contains the
# models you want to describe.
# @return [String]
#
# @!attribute [rw] version_names
# A list of model version names that you want to describe. You can add
# up to 10 model version names to the list. If you don't specify a
# value, all model descriptions are returned. A version name is part
# of a model (ProjectVersion) ARN. For example,
# `my-model.2020-01-21T09.10.15` is the version name in the following
# ARN.
# `arn:aws:rekognition:us-east-1:123456789012:project/getting-started/version/my-model.2020-01-21T09.10.15/1234567890123`.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
# @!attribute [rw] max_results
# The maximum number of results to return per paginated call. The
# largest value you can specify is 100. If you specify a value greater
# than 100, a ValidationException error occurs. The default value is
# 100.
# @return [Integer]
#
class DescribeProjectVersionsRequest < Struct.new(
:project_arn,
:version_names,
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_version_descriptions
# A list of model descriptions. The list is sorted by the creation
# date and time of the model versions, latest to earliest.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
class DescribeProjectVersionsResponse < Struct.new(
:project_version_descriptions,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DescribeProjectsRequest
# data as a hash:
#
# {
# next_token: "ExtendedPaginationToken",
# max_results: 1,
# project_names: ["ProjectName"],
# }
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
# @!attribute [rw] max_results
# The maximum number of results to return per paginated call. The
# largest value you can specify is 100. If you specify a value greater
# than 100, a ValidationException error occurs. The default value is
# 100.
# @return [Integer]
#
# @!attribute [rw] project_names
# A list of the projects that you want Amazon Rekognition Custom
# Labels to describe. If you don't specify a value, the response
# includes descriptions for all the projects in your AWS account.
# @return [Array]
#
class DescribeProjectsRequest < Struct.new(
:next_token,
:max_results,
:project_names)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_descriptions
# A list of project descriptions. The list is sorted by the date and
# time the projects are created.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
class DescribeProjectsResponse < Struct.new(
:project_descriptions,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DescribeStreamProcessorRequest
# data as a hash:
#
# {
# name: "StreamProcessorName", # required
# }
#
# @!attribute [rw] name
# Name of the stream processor for which you want information.
# @return [String]
#
class DescribeStreamProcessorRequest < Struct.new(
:name)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] name
# Name of the stream processor.
# @return [String]
#
# @!attribute [rw] stream_processor_arn
# ARN of the stream processor.
# @return [String]
#
# @!attribute [rw] status
# Current status of the stream processor.
# @return [String]
#
# @!attribute [rw] status_message
# Detailed status message about the stream processor.
# @return [String]
#
# @!attribute [rw] creation_timestamp
# Date and time the stream processor was created
# @return [Time]
#
# @!attribute [rw] last_update_timestamp
# The time, in Unix format, the stream processor was last updated. For
# example, when the stream processor moves from a running state to a
# failed state, or when the user starts or stops the stream processor.
# @return [Time]
#
# @!attribute [rw] input
# Kinesis video stream that provides the source streaming video.
# @return [Types::StreamProcessorInput]
#
# @!attribute [rw] output
# Kinesis data stream to which Amazon Rekognition Video puts the
# analysis results.
# @return [Types::StreamProcessorOutput]
#
# @!attribute [rw] role_arn
# ARN of the IAM role that allows access to the stream processor.
# @return [String]
#
# @!attribute [rw] settings
# Input parameters used in a streaming video analyzed by a stream
# processor. You can use `FaceSearch` to recognize faces in a
# streaming video, or you can use `ConnectedHome` to detect labels.
# @return [Types::StreamProcessorSettings]
#
# @!attribute [rw] notification_channel
# The Amazon Simple Notification Service topic to which Amazon
# Rekognition publishes the object detection results and completion
# status of a video analysis operation.
#
# Amazon Rekognition publishes a notification the first time an object
# of interest or a person is detected in the video stream. For
# example, if Amazon Rekognition detects a person at second 2, a pet
# at second 4, and a person again at second 5, Amazon Rekognition
# sends 2 object class detected notifications, one for a person at
# second 2 and one for a pet at second 4.
#
# Amazon Rekognition also publishes an an end-of-session notification
# with a summary when the stream processing session is complete.
# @return [Types::StreamProcessorNotificationChannel]
#
# @!attribute [rw] kms_key_id
# The identifier for your AWS Key Management Service key (AWS KMS
# key). This is an optional parameter for label detection stream
# processors.
# @return [String]
#
# @!attribute [rw] regions_of_interest
# Specifies locations in the frames where Amazon Rekognition checks
# for objects or people. This is an optional parameter for label
# detection stream processors.
# @return [Array]
#
# @!attribute [rw] data_sharing_preference
# Shows whether you are sharing data with Rekognition to improve model
# performance. You can choose this option at the account level or on a
# per-stream basis. Note that if you opt out at the account level this
# setting is ignored on individual streams.
# @return [Types::StreamProcessorDataSharingPreference]
#
class DescribeStreamProcessorResponse < Struct.new(
:name,
:stream_processor_arn,
:status,
:status_message,
:creation_timestamp,
:last_update_timestamp,
:input,
:output,
:role_arn,
:settings,
:notification_channel,
:kms_key_id,
:regions_of_interest,
:data_sharing_preference)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectCustomLabelsRequest
# data as a hash:
#
# {
# project_version_arn: "ProjectVersionArn", # required
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# max_results: 1,
# min_confidence: 1.0,
# }
#
# @!attribute [rw] project_version_arn
# The ARN of the model version that you want to use.
# @return [String]
#
# @!attribute [rw] image
# Provides the input image either as bytes or an S3 object.
#
# You pass image bytes to an Amazon Rekognition API operation by using
# the `Bytes` property. For example, you would use the `Bytes`
# property to pass an image loaded from a local file system. Image
# bytes passed by using the `Bytes` property must be base64-encoded.
# Your code may not need to encode image bytes if you are using an AWS
# SDK to call Amazon Rekognition API operations.
#
# For more information, see Analyzing an Image Loaded from a Local
# File System in the Amazon Rekognition Developer Guide.
#
# You pass images stored in an S3 bucket to an Amazon Rekognition API
# operation by using the `S3Object` property. Images stored in an S3
# bucket do not need to be base64-encoded.
#
# The region for the S3 bucket containing the S3 object must match the
# region you use for Amazon Rekognition operations.
#
# If you use the AWS CLI to call Amazon Rekognition operations,
# passing image bytes using the Bytes property is not supported. You
# must first upload the image to an Amazon S3 bucket and then call the
# operation using the S3Object property.
#
# For Amazon Rekognition to process an S3 object, the user must have
# permission to access the S3 object. For more information, see How
# Amazon Rekognition works with IAM in the Amazon Rekognition
# Developer Guide.
# @return [Types::Image]
#
# @!attribute [rw] max_results
# Maximum number of results you want the service to return in the
# response. The service returns the specified number of highest
# confidence labels ranked from highest confidence to lowest.
# @return [Integer]
#
# @!attribute [rw] min_confidence
# Specifies the minimum confidence level for the labels to return.
# `DetectCustomLabels` doesn't return any labels with a confidence
# value that's lower than this specified value. If you specify a
# value of 0, `DetectCustomLabels` returns all labels, regardless of
# the assumed threshold applied to each label. If you don't specify a
# value for `MinConfidence`, `DetectCustomLabels` returns labels based
# on the assumed threshold of each label.
# @return [Float]
#
class DetectCustomLabelsRequest < Struct.new(
:project_version_arn,
:image,
:max_results,
:min_confidence)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] custom_labels
# An array of custom labels detected in the input image.
# @return [Array]
#
class DetectCustomLabelsResponse < Struct.new(
:custom_labels)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectFacesRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# attributes: ["DEFAULT"], # accepts DEFAULT, ALL
# }
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] attributes
# An array of facial attributes you want to be returned. This can be
# the default list of attributes or all attributes. If you don't
# specify a value for `Attributes` or if you specify `["DEFAULT"]`,
# the API returns the following subset of facial attributes:
# `BoundingBox`, `Confidence`, `Pose`, `Quality`, and `Landmarks`. If
# you provide `["ALL"]`, all facial attributes are returned, but the
# operation takes longer to complete.
#
# If you provide both, `["ALL", "DEFAULT"]`, the service uses a
# logical AND operator to determine which attributes to return (in
# this case, all attributes).
# @return [Array]
#
class DetectFacesRequest < Struct.new(
:image,
:attributes)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] face_details
# Details of each face found in the image.
# @return [Array]
#
# @!attribute [rw] orientation_correction
# The value of `OrientationCorrection` is always null.
#
# If the input image is in .jpeg format, it might contain exchangeable
# image file format (Exif) metadata that includes the image's
# orientation. Amazon Rekognition uses this orientation information to
# perform image correction. The bounding box coordinates are
# translated to represent object locations after the orientation
# information in the Exif metadata is used to correct the image
# orientation. Images in .png format don't contain Exif metadata.
#
# Amazon Rekognition doesn’t perform image correction for images in
# .png format and .jpeg images without orientation information in the
# image Exif metadata. The bounding box coordinates aren't translated
# and represent the object locations before the image is rotated.
# @return [String]
#
class DetectFacesResponse < Struct.new(
:face_details,
:orientation_correction)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectLabelsRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# max_labels: 1,
# min_confidence: 1.0,
# }
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing image
# bytes is not supported. Images stored in an S3 Bucket do not need to
# be base64-encoded.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] max_labels
# Maximum number of labels you want the service to return in the
# response. The service returns the specified number of highest
# confidence labels.
# @return [Integer]
#
# @!attribute [rw] min_confidence
# Specifies the minimum confidence level for the labels to return.
# Amazon Rekognition doesn't return any labels with confidence lower
# than this specified value.
#
# If `MinConfidence` is not specified, the operation returns labels
# with a confidence values greater than or equal to 55 percent.
# @return [Float]
#
class DetectLabelsRequest < Struct.new(
:image,
:max_labels,
:min_confidence)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] labels
# An array of labels for the real-world objects detected.
# @return [Array]
#
# @!attribute [rw] orientation_correction
# The value of `OrientationCorrection` is always null.
#
# If the input image is in .jpeg format, it might contain exchangeable
# image file format (Exif) metadata that includes the image's
# orientation. Amazon Rekognition uses this orientation information to
# perform image correction. The bounding box coordinates are
# translated to represent object locations after the orientation
# information in the Exif metadata is used to correct the image
# orientation. Images in .png format don't contain Exif metadata.
#
# Amazon Rekognition doesn’t perform image correction for images in
# .png format and .jpeg images without orientation information in the
# image Exif metadata. The bounding box coordinates aren't translated
# and represent the object locations before the image is rotated.
# @return [String]
#
# @!attribute [rw] label_model_version
# Version number of the label detection model that was used to detect
# labels.
# @return [String]
#
class DetectLabelsResponse < Struct.new(
:labels,
:orientation_correction,
:label_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectModerationLabelsRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# min_confidence: 1.0,
# human_loop_config: {
# human_loop_name: "HumanLoopName", # required
# flow_definition_arn: "FlowDefinitionArn", # required
# data_attributes: {
# content_classifiers: ["FreeOfPersonallyIdentifiableInformation"], # accepts FreeOfPersonallyIdentifiableInformation, FreeOfAdultContent
# },
# },
# }
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] min_confidence
# Specifies the minimum confidence level for the labels to return.
# Amazon Rekognition doesn't return any labels with a confidence
# level lower than this specified value.
#
# If you don't specify `MinConfidence`, the operation returns labels
# with confidence values greater than or equal to 50 percent.
# @return [Float]
#
# @!attribute [rw] human_loop_config
# Sets up the configuration for human evaluation, including the
# FlowDefinition the image will be sent to.
# @return [Types::HumanLoopConfig]
#
class DetectModerationLabelsRequest < Struct.new(
:image,
:min_confidence,
:human_loop_config)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] moderation_labels
# Array of detected Moderation labels and the time, in milliseconds
# from the start of the video, they were detected.
# @return [Array]
#
# @!attribute [rw] moderation_model_version
# Version number of the moderation detection model that was used to
# detect unsafe content.
# @return [String]
#
# @!attribute [rw] human_loop_activation_output
# Shows the results of the human in the loop evaluation.
# @return [Types::HumanLoopActivationOutput]
#
class DetectModerationLabelsResponse < Struct.new(
:moderation_labels,
:moderation_model_version,
:human_loop_activation_output)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectProtectiveEquipmentRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# summarization_attributes: {
# min_confidence: 1.0, # required
# required_equipment_types: ["FACE_COVER"], # required, accepts FACE_COVER, HAND_COVER, HEAD_COVER
# },
# }
#
# @!attribute [rw] image
# The image in which you want to detect PPE on detected persons. The
# image can be passed as image bytes or you can reference an image
# stored in an Amazon S3 bucket.
# @return [Types::Image]
#
# @!attribute [rw] summarization_attributes
# An array of PPE types that you want to summarize.
# @return [Types::ProtectiveEquipmentSummarizationAttributes]
#
class DetectProtectiveEquipmentRequest < Struct.new(
:image,
:summarization_attributes)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] protective_equipment_model_version
# The version number of the PPE detection model used to detect PPE in
# the image.
# @return [String]
#
# @!attribute [rw] persons
# An array of persons detected in the image (including persons not
# wearing PPE).
# @return [Array]
#
# @!attribute [rw] summary
# Summary information for the types of PPE specified in the
# `SummarizationAttributes` input parameter.
# @return [Types::ProtectiveEquipmentSummary]
#
class DetectProtectiveEquipmentResponse < Struct.new(
:protective_equipment_model_version,
:persons,
:summary)
SENSITIVE = []
include Aws::Structure
end
# A set of optional parameters that you can use to set the criteria that
# the text must meet to be included in your response. `WordFilter` looks
# at a word’s height, width, and minimum confidence. `RegionOfInterest`
# lets you set a specific region of the image to look for text in.
#
# @note When making an API call, you may pass DetectTextFilters
# data as a hash:
#
# {
# word_filter: {
# min_confidence: 1.0,
# min_bounding_box_height: 1.0,
# min_bounding_box_width: 1.0,
# },
# regions_of_interest: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# }
#
# @!attribute [rw] word_filter
# A set of parameters that allow you to filter out certain results
# from your returned results.
# @return [Types::DetectionFilter]
#
# @!attribute [rw] regions_of_interest
# A Filter focusing on a certain area of the image. Uses a
# `BoundingBox` object to set the region of the image.
# @return [Array]
#
class DetectTextFilters < Struct.new(
:word_filter,
:regions_of_interest)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DetectTextRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# filters: {
# word_filter: {
# min_confidence: 1.0,
# min_bounding_box_height: 1.0,
# min_bounding_box_width: 1.0,
# },
# regions_of_interest: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# },
# }
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an Amazon S3 object. If
# you use the AWS CLI to call Amazon Rekognition operations, you
# can't pass image bytes.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] filters
# Optional parameters that let you set the criteria that the text must
# meet to be included in your response.
# @return [Types::DetectTextFilters]
#
class DetectTextRequest < Struct.new(
:image,
:filters)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] text_detections
# An array of text that was detected in the input image.
# @return [Array]
#
# @!attribute [rw] text_model_version
# The model version used to detect text.
# @return [String]
#
class DetectTextResponse < Struct.new(
:text_detections,
:text_model_version)
SENSITIVE = []
include Aws::Structure
end
# A set of parameters that allow you to filter out certain results from
# your returned results.
#
# @note When making an API call, you may pass DetectionFilter
# data as a hash:
#
# {
# min_confidence: 1.0,
# min_bounding_box_height: 1.0,
# min_bounding_box_width: 1.0,
# }
#
# @!attribute [rw] min_confidence
# Sets the confidence of word detection. Words with detection
# confidence below this will be excluded from the result. Values
# should be between 0 and 100. The default MinConfidence is 80.
# @return [Float]
#
# @!attribute [rw] min_bounding_box_height
# Sets the minimum height of the word bounding box. Words with
# bounding box heights lesser than this value will be excluded from
# the result. Value is relative to the video frame height.
# @return [Float]
#
# @!attribute [rw] min_bounding_box_width
# Sets the minimum width of the word bounding box. Words with bounding
# boxes widths lesser than this value will be excluded from the
# result. Value is relative to the video frame width.
# @return [Float]
#
class DetectionFilter < Struct.new(
:min_confidence,
:min_bounding_box_height,
:min_bounding_box_width)
SENSITIVE = []
include Aws::Structure
end
# A training dataset or a test dataset used in a dataset distribution
# operation. For more information, see DistributeDatasetEntries.
#
# @note When making an API call, you may pass DistributeDataset
# data as a hash:
#
# {
# arn: "DatasetArn", # required
# }
#
# @!attribute [rw] arn
# The Amazon Resource Name (ARN) of the dataset that you want to use.
# @return [String]
#
class DistributeDataset < Struct.new(
:arn)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass DistributeDatasetEntriesRequest
# data as a hash:
#
# {
# datasets: [ # required
# {
# arn: "DatasetArn", # required
# },
# ],
# }
#
# @!attribute [rw] datasets
# The ARNS for the training dataset and test dataset that you want to
# use. The datasets must belong to the same project. The test dataset
# must be empty.
# @return [Array]
#
class DistributeDatasetEntriesRequest < Struct.new(
:datasets)
SENSITIVE = []
include Aws::Structure
end
class DistributeDatasetEntriesResponse < Aws::EmptyStructure; end
# The emotions that appear to be expressed on the face, and the
# confidence level in the determination. The API is only making a
# determination of the physical appearance of a person's face. It is
# not a determination of the person’s internal emotional state and
# should not be used in such a way. For example, a person pretending to
# have a sad face might not be sad emotionally.
#
# @!attribute [rw] type
# Type of emotion detected.
# @return [String]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Emotion < Struct.new(
:type,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Information about an item of Personal Protective Equipment (PPE)
# detected by DetectProtectiveEquipment. For more information, see
# DetectProtectiveEquipment.
#
# @!attribute [rw] bounding_box
# A bounding box surrounding the item of detected PPE.
# @return [Types::BoundingBox]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has that the bounding box
# (`BoundingBox`) contains an item of PPE.
# @return [Float]
#
# @!attribute [rw] type
# The type of detected PPE.
# @return [String]
#
# @!attribute [rw] covers_body_part
# Information about the body part covered by the detected PPE.
# @return [Types::CoversBodyPart]
#
class EquipmentDetection < Struct.new(
:bounding_box,
:confidence,
:type,
:covers_body_part)
SENSITIVE = []
include Aws::Structure
end
# The evaluation results for the training of a model.
#
# @!attribute [rw] f1_score
# The F1 score for the evaluation of all labels. The F1 score metric
# evaluates the overall precision and recall performance of the model
# as a single value. A higher value indicates better precision and
# recall performance. A lower score indicates that precision, recall,
# or both are performing poorly.
# @return [Float]
#
# @!attribute [rw] summary
# The S3 bucket that contains the training summary.
# @return [Types::Summary]
#
class EvaluationResult < Struct.new(
:f1_score,
:summary)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the eyes on the face are open, and the
# confidence level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the eyes on the face are open.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class EyeOpen < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the face is wearing eye glasses, and the
# confidence level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the face is wearing eye glasses
# or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Eyeglasses < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Describes the face properties such as the bounding box, face ID, image
# ID of the input image, and external image ID that you assigned.
#
# @!attribute [rw] face_id
# Unique identifier that Amazon Rekognition assigns to the face.
# @return [String]
#
# @!attribute [rw] bounding_box
# Bounding box of the face.
# @return [Types::BoundingBox]
#
# @!attribute [rw] image_id
# Unique identifier that Amazon Rekognition assigns to the input
# image.
# @return [String]
#
# @!attribute [rw] external_image_id
# Identifier that you assign to all the faces in the input image.
# @return [String]
#
# @!attribute [rw] confidence
# Confidence level that the bounding box contains a face (and not a
# different object such as a tree).
# @return [Float]
#
# @!attribute [rw] index_faces_model_version
# The version of the face detect and storage model that was used when
# indexing the face vector.
# @return [String]
#
class Face < Struct.new(
:face_id,
:bounding_box,
:image_id,
:external_image_id,
:confidence,
:index_faces_model_version)
SENSITIVE = []
include Aws::Structure
end
# Structure containing attributes of the face that the algorithm
# detected.
#
# A `FaceDetail` object contains either the default facial attributes or
# all facial attributes. The default attributes are `BoundingBox`,
# `Confidence`, `Landmarks`, `Pose`, and `Quality`.
#
# GetFaceDetection is the only Amazon Rekognition Video stored video
# operation that can return a `FaceDetail` object with all attributes.
# To specify which attributes to return, use the `FaceAttributes` input
# parameter for StartFaceDetection. The following Amazon Rekognition
# Video operations return only the default attributes. The corresponding
# Start operations don't have a `FaceAttributes` input parameter.
#
# * GetCelebrityRecognition
#
# * GetPersonTracking
#
# * GetFaceSearch
#
# The Amazon Rekognition Image DetectFaces and IndexFaces operations can
# return all facial attributes. To specify which attributes to return,
# use the `Attributes` input parameter for `DetectFaces`. For
# `IndexFaces`, use the `DetectAttributes` input parameter.
#
# @!attribute [rw] bounding_box
# Bounding box of the face. Default attribute.
# @return [Types::BoundingBox]
#
# @!attribute [rw] age_range
# The estimated age range, in years, for the face. Low represents the
# lowest estimated age and High represents the highest estimated age.
# @return [Types::AgeRange]
#
# @!attribute [rw] smile
# Indicates whether or not the face is smiling, and the confidence
# level in the determination.
# @return [Types::Smile]
#
# @!attribute [rw] eyeglasses
# Indicates whether or not the face is wearing eye glasses, and the
# confidence level in the determination.
# @return [Types::Eyeglasses]
#
# @!attribute [rw] sunglasses
# Indicates whether or not the face is wearing sunglasses, and the
# confidence level in the determination.
# @return [Types::Sunglasses]
#
# @!attribute [rw] gender
# The predicted gender of a detected face.
# @return [Types::Gender]
#
# @!attribute [rw] beard
# Indicates whether or not the face has a beard, and the confidence
# level in the determination.
# @return [Types::Beard]
#
# @!attribute [rw] mustache
# Indicates whether or not the face has a mustache, and the confidence
# level in the determination.
# @return [Types::Mustache]
#
# @!attribute [rw] eyes_open
# Indicates whether or not the eyes on the face are open, and the
# confidence level in the determination.
# @return [Types::EyeOpen]
#
# @!attribute [rw] mouth_open
# Indicates whether or not the mouth on the face is open, and the
# confidence level in the determination.
# @return [Types::MouthOpen]
#
# @!attribute [rw] emotions
# The emotions that appear to be expressed on the face, and the
# confidence level in the determination. The API is only making a
# determination of the physical appearance of a person's face. It is
# not a determination of the person’s internal emotional state and
# should not be used in such a way. For example, a person pretending
# to have a sad face might not be sad emotionally.
# @return [Array]
#
# @!attribute [rw] landmarks
# Indicates the location of landmarks on the face. Default attribute.
# @return [Array]
#
# @!attribute [rw] pose
# Indicates the pose of the face as determined by its pitch, roll, and
# yaw. Default attribute.
# @return [Types::Pose]
#
# @!attribute [rw] quality
# Identifies image brightness and sharpness. Default attribute.
# @return [Types::ImageQuality]
#
# @!attribute [rw] confidence
# Confidence level that the bounding box contains a face (and not a
# different object such as a tree). Default attribute.
# @return [Float]
#
class FaceDetail < Struct.new(
:bounding_box,
:age_range,
:smile,
:eyeglasses,
:sunglasses,
:gender,
:beard,
:mustache,
:eyes_open,
:mouth_open,
:emotions,
:landmarks,
:pose,
:quality,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Information about a face detected in a video analysis request and the
# time the face was detected in the video.
#
# @!attribute [rw] timestamp
# Time, in milliseconds from the start of the video, that the face was
# detected.
# @return [Integer]
#
# @!attribute [rw] face
# The face properties for the detected face.
# @return [Types::FaceDetail]
#
class FaceDetection < Struct.new(
:timestamp,
:face)
SENSITIVE = []
include Aws::Structure
end
# Provides face metadata. In addition, it also provides the confidence
# in the match of this face with the input face.
#
# @!attribute [rw] similarity
# Confidence in the match of this face with the input face.
# @return [Float]
#
# @!attribute [rw] face
# Describes the face properties such as the bounding box, face ID,
# image ID of the source image, and external image ID that you
# assigned.
# @return [Types::Face]
#
class FaceMatch < Struct.new(
:similarity,
:face)
SENSITIVE = []
include Aws::Structure
end
# Object containing both the face metadata (stored in the backend
# database), and facial attributes that are detected but aren't stored
# in the database.
#
# @!attribute [rw] face
# Describes the face properties such as the bounding box, face ID,
# image ID of the input image, and external image ID that you
# assigned.
# @return [Types::Face]
#
# @!attribute [rw] face_detail
# Structure containing attributes of the face that the algorithm
# detected.
# @return [Types::FaceDetail]
#
class FaceRecord < Struct.new(
:face,
:face_detail)
SENSITIVE = []
include Aws::Structure
end
# Input face recognition parameters for an Amazon Rekognition stream
# processor. Includes the collection to use for face recognition and the
# face attributes to detect. Defining the settings is required in the
# request parameter for CreateStreamProcessor.
#
# @note When making an API call, you may pass FaceSearchSettings
# data as a hash:
#
# {
# collection_id: "CollectionId",
# face_match_threshold: 1.0,
# }
#
# @!attribute [rw] collection_id
# The ID of a collection that contains faces that you want to search
# for.
# @return [String]
#
# @!attribute [rw] face_match_threshold
# Minimum face match confidence score that must be met to return a
# result for a recognized face. The default is 80. 0 is the lowest
# confidence. 100 is the highest confidence. Values between 0 and 100
# are accepted, and values lower than 80 are set to 80.
# @return [Float]
#
class FaceSearchSettings < Struct.new(
:collection_id,
:face_match_threshold)
SENSITIVE = []
include Aws::Structure
end
# The predicted gender of a detected face.
#
# Amazon Rekognition makes gender binary (male/female) predictions based
# on the physical appearance of a face in a particular image. This kind
# of prediction is not designed to categorize a person’s gender
# identity, and you shouldn't use Amazon Rekognition to make such a
# determination. For example, a male actor wearing a long-haired wig and
# earrings for a role might be predicted as female.
#
# Using Amazon Rekognition to make gender binary predictions is best
# suited for use cases where aggregate gender distribution statistics
# need to be analyzed without identifying specific users. For example,
# the percentage of female users compared to male users on a social
# media platform.
#
# We don't recommend using gender binary predictions to make decisions
# that impact an individual's rights, privacy, or access to services.
#
# @!attribute [rw] value
# The predicted gender of the face.
# @return [String]
#
# @!attribute [rw] confidence
# Level of confidence in the prediction.
# @return [Float]
#
class Gender < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Information about where an object (DetectCustomLabels) or text
# (DetectText) is located on an image.
#
# @!attribute [rw] bounding_box
# An axis-aligned coarse representation of the detected item's
# location on the image.
# @return [Types::BoundingBox]
#
# @!attribute [rw] polygon
# Within the bounding box, a fine-grained polygon around the detected
# item.
# @return [Array]
#
class Geometry < Struct.new(
:bounding_box,
:polygon)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetCelebrityInfoRequest
# data as a hash:
#
# {
# id: "RekognitionUniqueId", # required
# }
#
# @!attribute [rw] id
# The ID for the celebrity. You get the celebrity ID from a call to
# the RecognizeCelebrities operation, which recognizes celebrities in
# an image.
# @return [String]
#
class GetCelebrityInfoRequest < Struct.new(
:id)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] urls
# An array of URLs pointing to additional celebrity information.
# @return [Array]
#
# @!attribute [rw] name
# The name of the celebrity.
# @return [String]
#
# @!attribute [rw] known_gender
# Retrieves the known gender for the celebrity.
# @return [Types::KnownGender]
#
class GetCelebrityInfoResponse < Struct.new(
:urls,
:name,
:known_gender)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetCelebrityRecognitionRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# sort_by: "ID", # accepts ID, TIMESTAMP
# }
#
# @!attribute [rw] job_id
# Job identifier for the required celebrity recognition analysis. You
# can get the job identifer from a call to
# `StartCelebrityRecognition`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# recognized celebrities to retrieve), Amazon Rekognition Video
# returns a pagination token in the response. You can use this
# pagination token to retrieve the next set of celebrities.
# @return [String]
#
# @!attribute [rw] sort_by
# Sort to use for celebrities returned in `Celebrities` field. Specify
# `ID` to sort by the celebrity identifier, specify `TIMESTAMP` to
# sort by the time the celebrity was recognized.
# @return [String]
#
class GetCelebrityRecognitionRequest < Struct.new(
:job_id,
:max_results,
:next_token,
:sort_by)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the celebrity recognition job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition Video analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition Video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of celebrities.
# @return [String]
#
# @!attribute [rw] celebrities
# Array of celebrities recognized in the video.
# @return [Array]
#
class GetCelebrityRecognitionResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:next_token,
:celebrities)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetContentModerationRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# sort_by: "NAME", # accepts NAME, TIMESTAMP
# }
#
# @!attribute [rw] job_id
# The identifier for the inappropriate, unwanted, or offensive content
# moderation job. Use `JobId` to identify the job in a subsequent call
# to `GetContentModeration`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more data
# to retrieve), Amazon Rekognition returns a pagination token in the
# response. You can use this pagination token to retrieve the next set
# of content moderation labels.
# @return [String]
#
# @!attribute [rw] sort_by
# Sort to use for elements in the `ModerationLabelDetections` array.
# Use `TIMESTAMP` to sort array elements by the time labels are
# detected. Use `NAME` to alphabetically group elements for a label
# together. Within each label group, the array element are sorted by
# detection confidence. The default sort is by `TIMESTAMP`.
# @return [String]
#
class GetContentModerationRequest < Struct.new(
:job_id,
:max_results,
:next_token,
:sort_by)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the content moderation analysis job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition analyzed.
# `Videometadata` is returned in every page of paginated responses
# from `GetContentModeration`.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] moderation_labels
# The detected inappropriate, unwanted, or offensive content
# moderation labels and the time(s) they were detected.
# @return [Array]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of content moderation labels.
# @return [String]
#
# @!attribute [rw] moderation_model_version
# Version number of the moderation detection model that was used to
# detect inappropriate, unwanted, or offensive content.
# @return [String]
#
class GetContentModerationResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:moderation_labels,
:next_token,
:moderation_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetFaceDetectionRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# }
#
# @!attribute [rw] job_id
# Unique identifier for the face detection job. The `JobId` is
# returned from `StartFaceDetection`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# faces to retrieve), Amazon Rekognition Video returns a pagination
# token in the response. You can use this pagination token to retrieve
# the next set of faces.
# @return [String]
#
class GetFaceDetectionRequest < Struct.new(
:job_id,
:max_results,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the face detection job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition Video analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition returns this token
# that you can use in the subsequent request to retrieve the next set
# of faces.
# @return [String]
#
# @!attribute [rw] faces
# An array of faces detected in the video. Each element contains a
# detected face's details and the time, in milliseconds from the
# start of the video, the face was detected.
# @return [Array]
#
class GetFaceDetectionResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:next_token,
:faces)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetFaceSearchRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# sort_by: "INDEX", # accepts INDEX, TIMESTAMP
# }
#
# @!attribute [rw] job_id
# The job identifer for the search request. You get the job identifier
# from an initial call to `StartFaceSearch`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# search results to retrieve), Amazon Rekognition Video returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of search results.
# @return [String]
#
# @!attribute [rw] sort_by
# Sort to use for grouping faces in the response. Use `TIMESTAMP` to
# group faces by the time that they are recognized. Use `INDEX` to
# sort by recognized faces.
# @return [String]
#
class GetFaceSearchRequest < Struct.new(
:job_id,
:max_results,
:next_token,
:sort_by)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the face search job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of search results.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition Video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] persons
# An array of persons, PersonMatch, in the video whose face(s) match
# the face(s) in an Amazon Rekognition collection. It also includes
# time information for when persons are matched in the video. You
# specify the input collection in an initial call to
# `StartFaceSearch`. Each `Persons` element includes a time the person
# was matched, face match details (`FaceMatches`) for matching faces
# in the collection, and person information (`Person`) for the matched
# person.
# @return [Array]
#
class GetFaceSearchResponse < Struct.new(
:job_status,
:status_message,
:next_token,
:video_metadata,
:persons)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetLabelDetectionRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# sort_by: "NAME", # accepts NAME, TIMESTAMP
# }
#
# @!attribute [rw] job_id
# Job identifier for the label detection operation for which you want
# results returned. You get the job identifer from an initial call to
# `StartlabelDetection`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# labels to retrieve), Amazon Rekognition Video returns a pagination
# token in the response. You can use this pagination token to retrieve
# the next set of labels.
# @return [String]
#
# @!attribute [rw] sort_by
# Sort to use for elements in the `Labels` array. Use `TIMESTAMP` to
# sort array elements by the time labels are detected. Use `NAME` to
# alphabetically group elements for a label together. Within each
# label group, the array element are sorted by detection confidence.
# The default sort is by `TIMESTAMP`.
# @return [String]
#
class GetLabelDetectionRequest < Struct.new(
:job_id,
:max_results,
:next_token,
:sort_by)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the label detection job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition Video analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of labels.
# @return [String]
#
# @!attribute [rw] labels
# An array of labels detected in the video. Each element contains the
# detected label and the time, in milliseconds from the start of the
# video, that the label was detected.
# @return [Array]
#
# @!attribute [rw] label_model_version
# Version number of the label detection model that was used to detect
# labels.
# @return [String]
#
class GetLabelDetectionResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:next_token,
:labels,
:label_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetPersonTrackingRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# sort_by: "INDEX", # accepts INDEX, TIMESTAMP
# }
#
# @!attribute [rw] job_id
# The identifier for a job that tracks persons in a video. You get the
# `JobId` from a call to `StartPersonTracking`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000. If you specify a value greater than
# 1000, a maximum of 1000 results is returned. The default value is
# 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# persons to retrieve), Amazon Rekognition Video returns a pagination
# token in the response. You can use this pagination token to retrieve
# the next set of persons.
# @return [String]
#
# @!attribute [rw] sort_by
# Sort to use for elements in the `Persons` array. Use `TIMESTAMP` to
# sort array elements by the time persons are detected. Use `INDEX` to
# sort by the tracked persons. If you sort by `INDEX`, the array
# elements for each person are sorted by detection confidence. The
# default sort is by `TIMESTAMP`.
# @return [String]
#
class GetPersonTrackingRequest < Struct.new(
:job_id,
:max_results,
:next_token,
:sort_by)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# The current status of the person tracking job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition Video analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition Video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of persons.
# @return [String]
#
# @!attribute [rw] persons
# An array of the persons detected in the video and the time(s) their
# path was tracked throughout the video. An array element will exist
# for each time a person's path is tracked.
# @return [Array]
#
class GetPersonTrackingResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:next_token,
:persons)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetSegmentDetectionRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# }
#
# @!attribute [rw] job_id
# Job identifier for the text detection operation for which you want
# results returned. You get the job identifer from an initial call to
# `StartSegmentDetection`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of text.
# @return [String]
#
class GetSegmentDetectionRequest < Struct.new(
:job_id,
:max_results,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# Current status of the segment detection job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Currently, Amazon Rekognition Video returns a single object in the
# `VideoMetadata` array. The object contains information about the
# video stream in the input file that Amazon Rekognition Video chose
# to analyze. The `VideoMetadata` object includes the video codec,
# video format and other information. Video metadata is returned in
# each page of information returned by `GetSegmentDetection`.
# @return [Array]
#
# @!attribute [rw] audio_metadata
# An array of objects. There can be multiple audio streams. Each
# `AudioMetadata` object contains metadata for a single audio stream.
# Audio information in an `AudioMetadata` objects includes the audio
# codec, the number of audio channels, the duration of the audio
# stream, and the sample rate. Audio metadata is returned in each page
# of information returned by `GetSegmentDetection`.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# labels to retrieve), Amazon Rekognition Video returns a pagination
# token in the response. You can use this pagination token to retrieve
# the next set of text.
# @return [String]
#
# @!attribute [rw] segments
# An array of segments detected in a video. The array is sorted by the
# segment types (TECHNICAL\_CUE or SHOT) specified in the
# `SegmentTypes` input parameter of `StartSegmentDetection`. Within
# each segment type the array is sorted by timestamp values.
# @return [Array]
#
# @!attribute [rw] selected_segment_types
# An array containing the segment types requested in the call to
# `StartSegmentDetection`.
# @return [Array]
#
class GetSegmentDetectionResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:audio_metadata,
:next_token,
:segments,
:selected_segment_types)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass GetTextDetectionRequest
# data as a hash:
#
# {
# job_id: "JobId", # required
# max_results: 1,
# next_token: "PaginationToken",
# }
#
# @!attribute [rw] job_id
# Job identifier for the text detection operation for which you want
# results returned. You get the job identifer from an initial call to
# `StartTextDetection`.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of results to return per paginated call. The largest
# value you can specify is 1000.
# @return [Integer]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# labels to retrieve), Amazon Rekognition Video returns a pagination
# token in the response. You can use this pagination token to retrieve
# the next set of text.
# @return [String]
#
class GetTextDetectionRequest < Struct.new(
:job_id,
:max_results,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_status
# Current status of the text detection job.
# @return [String]
#
# @!attribute [rw] status_message
# If the job fails, `StatusMessage` provides a descriptive error
# message.
# @return [String]
#
# @!attribute [rw] video_metadata
# Information about a video that Amazon Rekognition analyzed.
# `Videometadata` is returned in every page of paginated responses
# from a Amazon Rekognition video operation.
# @return [Types::VideoMetadata]
#
# @!attribute [rw] text_detections
# An array of text detected in the video. Each element contains the
# detected text, the time in milliseconds from the start of the video
# that the text was detected, and where it was detected on the screen.
# @return [Array]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of text.
# @return [String]
#
# @!attribute [rw] text_model_version
# Version number of the text detection model that was used to detect
# text.
# @return [String]
#
class GetTextDetectionResponse < Struct.new(
:job_status,
:status_message,
:video_metadata,
:text_detections,
:next_token,
:text_model_version)
SENSITIVE = []
include Aws::Structure
end
# The S3 bucket that contains an Amazon Sagemaker Ground Truth format
# manifest file.
#
# @note When making an API call, you may pass GroundTruthManifest
# data as a hash:
#
# {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# }
#
# @!attribute [rw] s3_object
# Provides the S3 bucket name and object name.
#
# The region for the S3 bucket containing the S3 object must match the
# region you use for Amazon Rekognition operations.
#
# For Amazon Rekognition to process an S3 object, the user must have
# permission to access the S3 object. For more information, see How
# Amazon Rekognition works with IAM in the Amazon Rekognition
# Developer Guide.
# @return [Types::S3Object]
#
class GroundTruthManifest < Struct.new(
:s3_object)
SENSITIVE = []
include Aws::Structure
end
# Shows the results of the human in the loop evaluation. If there is no
# HumanLoopArn, the input did not trigger human review.
#
# @!attribute [rw] human_loop_arn
# The Amazon Resource Name (ARN) of the HumanLoop created.
# @return [String]
#
# @!attribute [rw] human_loop_activation_reasons
# Shows if and why human review was needed.
# @return [Array]
#
# @!attribute [rw] human_loop_activation_conditions_evaluation_results
# Shows the result of condition evaluations, including those
# conditions which activated a human review.
# @return [String]
#
class HumanLoopActivationOutput < Struct.new(
:human_loop_arn,
:human_loop_activation_reasons,
:human_loop_activation_conditions_evaluation_results)
SENSITIVE = []
include Aws::Structure
end
# Sets up the flow definition the image will be sent to if one of the
# conditions is met. You can also set certain attributes of the image
# before review.
#
# @note When making an API call, you may pass HumanLoopConfig
# data as a hash:
#
# {
# human_loop_name: "HumanLoopName", # required
# flow_definition_arn: "FlowDefinitionArn", # required
# data_attributes: {
# content_classifiers: ["FreeOfPersonallyIdentifiableInformation"], # accepts FreeOfPersonallyIdentifiableInformation, FreeOfAdultContent
# },
# }
#
# @!attribute [rw] human_loop_name
# The name of the human review used for this image. This should be
# kept unique within a region.
# @return [String]
#
# @!attribute [rw] flow_definition_arn
# The Amazon Resource Name (ARN) of the flow definition. You can
# create a flow definition by using the Amazon Sagemaker
# [CreateFlowDefinition][1] Operation.
#
#
#
# [1]: https://docs.aws.amazon.com/sagemaker/latest/dg/API_CreateFlowDefinition.html
# @return [String]
#
# @!attribute [rw] data_attributes
# Sets attributes of the input data.
# @return [Types::HumanLoopDataAttributes]
#
class HumanLoopConfig < Struct.new(
:human_loop_name,
:flow_definition_arn,
:data_attributes)
SENSITIVE = []
include Aws::Structure
end
# Allows you to set attributes of the image. Currently, you can declare
# an image as free of personally identifiable information.
#
# @note When making an API call, you may pass HumanLoopDataAttributes
# data as a hash:
#
# {
# content_classifiers: ["FreeOfPersonallyIdentifiableInformation"], # accepts FreeOfPersonallyIdentifiableInformation, FreeOfAdultContent
# }
#
# @!attribute [rw] content_classifiers
# Sets whether the input image is free of personally identifiable
# information.
# @return [Array]
#
class HumanLoopDataAttributes < Struct.new(
:content_classifiers)
SENSITIVE = []
include Aws::Structure
end
# The number of in-progress human reviews you have has exceeded the
# number allowed.
#
# @!attribute [rw] resource_type
# The resource type.
# @return [String]
#
# @!attribute [rw] quota_code
# The quota code.
# @return [String]
#
# @!attribute [rw] service_code
# The service code.
# @return [String]
#
class HumanLoopQuotaExceededException < Struct.new(
:resource_type,
:quota_code,
:service_code)
SENSITIVE = []
include Aws::Structure
end
# A `ClientRequestToken` input parameter was reused with an operation,
# but at least one of the other input parameters is different from the
# previous call to the operation.
#
class IdempotentParameterMismatchException < Aws::EmptyStructure; end
# Provides the input image either as bytes or an S3 object.
#
# You pass image bytes to an Amazon Rekognition API operation by using
# the `Bytes` property. For example, you would use the `Bytes` property
# to pass an image loaded from a local file system. Image bytes passed
# by using the `Bytes` property must be base64-encoded. Your code may
# not need to encode image bytes if you are using an AWS SDK to call
# Amazon Rekognition API operations.
#
# For more information, see Analyzing an Image Loaded from a Local File
# System in the Amazon Rekognition Developer Guide.
#
# You pass images stored in an S3 bucket to an Amazon Rekognition API
# operation by using the `S3Object` property. Images stored in an S3
# bucket do not need to be base64-encoded.
#
# The region for the S3 bucket containing the S3 object must match the
# region you use for Amazon Rekognition operations.
#
# If you use the AWS CLI to call Amazon Rekognition operations, passing
# image bytes using the Bytes property is not supported. You must first
# upload the image to an Amazon S3 bucket and then call the operation
# using the S3Object property.
#
# For Amazon Rekognition to process an S3 object, the user must have
# permission to access the S3 object. For more information, see How
# Amazon Rekognition works with IAM in the Amazon Rekognition Developer
# Guide.
#
# @note When making an API call, you may pass Image
# data as a hash:
#
# {
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# }
#
# @!attribute [rw] bytes
# Blob of image bytes up to 5 MBs.
# @return [String]
#
# @!attribute [rw] s3_object
# Identifies an S3 object as the image source.
# @return [Types::S3Object]
#
class Image < Struct.new(
:bytes,
:s3_object)
SENSITIVE = []
include Aws::Structure
end
# Identifies face image brightness and sharpness.
#
# @!attribute [rw] brightness
# Value representing brightness of the face. The service returns a
# value between 0 and 100 (inclusive). A higher value indicates a
# brighter face image.
# @return [Float]
#
# @!attribute [rw] sharpness
# Value representing sharpness of the face. The service returns a
# value between 0 and 100 (inclusive). A higher value indicates a
# sharper face image.
# @return [Float]
#
class ImageQuality < Struct.new(
:brightness,
:sharpness)
SENSITIVE = []
include Aws::Structure
end
# The input image size exceeds the allowed limit. If you are calling
# DetectProtectiveEquipment, the image size or resolution exceeds the
# allowed limit. For more information, see Guidelines and quotas in
# Amazon Rekognition in the Amazon Rekognition Developer Guide.
#
class ImageTooLargeException < Aws::EmptyStructure; end
# @note When making an API call, you may pass IndexFacesRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# external_image_id: "ExternalImageId",
# detection_attributes: ["DEFAULT"], # accepts DEFAULT, ALL
# max_faces: 1,
# quality_filter: "NONE", # accepts NONE, AUTO, LOW, MEDIUM, HIGH
# }
#
# @!attribute [rw] collection_id
# The ID of an existing collection to which you want to add the faces
# that are detected in the input images.
# @return [String]
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes isn't supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] external_image_id
# The ID you want to assign to all the faces detected in the image.
# @return [String]
#
# @!attribute [rw] detection_attributes
# An array of facial attributes that you want to be returned. This can
# be the default list of attributes or all attributes. If you don't
# specify a value for `Attributes` or if you specify `["DEFAULT"]`,
# the API returns the following subset of facial attributes:
# `BoundingBox`, `Confidence`, `Pose`, `Quality`, and `Landmarks`. If
# you provide `["ALL"]`, all facial attributes are returned, but the
# operation takes longer to complete.
#
# If you provide both, `["ALL", "DEFAULT"]`, the service uses a
# logical AND operator to determine which attributes to return (in
# this case, all attributes).
# @return [Array]
#
# @!attribute [rw] max_faces
# The maximum number of faces to index. The value of `MaxFaces` must
# be greater than or equal to 1. `IndexFaces` returns no more than 100
# detected faces in an image, even if you specify a larger value for
# `MaxFaces`.
#
# If `IndexFaces` detects more faces than the value of `MaxFaces`, the
# faces with the lowest quality are filtered out first. If there are
# still more faces than the value of `MaxFaces`, the faces with the
# smallest bounding boxes are filtered out (up to the number that's
# needed to satisfy the value of `MaxFaces`). Information about the
# unindexed faces is available in the `UnindexedFaces` array.
#
# The faces that are returned by `IndexFaces` are sorted by the
# largest face bounding box size to the smallest size, in descending
# order.
#
# `MaxFaces` can be used with a collection associated with any version
# of the face model.
# @return [Integer]
#
# @!attribute [rw] quality_filter
# A filter that specifies a quality bar for how much filtering is done
# to identify faces. Filtered faces aren't indexed. If you specify
# `AUTO`, Amazon Rekognition chooses the quality bar. If you specify
# `LOW`, `MEDIUM`, or `HIGH`, filtering removes all faces that don’t
# meet the chosen quality bar. The default value is `AUTO`. The
# quality bar is based on a variety of common use cases. Low-quality
# detections can occur for a number of reasons. Some examples are an
# object that's misidentified as a face, a face that's too blurry,
# or a face with a pose that's too extreme to use. If you specify
# `NONE`, no filtering is performed.
#
# To use quality filtering, the collection you are using must be
# associated with version 3 of the face model or higher.
# @return [String]
#
class IndexFacesRequest < Struct.new(
:collection_id,
:image,
:external_image_id,
:detection_attributes,
:max_faces,
:quality_filter)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] face_records
# An array of faces detected and added to the collection. For more
# information, see Searching Faces in a Collection in the Amazon
# Rekognition Developer Guide.
# @return [Array]
#
# @!attribute [rw] orientation_correction
# If your collection is associated with a face detection model that's
# later than version 3.0, the value of `OrientationCorrection` is
# always null and no orientation information is returned.
#
# If your collection is associated with a face detection model that's
# version 3.0 or earlier, the following applies:
#
# * If the input image is in .jpeg format, it might contain
# exchangeable image file format (Exif) metadata that includes the
# image's orientation. Amazon Rekognition uses this orientation
# information to perform image correction - the bounding box
# coordinates are translated to represent object locations after the
# orientation information in the Exif metadata is used to correct
# the image orientation. Images in .png format don't contain Exif
# metadata. The value of `OrientationCorrection` is null.
#
# * If the image doesn't contain orientation information in its Exif
# metadata, Amazon Rekognition returns an estimated orientation
# (ROTATE\_0, ROTATE\_90, ROTATE\_180, ROTATE\_270). Amazon
# Rekognition doesn’t perform image correction for images. The
# bounding box coordinates aren't translated and represent the
# object locations before the image is rotated.
#
# Bounding box information is returned in the `FaceRecords` array. You
# can get the version of the face detection model by calling
# DescribeCollection.
# @return [String]
#
# @!attribute [rw] face_model_version
# The version number of the face detection model that's associated
# with the input collection (`CollectionId`).
# @return [String]
#
# @!attribute [rw] unindexed_faces
# An array of faces that were detected in the image but weren't
# indexed. They weren't indexed because the quality filter identified
# them as low quality, or the `MaxFaces` request parameter filtered
# them out. To use the quality filter, you specify the `QualityFilter`
# request parameter.
# @return [Array]
#
class IndexFacesResponse < Struct.new(
:face_records,
:orientation_correction,
:face_model_version,
:unindexed_faces)
SENSITIVE = []
include Aws::Structure
end
# An instance of a label returned by Amazon Rekognition Image
# (DetectLabels) or by Amazon Rekognition Video (GetLabelDetection).
#
# @!attribute [rw] bounding_box
# The position of the label instance on the image.
# @return [Types::BoundingBox]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has in the accuracy of the
# bounding box.
# @return [Float]
#
class Instance < Struct.new(
:bounding_box,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Amazon Rekognition experienced a service issue. Try your call again.
#
class InternalServerError < Aws::EmptyStructure; end
# The provided image format is not supported.
#
class InvalidImageFormatException < Aws::EmptyStructure; end
# Pagination token in the request is not valid.
#
class InvalidPaginationTokenException < Aws::EmptyStructure; end
# Input parameter violated a constraint. Validate your parameter before
# calling the API operation again.
#
class InvalidParameterException < Aws::EmptyStructure; end
# The supplied revision id for the project policy is invalid.
#
class InvalidPolicyRevisionIdException < Aws::EmptyStructure; end
# Amazon Rekognition is unable to access the S3 object specified in the
# request.
#
class InvalidS3ObjectException < Aws::EmptyStructure; end
# The Kinesis data stream Amazon Rekognition to which the analysis
# results of a Amazon Rekognition stream processor are streamed. For
# more information, see CreateStreamProcessor in the Amazon Rekognition
# Developer Guide.
#
# @note When making an API call, you may pass KinesisDataStream
# data as a hash:
#
# {
# arn: "KinesisDataArn",
# }
#
# @!attribute [rw] arn
# ARN of the output Amazon Kinesis Data Streams stream.
# @return [String]
#
class KinesisDataStream < Struct.new(
:arn)
SENSITIVE = []
include Aws::Structure
end
# Kinesis video stream stream that provides the source streaming video
# for a Amazon Rekognition Video stream processor. For more information,
# see CreateStreamProcessor in the Amazon Rekognition Developer Guide.
#
# @note When making an API call, you may pass KinesisVideoStream
# data as a hash:
#
# {
# arn: "KinesisVideoArn",
# }
#
# @!attribute [rw] arn
# ARN of the Kinesis video stream stream that streams the source
# video.
# @return [String]
#
class KinesisVideoStream < Struct.new(
:arn)
SENSITIVE = []
include Aws::Structure
end
# Specifies the starting point in a Kinesis stream to start processing.
# You can use the producer timestamp or the fragment number. For more
# information, see [Fragment][1].
#
#
#
# [1]: https://docs.aws.amazon.com/kinesisvideostreams/latest/dg/API_reader_Fragment.html
#
# @note When making an API call, you may pass KinesisVideoStreamStartSelector
# data as a hash:
#
# {
# producer_timestamp: 1,
# fragment_number: "KinesisVideoStreamFragmentNumber",
# }
#
# @!attribute [rw] producer_timestamp
# The timestamp from the producer corresponding to the fragment.
# @return [Integer]
#
# @!attribute [rw] fragment_number
# The unique identifier of the fragment. This value monotonically
# increases based on the ingestion order.
# @return [String]
#
class KinesisVideoStreamStartSelector < Struct.new(
:producer_timestamp,
:fragment_number)
SENSITIVE = []
include Aws::Structure
end
# The known gender identity for the celebrity that matches the provided
# ID. The known gender identity can be Male, Female, Nonbinary, or
# Unlisted.
#
# @!attribute [rw] type
# A string value of the KnownGender info about the Celebrity.
# @return [String]
#
class KnownGender < Struct.new(
:type)
SENSITIVE = []
include Aws::Structure
end
# Structure containing details about the detected label, including the
# name, detected instances, parent labels, and level of confidence.
#
# @!attribute [rw] name
# The name (label) of the object or scene.
# @return [String]
#
# @!attribute [rw] confidence
# Level of confidence.
# @return [Float]
#
# @!attribute [rw] instances
# If `Label` represents an object, `Instances` contains the bounding
# boxes for each instance of the detected object. Bounding boxes are
# returned for common object labels such as people, cars, furniture,
# apparel or pets.
# @return [Array]
#
# @!attribute [rw] parents
# The parent labels for a label. The response includes all ancestor
# labels.
# @return [Array]
#
class Label < Struct.new(
:name,
:confidence,
:instances,
:parents)
SENSITIVE = []
include Aws::Structure
end
# Information about a label detected in a video analysis request and the
# time the label was detected in the video.
#
# @!attribute [rw] timestamp
# Time, in milliseconds from the start of the video, that the label
# was detected.
# @return [Integer]
#
# @!attribute [rw] label
# Details about the detected label.
# @return [Types::Label]
#
class LabelDetection < Struct.new(
:timestamp,
:label)
SENSITIVE = []
include Aws::Structure
end
# Indicates the location of the landmark on the face.
#
# @!attribute [rw] type
# Type of landmark.
# @return [String]
#
# @!attribute [rw] x
# The x-coordinate of the landmark expressed as a ratio of the width
# of the image. The x-coordinate is measured from the left-side of the
# image. For example, if the image is 700 pixels wide and the
# x-coordinate of the landmark is at 350 pixels, this value is 0.5.
# @return [Float]
#
# @!attribute [rw] y
# The y-coordinate of the landmark expressed as a ratio of the height
# of the image. The y-coordinate is measured from the top of the
# image. For example, if the image height is 200 pixels and the
# y-coordinate of the landmark is at 50 pixels, this value is 0.25.
# @return [Float]
#
class Landmark < Struct.new(
:type,
:x,
:y)
SENSITIVE = []
include Aws::Structure
end
# An Amazon Rekognition service limit was exceeded. For example, if you
# start too many Amazon Rekognition Video jobs concurrently, calls to
# start operations (`StartLabelDetection`, for example) will raise a
# `LimitExceededException` exception (HTTP status code: 400) until the
# number of concurrently running jobs is below the Amazon Rekognition
# service limit.
#
class LimitExceededException < Aws::EmptyStructure; end
# @note When making an API call, you may pass ListCollectionsRequest
# data as a hash:
#
# {
# next_token: "PaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] next_token
# Pagination token from the previous response.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of collection IDs to return.
# @return [Integer]
#
class ListCollectionsRequest < Struct.new(
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] collection_ids
# An array of collection IDs.
# @return [Array]
#
# @!attribute [rw] next_token
# If the result is truncated, the response provides a `NextToken` that
# you can use in the subsequent request to fetch the next set of
# collection IDs.
# @return [String]
#
# @!attribute [rw] face_model_versions
# Version numbers of the face detection models associated with the
# collections in the array `CollectionIds`. For example, the value of
# `FaceModelVersions[2]` is the version number for the face detection
# model used by the collection in `CollectionId[2]`.
# @return [Array]
#
class ListCollectionsResponse < Struct.new(
:collection_ids,
:next_token,
:face_model_versions)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListDatasetEntriesRequest
# data as a hash:
#
# {
# dataset_arn: "DatasetArn", # required
# contains_labels: ["DatasetLabel"],
# labeled: false,
# source_ref_contains: "QueryString",
# has_errors: false,
# next_token: "ExtendedPaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] dataset_arn
# The Amazon Resource Name (ARN) for the dataset that you want to use.
# @return [String]
#
# @!attribute [rw] contains_labels
# Specifies a label filter for the response. The response includes an
# entry only if one or more of the labels in `ContainsLabels` exist in
# the entry.
# @return [Array]
#
# @!attribute [rw] labeled
# Specify `true` to get only the JSON Lines where the image is
# labeled. Specify `false` to get only the JSON Lines where the image
# isn't labeled. If you don't specify `Labeled`,
# `ListDatasetEntries` returns JSON Lines for labeled and unlabeled
# images.
# @return [Boolean]
#
# @!attribute [rw] source_ref_contains
# If specified, `ListDatasetEntries` only returns JSON Lines where the
# value of `SourceRefContains` is part of the `source-ref` field. The
# `source-ref` field contains the Amazon S3 location of the image. You
# can use `SouceRefContains` for tasks such as getting the JSON Line
# for a single image, or gettting JSON Lines for all images within a
# specific folder.
# @return [String]
#
# @!attribute [rw] has_errors
# Specifies an error filter for the response. Specify `True` to only
# include entries that have errors.
# @return [Boolean]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
# @!attribute [rw] max_results
# The maximum number of results to return per paginated call. The
# largest value you can specify is 100. If you specify a value greater
# than 100, a ValidationException error occurs. The default value is
# 100.
# @return [Integer]
#
class ListDatasetEntriesRequest < Struct.new(
:dataset_arn,
:contains_labels,
:labeled,
:source_ref_contains,
:has_errors,
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] dataset_entries
# A list of entries (images) in the dataset.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
class ListDatasetEntriesResponse < Struct.new(
:dataset_entries,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListDatasetLabelsRequest
# data as a hash:
#
# {
# dataset_arn: "DatasetArn", # required
# next_token: "ExtendedPaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] dataset_arn
# The Amazon Resource Name (ARN) of the dataset that you want to use.
# @return [String]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
# @!attribute [rw] max_results
# The maximum number of results to return per paginated call. The
# largest value you can specify is 100. If you specify a value greater
# than 100, a ValidationException error occurs. The default value is
# 100.
# @return [Integer]
#
class ListDatasetLabelsRequest < Struct.new(
:dataset_arn,
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] dataset_label_descriptions
# A list of the labels in the dataset.
# @return [Array]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
class ListDatasetLabelsResponse < Struct.new(
:dataset_label_descriptions,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListFacesRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# next_token: "PaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] collection_id
# ID of the collection from which to list the faces.
# @return [String]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more data
# to retrieve), Amazon Rekognition returns a pagination token in the
# response. You can use this pagination token to retrieve the next set
# of faces.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of faces to return.
# @return [Integer]
#
class ListFacesRequest < Struct.new(
:collection_id,
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] faces
# An array of `Face` objects.
# @return [Array]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition returns this token
# that you can use in the subsequent request to retrieve the next set
# of faces.
# @return [String]
#
# @!attribute [rw] face_model_version
# Version number of the face detection model associated with the input
# collection (`CollectionId`).
# @return [String]
#
class ListFacesResponse < Struct.new(
:faces,
:next_token,
:face_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListProjectPoliciesRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# next_token: "ExtendedPaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] project_arn
# The ARN of the project for which you want to list the project
# policies.
# @return [String]
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there is more
# results to retrieve), Amazon Rekognition Custom Labels returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of results.
# @return [String]
#
# @!attribute [rw] max_results
# The maximum number of results to return per paginated call. The
# largest value you can specify is 5. If you specify a value greater
# than 5, a ValidationException error occurs. The default value is 5.
# @return [Integer]
#
class ListProjectPoliciesRequest < Struct.new(
:project_arn,
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] project_policies
# A list of project policies attached to the project.
# @return [Array]
#
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition returns this token
# that you can use in the subsequent request to retrieve the next set
# of project policies.
# @return [String]
#
class ListProjectPoliciesResponse < Struct.new(
:project_policies,
:next_token)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListStreamProcessorsRequest
# data as a hash:
#
# {
# next_token: "PaginationToken",
# max_results: 1,
# }
#
# @!attribute [rw] next_token
# If the previous response was incomplete (because there are more
# stream processors to retrieve), Amazon Rekognition Video returns a
# pagination token in the response. You can use this pagination token
# to retrieve the next set of stream processors.
# @return [String]
#
# @!attribute [rw] max_results
# Maximum number of stream processors you want Amazon Rekognition
# Video to return in the response. The default is 1000.
# @return [Integer]
#
class ListStreamProcessorsRequest < Struct.new(
:next_token,
:max_results)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] next_token
# If the response is truncated, Amazon Rekognition Video returns this
# token that you can use in the subsequent request to retrieve the
# next set of stream processors.
# @return [String]
#
# @!attribute [rw] stream_processors
# List of stream processors that you have created.
# @return [Array]
#
class ListStreamProcessorsResponse < Struct.new(
:next_token,
:stream_processors)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass ListTagsForResourceRequest
# data as a hash:
#
# {
# resource_arn: "ResourceArn", # required
# }
#
# @!attribute [rw] resource_arn
# Amazon Resource Name (ARN) of the model, collection, or stream
# processor that contains the tags that you want a list of.
# @return [String]
#
class ListTagsForResourceRequest < Struct.new(
:resource_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] tags
# A list of key-value tags assigned to the resource.
# @return [Hash]
#
class ListTagsForResourceResponse < Struct.new(
:tags)
SENSITIVE = []
include Aws::Structure
end
# The format of the project policy document that you supplied to
# `PutProjectPolicy` is incorrect.
#
class MalformedPolicyDocumentException < Aws::EmptyStructure; end
# Provides information about a single type of inappropriate, unwanted,
# or offensive content found in an image or video. Each type of
# moderated content has a label within a hierarchical taxonomy. For more
# information, see Content moderation in the Amazon Rekognition
# Developer Guide.
#
# @!attribute [rw] confidence
# Specifies the confidence that Amazon Rekognition has that the label
# has been correctly identified.
#
# If you don't specify the `MinConfidence` parameter in the call to
# `DetectModerationLabels`, the operation returns labels with a
# confidence value greater than or equal to 50 percent.
# @return [Float]
#
# @!attribute [rw] name
# The label name for the type of unsafe content detected in the image.
# @return [String]
#
# @!attribute [rw] parent_name
# The name for the parent label. Labels at the top level of the
# hierarchy have the parent label `""`.
# @return [String]
#
class ModerationLabel < Struct.new(
:confidence,
:name,
:parent_name)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the mouth on the face is open, and the
# confidence level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the mouth on the face is open
# or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class MouthOpen < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the face has a mustache, and the confidence
# level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the face has mustache or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Mustache < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# The Amazon Simple Notification Service topic to which Amazon
# Rekognition publishes the completion status of a video analysis
# operation. For more information, see [Calling Amazon Rekognition Video
# operations][1]. Note that the Amazon SNS topic must have a topic name
# that begins with *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy to access the topic.
# For more information, see [Giving access to multiple Amazon SNS
# topics][2].
#
#
#
# [1]: https://docs.aws.amazon.com/rekognition/latest/dg/api-video.html
# [2]: https://docs.aws.amazon.com/rekognition/latest/dg/api-video-roles.html#api-video-roles-all-topics
#
# @note When making an API call, you may pass NotificationChannel
# data as a hash:
#
# {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# }
#
# @!attribute [rw] sns_topic_arn
# The Amazon SNS topic to which Amazon Rekognition posts the
# completion status.
# @return [String]
#
# @!attribute [rw] role_arn
# The ARN of an IAM role that gives Amazon Rekognition publishing
# permissions to the Amazon SNS topic.
# @return [String]
#
class NotificationChannel < Struct.new(
:sns_topic_arn,
:role_arn)
SENSITIVE = []
include Aws::Structure
end
# The S3 bucket and folder location where training output is placed.
#
# @note When making an API call, you may pass OutputConfig
# data as a hash:
#
# {
# s3_bucket: "S3Bucket",
# s3_key_prefix: "S3KeyPrefix",
# }
#
# @!attribute [rw] s3_bucket
# The S3 bucket where training output is placed.
# @return [String]
#
# @!attribute [rw] s3_key_prefix
# The prefix applied to the training output files.
# @return [String]
#
class OutputConfig < Struct.new(
:s3_bucket,
:s3_key_prefix)
SENSITIVE = []
include Aws::Structure
end
# A parent label for a label. A label can have 0, 1, or more parents.
#
# @!attribute [rw] name
# The name of the parent label.
# @return [String]
#
class Parent < Struct.new(
:name)
SENSITIVE = []
include Aws::Structure
end
# Details about a person detected in a video analysis request.
#
# @!attribute [rw] index
# Identifier for the person detected person within a video. Use to
# keep track of the person throughout the video. The identifier is not
# stored by Amazon Rekognition.
# @return [Integer]
#
# @!attribute [rw] bounding_box
# Bounding box around the detected person.
# @return [Types::BoundingBox]
#
# @!attribute [rw] face
# Face details for the detected person.
# @return [Types::FaceDetail]
#
class PersonDetail < Struct.new(
:index,
:bounding_box,
:face)
SENSITIVE = []
include Aws::Structure
end
# Details and path tracking information for a single time a person's
# path is tracked in a video. Amazon Rekognition operations that track
# people's paths return an array of `PersonDetection` objects with
# elements for each time a person's path is tracked in a video.
#
# For more information, see GetPersonTracking in the Amazon Rekognition
# Developer Guide.
#
# @!attribute [rw] timestamp
# The time, in milliseconds from the start of the video, that the
# person's path was tracked.
# @return [Integer]
#
# @!attribute [rw] person
# Details about a person whose path was tracked in a video.
# @return [Types::PersonDetail]
#
class PersonDetection < Struct.new(
:timestamp,
:person)
SENSITIVE = []
include Aws::Structure
end
# Information about a person whose face matches a face(s) in an Amazon
# Rekognition collection. Includes information about the faces in the
# Amazon Rekognition collection (FaceMatch), information about the
# person (PersonDetail), and the time stamp for when the person was
# detected in a video. An array of `PersonMatch` objects is returned by
# GetFaceSearch.
#
# @!attribute [rw] timestamp
# The time, in milliseconds from the beginning of the video, that the
# person was matched in the video.
# @return [Integer]
#
# @!attribute [rw] person
# Information about the matched person.
# @return [Types::PersonDetail]
#
# @!attribute [rw] face_matches
# Information about the faces in the input collection that match the
# face of a person in the video.
# @return [Array]
#
class PersonMatch < Struct.new(
:timestamp,
:person,
:face_matches)
SENSITIVE = []
include Aws::Structure
end
# The X and Y coordinates of a point on an image or video frame. The X
# and Y values are ratios of the overall image size or video resolution.
# For example, if an input image is 700x200 and the values are X=0.5 and
# Y=0.25, then the point is at the (350,50) pixel coordinate on the
# image.
#
# An array of `Point` objects makes up a `Polygon`. A `Polygon` is
# returned by DetectText and by DetectCustomLabels `Polygon` represents
# a fine-grained polygon around a detected item. For more information,
# see Geometry in the Amazon Rekognition Developer Guide.
#
# @note When making an API call, you may pass Point
# data as a hash:
#
# {
# x: 1.0,
# y: 1.0,
# }
#
# @!attribute [rw] x
# The value of the X coordinate for a point on a `Polygon`.
# @return [Float]
#
# @!attribute [rw] y
# The value of the Y coordinate for a point on a `Polygon`.
# @return [Float]
#
class Point < Struct.new(
:x,
:y)
SENSITIVE = []
include Aws::Structure
end
# Indicates the pose of the face as determined by its pitch, roll, and
# yaw.
#
# @!attribute [rw] roll
# Value representing the face rotation on the roll axis.
# @return [Float]
#
# @!attribute [rw] yaw
# Value representing the face rotation on the yaw axis.
# @return [Float]
#
# @!attribute [rw] pitch
# Value representing the face rotation on the pitch axis.
# @return [Float]
#
class Pose < Struct.new(
:roll,
:yaw,
:pitch)
SENSITIVE = []
include Aws::Structure
end
# A description of an Amazon Rekognition Custom Labels project. For more
# information, see DescribeProjects.
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project.
# @return [String]
#
# @!attribute [rw] creation_timestamp
# The Unix timestamp for the date and time that the project was
# created.
# @return [Time]
#
# @!attribute [rw] status
# The current status of the project.
# @return [String]
#
# @!attribute [rw] datasets
# Information about the training and test datasets in the project.
# @return [Array]
#
class ProjectDescription < Struct.new(
:project_arn,
:creation_timestamp,
:status,
:datasets)
SENSITIVE = []
include Aws::Structure
end
# Describes a project policy in the response from ListProjectPolicies.
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project to which the project
# policy is attached.
# @return [String]
#
# @!attribute [rw] policy_name
# The name of the project policy.
# @return [String]
#
# @!attribute [rw] policy_revision_id
# The revision ID of the project policy.
# @return [String]
#
# @!attribute [rw] policy_document
# The JSON document for the project policy.
# @return [String]
#
# @!attribute [rw] creation_timestamp
# The Unix datetime for the creation of the project policy.
# @return [Time]
#
# @!attribute [rw] last_updated_timestamp
# The Unix datetime for when the project policy was last updated.
# @return [Time]
#
class ProjectPolicy < Struct.new(
:project_arn,
:policy_name,
:policy_revision_id,
:policy_document,
:creation_timestamp,
:last_updated_timestamp)
SENSITIVE = []
include Aws::Structure
end
# A description of a version of an Amazon Rekognition Custom Labels
# model.
#
# @!attribute [rw] project_version_arn
# The Amazon Resource Name (ARN) of the model version.
# @return [String]
#
# @!attribute [rw] creation_timestamp
# The Unix datetime for the date and time that training started.
# @return [Time]
#
# @!attribute [rw] min_inference_units
# The minimum number of inference units used by the model. For more
# information, see StartProjectVersion.
# @return [Integer]
#
# @!attribute [rw] status
# The current status of the model version.
# @return [String]
#
# @!attribute [rw] status_message
# A descriptive message for an error or warning that occurred.
# @return [String]
#
# @!attribute [rw] billable_training_time_in_seconds
# The duration, in seconds, that you were billed for a successful
# training of the model version. This value is only returned if the
# model version has been successfully trained.
# @return [Integer]
#
# @!attribute [rw] training_end_timestamp
# The Unix date and time that training of the model ended.
# @return [Time]
#
# @!attribute [rw] output_config
# The location where training results are saved.
# @return [Types::OutputConfig]
#
# @!attribute [rw] training_data_result
# Contains information about the training results.
# @return [Types::TrainingDataResult]
#
# @!attribute [rw] testing_data_result
# Contains information about the testing results.
# @return [Types::TestingDataResult]
#
# @!attribute [rw] evaluation_result
# The training results. `EvaluationResult` is only returned if
# training is successful.
# @return [Types::EvaluationResult]
#
# @!attribute [rw] manifest_summary
# The location of the summary manifest. The summary manifest provides
# aggregate data validation results for the training and test
# datasets.
# @return [Types::GroundTruthManifest]
#
# @!attribute [rw] kms_key_id
# The identifer for the AWS Key Management Service key (AWS KMS key)
# that was used to encrypt the model during training.
# @return [String]
#
# @!attribute [rw] max_inference_units
# The maximum number of inference units Amazon Rekognition Custom
# Labels uses to auto-scale the model. For more information, see
# StartProjectVersion.
# @return [Integer]
#
# @!attribute [rw] source_project_version_arn
# If the model version was copied from a different project,
# `SourceProjectVersionArn` contains the ARN of the source model
# version.
# @return [String]
#
class ProjectVersionDescription < Struct.new(
:project_version_arn,
:creation_timestamp,
:min_inference_units,
:status,
:status_message,
:billable_training_time_in_seconds,
:training_end_timestamp,
:output_config,
:training_data_result,
:testing_data_result,
:evaluation_result,
:manifest_summary,
:kms_key_id,
:max_inference_units,
:source_project_version_arn)
SENSITIVE = []
include Aws::Structure
end
# Information about a body part detected by DetectProtectiveEquipment
# that contains PPE. An array of `ProtectiveEquipmentBodyPart` objects
# is returned for each person detected by `DetectProtectiveEquipment`.
#
# @!attribute [rw] name
# The detected body part.
# @return [String]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has in the detection accuracy
# of the detected body part.
# @return [Float]
#
# @!attribute [rw] equipment_detections
# An array of Personal Protective Equipment items detected around a
# body part.
# @return [Array]
#
class ProtectiveEquipmentBodyPart < Struct.new(
:name,
:confidence,
:equipment_detections)
SENSITIVE = []
include Aws::Structure
end
# A person detected by a call to DetectProtectiveEquipment. The API
# returns all persons detected in the input image in an array of
# `ProtectiveEquipmentPerson` objects.
#
# @!attribute [rw] body_parts
# An array of body parts detected on a person's body (including body
# parts without PPE).
# @return [Array]
#
# @!attribute [rw] bounding_box
# A bounding box around the detected person.
# @return [Types::BoundingBox]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has that the bounding box
# contains a person.
# @return [Float]
#
# @!attribute [rw] id
# The identifier for the detected person. The identifier is only
# unique for a single call to `DetectProtectiveEquipment`.
# @return [Integer]
#
class ProtectiveEquipmentPerson < Struct.new(
:body_parts,
:bounding_box,
:confidence,
:id)
SENSITIVE = []
include Aws::Structure
end
# Specifies summary attributes to return from a call to
# DetectProtectiveEquipment. You can specify which types of PPE to
# summarize. You can also specify a minimum confidence value for
# detections. Summary information is returned in the `Summary`
# (ProtectiveEquipmentSummary) field of the response from
# `DetectProtectiveEquipment`. The summary includes which persons in an
# image were detected wearing the requested types of person protective
# equipment (PPE), which persons were detected as not wearing PPE, and
# the persons in which a determination could not be made. For more
# information, see ProtectiveEquipmentSummary.
#
# @note When making an API call, you may pass ProtectiveEquipmentSummarizationAttributes
# data as a hash:
#
# {
# min_confidence: 1.0, # required
# required_equipment_types: ["FACE_COVER"], # required, accepts FACE_COVER, HAND_COVER, HEAD_COVER
# }
#
# @!attribute [rw] min_confidence
# The minimum confidence level for which you want summary information.
# The confidence level applies to person detection, body part
# detection, equipment detection, and body part coverage. Amazon
# Rekognition doesn't return summary information with a confidence
# than this specified value. There isn't a default value.
#
# Specify a `MinConfidence` value that is between 50-100% as
# `DetectProtectiveEquipment` returns predictions only where the
# detection confidence is between 50% - 100%. If you specify a value
# that is less than 50%, the results are the same specifying a value
# of 50%.
# @return [Float]
#
# @!attribute [rw] required_equipment_types
# An array of personal protective equipment types for which you want
# summary information. If a person is detected wearing a required
# requipment type, the person's ID is added to the
# `PersonsWithRequiredEquipment` array field returned in
# ProtectiveEquipmentSummary by `DetectProtectiveEquipment`.
# @return [Array]
#
class ProtectiveEquipmentSummarizationAttributes < Struct.new(
:min_confidence,
:required_equipment_types)
SENSITIVE = []
include Aws::Structure
end
# Summary information for required items of personal protective
# equipment (PPE) detected on persons by a call to
# DetectProtectiveEquipment. You specify the required type of PPE in the
# `SummarizationAttributes` (ProtectiveEquipmentSummarizationAttributes)
# input parameter. The summary includes which persons were detected
# wearing the required personal protective equipment
# (`PersonsWithRequiredEquipment`), which persons were detected as not
# wearing the required PPE (`PersonsWithoutRequiredEquipment`), and the
# persons in which a determination could not be made
# (`PersonsIndeterminate`).
#
# To get a total for each category, use the size of the field array. For
# example, to find out how many people were detected as wearing the
# specified PPE, use the size of the `PersonsWithRequiredEquipment`
# array. If you want to find out more about a person, such as the
# location (BoundingBox) of the person on the image, use the person ID
# in each array element. Each person ID matches the ID field of a
# ProtectiveEquipmentPerson object returned in the `Persons` array by
# `DetectProtectiveEquipment`.
#
# @!attribute [rw] persons_with_required_equipment
# An array of IDs for persons who are wearing detected personal
# protective equipment.
# @return [Array]
#
# @!attribute [rw] persons_without_required_equipment
# An array of IDs for persons who are not wearing all of the types of
# PPE specified in the `RequiredEquipmentTypes` field of the detected
# personal protective equipment.
# @return [Array]
#
# @!attribute [rw] persons_indeterminate
# An array of IDs for persons where it was not possible to determine
# if they are wearing personal protective equipment.
# @return [Array]
#
class ProtectiveEquipmentSummary < Struct.new(
:persons_with_required_equipment,
:persons_without_required_equipment,
:persons_indeterminate)
SENSITIVE = []
include Aws::Structure
end
# The number of requests exceeded your throughput limit. If you want to
# increase this limit, contact Amazon Rekognition.
#
class ProvisionedThroughputExceededException < Aws::EmptyStructure; end
# @note When making an API call, you may pass PutProjectPolicyRequest
# data as a hash:
#
# {
# project_arn: "ProjectArn", # required
# policy_name: "ProjectPolicyName", # required
# policy_revision_id: "ProjectPolicyRevisionId",
# policy_document: "ProjectPolicyDocument", # required
# }
#
# @!attribute [rw] project_arn
# The Amazon Resource Name (ARN) of the project that the project
# policy is attached to.
# @return [String]
#
# @!attribute [rw] policy_name
# A name for the policy.
# @return [String]
#
# @!attribute [rw] policy_revision_id
# The revision ID for the Project Policy. Each time you modify a
# policy, Amazon Rekognition Custom Labels generates and assigns a new
# `PolicyRevisionId` and then deletes the previous version of the
# policy.
# @return [String]
#
# @!attribute [rw] policy_document
# A resource policy to add to the model. The policy is a JSON
# structure that contains one or more statements that define the
# policy. The policy must follow the IAM syntax. For more information
# about the contents of a JSON policy document, see [IAM JSON policy
# reference][1].
#
#
#
# [1]: https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies.html
# @return [String]
#
class PutProjectPolicyRequest < Struct.new(
:project_arn,
:policy_name,
:policy_revision_id,
:policy_document)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] policy_revision_id
# The ID of the project policy.
# @return [String]
#
class PutProjectPolicyResponse < Struct.new(
:policy_revision_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass RecognizeCelebritiesRequest
# data as a hash:
#
# {
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# }
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
class RecognizeCelebritiesRequest < Struct.new(
:image)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] celebrity_faces
# Details about each celebrity found in the image. Amazon Rekognition
# can detect a maximum of 64 celebrities in an image. Each celebrity
# object includes the following attributes: `Face`, `Confidence`,
# `Emotions`, `Landmarks`, `Pose`, `Quality`, `Smile`, `Id`,
# `KnownGender`, `MatchConfidence`, `Name`, `Urls`.
# @return [Array]
#
# @!attribute [rw] unrecognized_faces
# Details about each unrecognized face in the image.
# @return [Array]
#
# @!attribute [rw] orientation_correction
# Support for estimating image orientation using the the
# OrientationCorrection field has ceased as of August 2021. Any
# returned values for this field included in an API response will
# always be NULL.
#
#
#
# The orientation of the input image (counterclockwise direction). If
# your application displays the image, you can use this value to
# correct the orientation. The bounding box coordinates returned in
# `CelebrityFaces` and `UnrecognizedFaces` represent face locations
# before the image orientation is corrected.
#
# If the input image is in .jpeg format, it might contain exchangeable
# image (Exif) metadata that includes the image's orientation. If so,
# and the Exif metadata for the input image populates the orientation
# field, the value of `OrientationCorrection` is null. The
# `CelebrityFaces` and `UnrecognizedFaces` bounding box coordinates
# represent face locations after Exif metadata is used to correct the
# image orientation. Images in .png format don't contain Exif
# metadata.
#
#
# @return [String]
#
class RecognizeCelebritiesResponse < Struct.new(
:celebrity_faces,
:unrecognized_faces,
:orientation_correction)
SENSITIVE = []
include Aws::Structure
end
# Specifies a location within the frame that Rekognition checks for
# objects of interest such as text, labels, or faces. It uses a
# `BoundingBox` or `Polygon` to set a region of the screen.
#
# A word, face, or label is included in the region if it is more than
# half in that region. If there is more than one region, the word, face,
# or label is compared with all regions of the screen. Any object of
# interest that is more than half in a region is kept in the results.
#
# @note When making an API call, you may pass RegionOfInterest
# data as a hash:
#
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# }
#
# @!attribute [rw] bounding_box
# The box representing a region of interest on screen.
# @return [Types::BoundingBox]
#
# @!attribute [rw] polygon
# Specifies a shape made up of up to 10 `Point` objects to define a
# region of interest.
# @return [Array]
#
class RegionOfInterest < Struct.new(
:bounding_box,
:polygon)
SENSITIVE = []
include Aws::Structure
end
# A resource with the specified ID already exists.
#
class ResourceAlreadyExistsException < Aws::EmptyStructure; end
# The specified resource is already being used.
#
class ResourceInUseException < Aws::EmptyStructure; end
# The resource specified in the request cannot be found.
#
class ResourceNotFoundException < Aws::EmptyStructure; end
# The requested resource isn't ready. For example, this exception
# occurs when you call `DetectCustomLabels` with a model version that
# isn't deployed.
#
class ResourceNotReadyException < Aws::EmptyStructure; end
# The Amazon S3 bucket location to which Amazon Rekognition publishes
# the detailed inference results of a video analysis operation. These
# results include the name of the stream processor resource, the session
# ID of the stream processing session, and labeled timestamps and
# bounding boxes for detected labels.
#
# @note When making an API call, you may pass S3Destination
# data as a hash:
#
# {
# bucket: "S3Bucket",
# key_prefix: "S3KeyPrefix",
# }
#
# @!attribute [rw] bucket
# The name of the Amazon S3 bucket you want to associate with the
# streaming video project. You must be the owner of the Amazon S3
# bucket.
# @return [String]
#
# @!attribute [rw] key_prefix
# The prefix value of the location within the bucket that you want the
# information to be published to. For more information, see [Using
# prefixes][1].
#
#
#
# [1]: https://docs.aws.amazon.com/AmazonS3/latest/userguide/using-prefixes.html
# @return [String]
#
class S3Destination < Struct.new(
:bucket,
:key_prefix)
SENSITIVE = []
include Aws::Structure
end
# Provides the S3 bucket name and object name.
#
# The region for the S3 bucket containing the S3 object must match the
# region you use for Amazon Rekognition operations.
#
# For Amazon Rekognition to process an S3 object, the user must have
# permission to access the S3 object. For more information, see How
# Amazon Rekognition works with IAM in the Amazon Rekognition Developer
# Guide.
#
# @note When making an API call, you may pass S3Object
# data as a hash:
#
# {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# }
#
# @!attribute [rw] bucket
# Name of the S3 bucket.
# @return [String]
#
# @!attribute [rw] name
# S3 object key name.
# @return [String]
#
# @!attribute [rw] version
# If the bucket is versioning enabled, you can specify the object
# version.
# @return [String]
#
class S3Object < Struct.new(
:bucket,
:name,
:version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass SearchFacesByImageRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# image: { # required
# bytes: "data",
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# max_faces: 1,
# face_match_threshold: 1.0,
# quality_filter: "NONE", # accepts NONE, AUTO, LOW, MEDIUM, HIGH
# }
#
# @!attribute [rw] collection_id
# ID of the collection to search.
# @return [String]
#
# @!attribute [rw] image
# The input image as base64-encoded bytes or an S3 object. If you use
# the AWS CLI to call Amazon Rekognition operations, passing
# base64-encoded image bytes is not supported.
#
# If you are using an AWS SDK to call Amazon Rekognition, you might
# not need to base64-encode image bytes passed using the `Bytes`
# field. For more information, see Images in the Amazon Rekognition
# developer guide.
# @return [Types::Image]
#
# @!attribute [rw] max_faces
# Maximum number of faces to return. The operation returns the maximum
# number of faces with the highest confidence in the match.
# @return [Integer]
#
# @!attribute [rw] face_match_threshold
# (Optional) Specifies the minimum confidence in the face match to
# return. For example, don't return any matches where confidence in
# matches is less than 70%. The default value is 80%.
# @return [Float]
#
# @!attribute [rw] quality_filter
# A filter that specifies a quality bar for how much filtering is done
# to identify faces. Filtered faces aren't searched for in the
# collection. If you specify `AUTO`, Amazon Rekognition chooses the
# quality bar. If you specify `LOW`, `MEDIUM`, or `HIGH`, filtering
# removes all faces that don’t meet the chosen quality bar. The
# quality bar is based on a variety of common use cases. Low-quality
# detections can occur for a number of reasons. Some examples are an
# object that's misidentified as a face, a face that's too blurry,
# or a face with a pose that's too extreme to use. If you specify
# `NONE`, no filtering is performed. The default value is `NONE`.
#
# To use quality filtering, the collection you are using must be
# associated with version 3 of the face model or higher.
# @return [String]
#
class SearchFacesByImageRequest < Struct.new(
:collection_id,
:image,
:max_faces,
:face_match_threshold,
:quality_filter)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] searched_face_bounding_box
# The bounding box around the face in the input image that Amazon
# Rekognition used for the search.
# @return [Types::BoundingBox]
#
# @!attribute [rw] searched_face_confidence
# The level of confidence that the `searchedFaceBoundingBox`, contains
# a face.
# @return [Float]
#
# @!attribute [rw] face_matches
# An array of faces that match the input face, along with the
# confidence in the match.
# @return [Array]
#
# @!attribute [rw] face_model_version
# Version number of the face detection model associated with the input
# collection (`CollectionId`).
# @return [String]
#
class SearchFacesByImageResponse < Struct.new(
:searched_face_bounding_box,
:searched_face_confidence,
:face_matches,
:face_model_version)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass SearchFacesRequest
# data as a hash:
#
# {
# collection_id: "CollectionId", # required
# face_id: "FaceId", # required
# max_faces: 1,
# face_match_threshold: 1.0,
# }
#
# @!attribute [rw] collection_id
# ID of the collection the face belongs to.
# @return [String]
#
# @!attribute [rw] face_id
# ID of a face to find matches for in the collection.
# @return [String]
#
# @!attribute [rw] max_faces
# Maximum number of faces to return. The operation returns the maximum
# number of faces with the highest confidence in the match.
# @return [Integer]
#
# @!attribute [rw] face_match_threshold
# Optional value specifying the minimum confidence in the face match
# to return. For example, don't return any matches where confidence
# in matches is less than 70%. The default value is 80%.
# @return [Float]
#
class SearchFacesRequest < Struct.new(
:collection_id,
:face_id,
:max_faces,
:face_match_threshold)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] searched_face_id
# ID of the face that was searched for matches in a collection.
# @return [String]
#
# @!attribute [rw] face_matches
# An array of faces that matched the input face, along with the
# confidence in the match.
# @return [Array]
#
# @!attribute [rw] face_model_version
# Version number of the face detection model associated with the input
# collection (`CollectionId`).
# @return [String]
#
class SearchFacesResponse < Struct.new(
:searched_face_id,
:face_matches,
:face_model_version)
SENSITIVE = []
include Aws::Structure
end
# A technical cue or shot detection segment detected in a video. An
# array of `SegmentDetection` objects containing all segments detected
# in a stored video is returned by GetSegmentDetection.
#
# @!attribute [rw] type
# The type of the segment. Valid values are `TECHNICAL_CUE` and
# `SHOT`.
# @return [String]
#
# @!attribute [rw] start_timestamp_millis
# The start time of the detected segment in milliseconds from the
# start of the video. This value is rounded down. For example, if the
# actual timestamp is 100.6667 milliseconds, Amazon Rekognition Video
# returns a value of 100 millis.
# @return [Integer]
#
# @!attribute [rw] end_timestamp_millis
# The end time of the detected segment, in milliseconds, from the
# start of the video. This value is rounded down.
# @return [Integer]
#
# @!attribute [rw] duration_millis
# The duration of the detected segment in milliseconds.
# @return [Integer]
#
# @!attribute [rw] start_timecode_smpte
# The frame-accurate SMPTE timecode, from the start of a video, for
# the start of a detected segment. `StartTimecode` is in *HH:MM:SS:fr*
# format (and *;fr* for drop frame-rates).
# @return [String]
#
# @!attribute [rw] end_timecode_smpte
# The frame-accurate SMPTE timecode, from the start of a video, for
# the end of a detected segment. `EndTimecode` is in *HH:MM:SS:fr*
# format (and *;fr* for drop frame-rates).
# @return [String]
#
# @!attribute [rw] duration_smpte
# The duration of the timecode for the detected segment in SMPTE
# format.
# @return [String]
#
# @!attribute [rw] technical_cue_segment
# If the segment is a technical cue, contains information about the
# technical cue.
# @return [Types::TechnicalCueSegment]
#
# @!attribute [rw] shot_segment
# If the segment is a shot detection, contains information about the
# shot detection.
# @return [Types::ShotSegment]
#
# @!attribute [rw] start_frame_number
# The frame number of the start of a video segment, using a frame
# index that starts with 0.
# @return [Integer]
#
# @!attribute [rw] end_frame_number
# The frame number at the end of a video segment, using a frame index
# that starts with 0.
# @return [Integer]
#
# @!attribute [rw] duration_frames
# The duration of a video segment, expressed in frames.
# @return [Integer]
#
class SegmentDetection < Struct.new(
:type,
:start_timestamp_millis,
:end_timestamp_millis,
:duration_millis,
:start_timecode_smpte,
:end_timecode_smpte,
:duration_smpte,
:technical_cue_segment,
:shot_segment,
:start_frame_number,
:end_frame_number,
:duration_frames)
SENSITIVE = []
include Aws::Structure
end
# Information about the type of a segment requested in a call to
# StartSegmentDetection. An array of `SegmentTypeInfo` objects is
# returned by the response from GetSegmentDetection.
#
# @!attribute [rw] type
# The type of a segment (technical cue or shot detection).
# @return [String]
#
# @!attribute [rw] model_version
# The version of the model used to detect segments.
# @return [String]
#
class SegmentTypeInfo < Struct.new(
:type,
:model_version)
SENSITIVE = []
include Aws::Structure
end
# The size of the collection exceeds the allowed limit. For more
# information, see Guidelines and quotas in Amazon Rekognition in the
# Amazon Rekognition Developer Guide.
#
class ServiceQuotaExceededException < Aws::EmptyStructure; end
# Information about a shot detection segment detected in a video. For
# more information, see SegmentDetection.
#
# @!attribute [rw] index
# An Identifier for a shot detection segment detected in a video.
# @return [Integer]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition Video has in the accuracy of
# the detected segment.
# @return [Float]
#
class ShotSegment < Struct.new(
:index,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the face is smiling, and the confidence level
# in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the face is smiling or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Smile < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartCelebrityRecognitionRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video in which you want to recognize celebrities. The video must
# be stored in an Amazon S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartCelebrityRecognition` requests, the
# same `JobId` is returned. Use `ClientRequestToken` to prevent the
# same job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The Amazon SNS topic ARN that you want Amazon Rekognition Video to
# publish the completion status of the celebrity recognition analysis
# to. The Amazon SNS topic must have a topic name that begins with
# *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartCelebrityRecognitionRequest < Struct.new(
:video,
:client_request_token,
:notification_channel,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the celebrity recognition analysis job. Use
# `JobId` to identify the job in a subsequent call to
# `GetCelebrityRecognition`.
# @return [String]
#
class StartCelebrityRecognitionResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartContentModerationRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# min_confidence: 1.0,
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video in which you want to detect inappropriate, unwanted, or
# offensive content. The video must be stored in an Amazon S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] min_confidence
# Specifies the minimum confidence that Amazon Rekognition must have
# in order to return a moderated content label. Confidence represents
# how certain Amazon Rekognition is that the moderated content is
# correctly identified. 0 is the lowest confidence. 100 is the highest
# confidence. Amazon Rekognition doesn't return any moderated content
# labels with a confidence level lower than this specified value. If
# you don't specify `MinConfidence`, `GetContentModeration` returns
# labels with confidence values greater than or equal to 50 percent.
# @return [Float]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartContentModeration` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The Amazon SNS topic ARN that you want Amazon Rekognition Video to
# publish the completion status of the content analysis to. The Amazon
# SNS topic must have a topic name that begins with
# *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy to access the topic.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartContentModerationRequest < Struct.new(
:video,
:min_confidence,
:client_request_token,
:notification_channel,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the content analysis job. Use `JobId` to identify
# the job in a subsequent call to `GetContentModeration`.
# @return [String]
#
class StartContentModerationResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartFaceDetectionRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# face_attributes: "DEFAULT", # accepts DEFAULT, ALL
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video in which you want to detect faces. The video must be
# stored in an Amazon S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartFaceDetection` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The ARN of the Amazon SNS topic to which you want Amazon Rekognition
# Video to publish the completion status of the face detection
# operation. The Amazon SNS topic must have a topic name that begins
# with *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] face_attributes
# The face attributes you want returned.
#
# `DEFAULT` - The following subset of facial attributes are returned:
# BoundingBox, Confidence, Pose, Quality and Landmarks.
#
# `ALL` - All facial attributes are returned.
# @return [String]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartFaceDetectionRequest < Struct.new(
:video,
:client_request_token,
:notification_channel,
:face_attributes,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the face detection job. Use `JobId` to identify
# the job in a subsequent call to `GetFaceDetection`.
# @return [String]
#
class StartFaceDetectionResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartFaceSearchRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# face_match_threshold: 1.0,
# collection_id: "CollectionId", # required
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video you want to search. The video must be stored in an Amazon
# S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartFaceSearch` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] face_match_threshold
# The minimum confidence in the person match to return. For example,
# don't return any matches where confidence in matches is less than
# 70%. The default value is 80%.
# @return [Float]
#
# @!attribute [rw] collection_id
# ID of the collection that contains the faces you want to search for.
# @return [String]
#
# @!attribute [rw] notification_channel
# The ARN of the Amazon SNS topic to which you want Amazon Rekognition
# Video to publish the completion status of the search. The Amazon SNS
# topic must have a topic name that begins with *AmazonRekognition* if
# you are using the AmazonRekognitionServiceRole permissions policy to
# access the topic.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartFaceSearchRequest < Struct.new(
:video,
:client_request_token,
:face_match_threshold,
:collection_id,
:notification_channel,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the search job. Use `JobId` to identify the job
# in a subsequent call to `GetFaceSearch`.
# @return [String]
#
class StartFaceSearchResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartLabelDetectionRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# min_confidence: 1.0,
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video in which you want to detect labels. The video must be
# stored in an Amazon S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartLabelDetection` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] min_confidence
# Specifies the minimum confidence that Amazon Rekognition Video must
# have in order to return a detected label. Confidence represents how
# certain Amazon Rekognition is that a label is correctly identified.0
# is the lowest confidence. 100 is the highest confidence. Amazon
# Rekognition Video doesn't return any labels with a confidence level
# lower than this specified value.
#
# If you don't specify `MinConfidence`, the operation returns labels
# with confidence values greater than or equal to 50 percent.
# @return [Float]
#
# @!attribute [rw] notification_channel
# The Amazon SNS topic ARN you want Amazon Rekognition Video to
# publish the completion status of the label detection operation to.
# The Amazon SNS topic must have a topic name that begins with
# *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartLabelDetectionRequest < Struct.new(
:video,
:client_request_token,
:min_confidence,
:notification_channel,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the label detection job. Use `JobId` to identify
# the job in a subsequent call to `GetLabelDetection`.
# @return [String]
#
class StartLabelDetectionResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartPersonTrackingRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# }
#
# @!attribute [rw] video
# The video in which you want to detect people. The video must be
# stored in an Amazon S3 bucket.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartPersonTracking` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The Amazon SNS topic ARN you want Amazon Rekognition Video to
# publish the completion status of the people detection operation to.
# The Amazon SNS topic must have a topic name that begins with
# *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
class StartPersonTrackingRequest < Struct.new(
:video,
:client_request_token,
:notification_channel,
:job_tag)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# The identifier for the person detection job. Use `JobId` to identify
# the job in a subsequent call to `GetPersonTracking`.
# @return [String]
#
class StartPersonTrackingResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartProjectVersionRequest
# data as a hash:
#
# {
# project_version_arn: "ProjectVersionArn", # required
# min_inference_units: 1, # required
# max_inference_units: 1,
# }
#
# @!attribute [rw] project_version_arn
# The Amazon Resource Name(ARN) of the model version that you want to
# start.
# @return [String]
#
# @!attribute [rw] min_inference_units
# The minimum number of inference units to use. A single inference
# unit represents 1 hour of processing.
#
# For information about the number of transactions per second (TPS)
# that an inference unit can support, see *Running a trained Amazon
# Rekognition Custom Labels model* in the Amazon Rekognition Custom
# Labels Guide.
#
# Use a higher number to increase the TPS throughput of your model.
# You are charged for the number of inference units that you use.
# @return [Integer]
#
# @!attribute [rw] max_inference_units
# The maximum number of inference units to use for auto-scaling the
# model. If you don't specify a value, Amazon Rekognition Custom
# Labels doesn't auto-scale the model.
# @return [Integer]
#
class StartProjectVersionRequest < Struct.new(
:project_version_arn,
:min_inference_units,
:max_inference_units)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status
# The current running status of the model.
# @return [String]
#
class StartProjectVersionResponse < Struct.new(
:status)
SENSITIVE = []
include Aws::Structure
end
# Filters applied to the technical cue or shot detection segments. For
# more information, see StartSegmentDetection.
#
# @note When making an API call, you may pass StartSegmentDetectionFilters
# data as a hash:
#
# {
# technical_cue_filter: {
# min_segment_confidence: 1.0,
# black_frame: {
# max_pixel_threshold: 1.0,
# min_coverage_percentage: 1.0,
# },
# },
# shot_filter: {
# min_segment_confidence: 1.0,
# },
# }
#
# @!attribute [rw] technical_cue_filter
# Filters that are specific to technical cues.
# @return [Types::StartTechnicalCueDetectionFilter]
#
# @!attribute [rw] shot_filter
# Filters that are specific to shot detections.
# @return [Types::StartShotDetectionFilter]
#
class StartSegmentDetectionFilters < Struct.new(
:technical_cue_filter,
:shot_filter)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartSegmentDetectionRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# filters: {
# technical_cue_filter: {
# min_segment_confidence: 1.0,
# black_frame: {
# max_pixel_threshold: 1.0,
# min_coverage_percentage: 1.0,
# },
# },
# shot_filter: {
# min_segment_confidence: 1.0,
# },
# },
# segment_types: ["TECHNICAL_CUE"], # required, accepts TECHNICAL_CUE, SHOT
# }
#
# @!attribute [rw] video
# Video file stored in an Amazon S3 bucket. Amazon Rekognition video
# start operations such as StartLabelDetection use `Video` to specify
# a video for analysis. The supported file formats are .mp4, .mov and
# .avi.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartSegmentDetection` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidently started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The ARN of the Amazon SNS topic to which you want Amazon Rekognition
# Video to publish the completion status of the segment detection
# operation. Note that the Amazon SNS topic must have a topic name
# that begins with *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy to access the topic.
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier you specify that's returned in the completion
# notification that's published to your Amazon Simple Notification
# Service topic. For example, you can use `JobTag` to group related
# jobs and identify them in the completion notification.
# @return [String]
#
# @!attribute [rw] filters
# Filters for technical cue or shot detection.
# @return [Types::StartSegmentDetectionFilters]
#
# @!attribute [rw] segment_types
# An array of segment types to detect in the video. Valid values are
# TECHNICAL\_CUE and SHOT.
# @return [Array]
#
class StartSegmentDetectionRequest < Struct.new(
:video,
:client_request_token,
:notification_channel,
:job_tag,
:filters,
:segment_types)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# Unique identifier for the segment detection job. The `JobId` is
# returned from `StartSegmentDetection`.
# @return [String]
#
class StartSegmentDetectionResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# Filters for the shot detection segments returned by
# `GetSegmentDetection`. For more information, see
# StartSegmentDetectionFilters.
#
# @note When making an API call, you may pass StartShotDetectionFilter
# data as a hash:
#
# {
# min_segment_confidence: 1.0,
# }
#
# @!attribute [rw] min_segment_confidence
# Specifies the minimum confidence that Amazon Rekognition Video must
# have in order to return a detected segment. Confidence represents
# how certain Amazon Rekognition is that a segment is correctly
# identified. 0 is the lowest confidence. 100 is the highest
# confidence. Amazon Rekognition Video doesn't return any segments
# with a confidence level lower than this specified value.
#
# If you don't specify `MinSegmentConfidence`, the
# `GetSegmentDetection` returns segments with confidence values
# greater than or equal to 50 percent.
# @return [Float]
#
class StartShotDetectionFilter < Struct.new(
:min_segment_confidence)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartStreamProcessorRequest
# data as a hash:
#
# {
# name: "StreamProcessorName", # required
# start_selector: {
# kvs_stream_start_selector: {
# producer_timestamp: 1,
# fragment_number: "KinesisVideoStreamFragmentNumber",
# },
# },
# stop_selector: {
# max_duration_in_seconds: 1,
# },
# }
#
# @!attribute [rw] name
# The name of the stream processor to start processing.
# @return [String]
#
# @!attribute [rw] start_selector
# Specifies the starting point in the Kinesis stream to start
# processing. You can use the producer timestamp or the fragment
# number. For more information, see [Fragment][1].
#
# This is a required parameter for label detection stream processors
# and should not be used to start a face search stream processor.
#
#
#
# [1]: https://docs.aws.amazon.com/kinesisvideostreams/latest/dg/API_reader_Fragment.html
# @return [Types::StreamProcessingStartSelector]
#
# @!attribute [rw] stop_selector
# Specifies when to stop processing the stream. You can specify a
# maximum amount of time to process the video.
#
# This is a required parameter for label detection stream processors
# and should not be used to start a face search stream processor.
# @return [Types::StreamProcessingStopSelector]
#
class StartStreamProcessorRequest < Struct.new(
:name,
:start_selector,
:stop_selector)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] session_id
# A unique identifier for the stream processing session.
# @return [String]
#
class StartStreamProcessorResponse < Struct.new(
:session_id)
SENSITIVE = []
include Aws::Structure
end
# Filters for the technical segments returned by GetSegmentDetection.
# For more information, see StartSegmentDetectionFilters.
#
# @note When making an API call, you may pass StartTechnicalCueDetectionFilter
# data as a hash:
#
# {
# min_segment_confidence: 1.0,
# black_frame: {
# max_pixel_threshold: 1.0,
# min_coverage_percentage: 1.0,
# },
# }
#
# @!attribute [rw] min_segment_confidence
# Specifies the minimum confidence that Amazon Rekognition Video must
# have in order to return a detected segment. Confidence represents
# how certain Amazon Rekognition is that a segment is correctly
# identified. 0 is the lowest confidence. 100 is the highest
# confidence. Amazon Rekognition Video doesn't return any segments
# with a confidence level lower than this specified value.
#
# If you don't specify `MinSegmentConfidence`, `GetSegmentDetection`
# returns segments with confidence values greater than or equal to 50
# percent.
# @return [Float]
#
# @!attribute [rw] black_frame
# 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. Videos can come from multiple sources, formats, and time
# periods, with different standards and varying noise levels for black
# frames that need to be accounted for.
# @return [Types::BlackFrame]
#
class StartTechnicalCueDetectionFilter < Struct.new(
:min_segment_confidence,
:black_frame)
SENSITIVE = []
include Aws::Structure
end
# Set of optional parameters that let you set the criteria text must
# meet to be included in your response. `WordFilter` looks at a word's
# height, width and minimum confidence. `RegionOfInterest` lets you set
# a specific region of the screen to look for text in.
#
# @note When making an API call, you may pass StartTextDetectionFilters
# data as a hash:
#
# {
# word_filter: {
# min_confidence: 1.0,
# min_bounding_box_height: 1.0,
# min_bounding_box_width: 1.0,
# },
# regions_of_interest: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# }
#
# @!attribute [rw] word_filter
# Filters focusing on qualities of the text, such as confidence or
# size.
# @return [Types::DetectionFilter]
#
# @!attribute [rw] regions_of_interest
# Filter focusing on a certain area of the frame. Uses a `BoundingBox`
# object to set the region of the screen.
# @return [Array]
#
class StartTextDetectionFilters < Struct.new(
:word_filter,
:regions_of_interest)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StartTextDetectionRequest
# data as a hash:
#
# {
# video: { # required
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# client_request_token: "ClientRequestToken",
# notification_channel: {
# sns_topic_arn: "SNSTopicArn", # required
# role_arn: "RoleArn", # required
# },
# job_tag: "JobTag",
# filters: {
# word_filter: {
# min_confidence: 1.0,
# min_bounding_box_height: 1.0,
# min_bounding_box_width: 1.0,
# },
# regions_of_interest: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# },
# }
#
# @!attribute [rw] video
# Video file stored in an Amazon S3 bucket. Amazon Rekognition video
# start operations such as StartLabelDetection use `Video` to specify
# a video for analysis. The supported file formats are .mp4, .mov and
# .avi.
# @return [Types::Video]
#
# @!attribute [rw] client_request_token
# Idempotent token used to identify the start request. If you use the
# same token with multiple `StartTextDetection` requests, the same
# `JobId` is returned. Use `ClientRequestToken` to prevent the same
# job from being accidentaly started more than once.
# @return [String]
#
# @!attribute [rw] notification_channel
# The Amazon Simple Notification Service topic to which Amazon
# Rekognition publishes the completion status of a video analysis
# operation. For more information, see [Calling Amazon Rekognition
# Video operations][1]. Note that the Amazon SNS topic must have a
# topic name that begins with *AmazonRekognition* if you are using the
# AmazonRekognitionServiceRole permissions policy to access the topic.
# For more information, see [Giving access to multiple Amazon SNS
# topics][2].
#
#
#
# [1]: https://docs.aws.amazon.com/rekognition/latest/dg/api-video.html
# [2]: https://docs.aws.amazon.com/rekognition/latest/dg/api-video-roles.html#api-video-roles-all-topics
# @return [Types::NotificationChannel]
#
# @!attribute [rw] job_tag
# An identifier returned in the completion status published by your
# Amazon Simple Notification Service topic. For example, you can use
# `JobTag` to group related jobs and identify them in the completion
# notification.
# @return [String]
#
# @!attribute [rw] filters
# Optional parameters that let you set criteria the text must meet to
# be included in your response.
# @return [Types::StartTextDetectionFilters]
#
class StartTextDetectionRequest < Struct.new(
:video,
:client_request_token,
:notification_channel,
:job_tag,
:filters)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] job_id
# Identifier for the text detection job. Use `JobId` to identify the
# job in a subsequent call to `GetTextDetection`.
# @return [String]
#
class StartTextDetectionResponse < Struct.new(
:job_id)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StopProjectVersionRequest
# data as a hash:
#
# {
# project_version_arn: "ProjectVersionArn", # required
# }
#
# @!attribute [rw] project_version_arn
# The Amazon Resource Name (ARN) of the model version that you want to
# delete.
#
# This operation requires permissions to perform the
# `rekognition:StopProjectVersion` action.
# @return [String]
#
class StopProjectVersionRequest < Struct.new(
:project_version_arn)
SENSITIVE = []
include Aws::Structure
end
# @!attribute [rw] status
# The current status of the stop operation.
# @return [String]
#
class StopProjectVersionResponse < Struct.new(
:status)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass StopStreamProcessorRequest
# data as a hash:
#
# {
# name: "StreamProcessorName", # required
# }
#
# @!attribute [rw] name
# The name of a stream processor created by CreateStreamProcessor.
# @return [String]
#
class StopStreamProcessorRequest < Struct.new(
:name)
SENSITIVE = []
include Aws::Structure
end
class StopStreamProcessorResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass StreamProcessingStartSelector
# data as a hash:
#
# {
# kvs_stream_start_selector: {
# producer_timestamp: 1,
# fragment_number: "KinesisVideoStreamFragmentNumber",
# },
# }
#
# @!attribute [rw] kvs_stream_start_selector
# Specifies the starting point in the stream to start processing. This
# can be done with a timestamp or a fragment number in a Kinesis
# stream.
# @return [Types::KinesisVideoStreamStartSelector]
#
class StreamProcessingStartSelector < Struct.new(
:kvs_stream_start_selector)
SENSITIVE = []
include Aws::Structure
end
# Specifies when to stop processing the stream. You can specify a
# maximum amount of time to process the video.
#
# @note When making an API call, you may pass StreamProcessingStopSelector
# data as a hash:
#
# {
# max_duration_in_seconds: 1,
# }
#
# @!attribute [rw] max_duration_in_seconds
# Specifies the maximum amount of time in seconds that you want the
# stream to be processed. The largest amount of time is 2 minutes. The
# default is 10 seconds.
# @return [Integer]
#
class StreamProcessingStopSelector < Struct.new(
:max_duration_in_seconds)
SENSITIVE = []
include Aws::Structure
end
# An object that recognizes faces or labels in a streaming video. An
# Amazon Rekognition stream processor is created by a call to
# CreateStreamProcessor. The request parameters for
# `CreateStreamProcessor` describe the Kinesis video stream source for
# the streaming video, face recognition parameters, and where to stream
# the analysis resullts.
#
# @!attribute [rw] name
# Name of the Amazon Rekognition stream processor.
# @return [String]
#
# @!attribute [rw] status
# Current status of the Amazon Rekognition stream processor.
# @return [String]
#
class StreamProcessor < Struct.new(
:name,
:status)
SENSITIVE = []
include Aws::Structure
end
# Allows you to opt in or opt out to share data with Rekognition to
# improve model performance. You can choose this option at the account
# level or on a per-stream basis. Note that if you opt out at the
# account level this setting is ignored on individual streams.
#
# @note When making an API call, you may pass StreamProcessorDataSharingPreference
# data as a hash:
#
# {
# opt_in: false, # required
# }
#
# @!attribute [rw] opt_in
# If this option is set to true, you choose to share data with
# Rekognition to improve model performance.
# @return [Boolean]
#
class StreamProcessorDataSharingPreference < Struct.new(
:opt_in)
SENSITIVE = []
include Aws::Structure
end
# Information about the source streaming video.
#
# @note When making an API call, you may pass StreamProcessorInput
# data as a hash:
#
# {
# kinesis_video_stream: {
# arn: "KinesisVideoArn",
# },
# }
#
# @!attribute [rw] kinesis_video_stream
# The Kinesis video stream input stream for the source streaming
# video.
# @return [Types::KinesisVideoStream]
#
class StreamProcessorInput < Struct.new(
:kinesis_video_stream)
SENSITIVE = []
include Aws::Structure
end
# The Amazon Simple Notification Service topic to which Amazon
# Rekognition publishes the object detection results and completion
# status of a video analysis operation.
#
# Amazon Rekognition publishes a notification the first time an object
# of interest or a person is detected in the video stream. For example,
# if Amazon Rekognition detects a person at second 2, a pet at second 4,
# and a person again at second 5, Amazon Rekognition sends 2 object
# class detected notifications, one for a person at second 2 and one for
# a pet at second 4.
#
# Amazon Rekognition also publishes an an end-of-session notification
# with a summary when the stream processing session is complete.
#
# @note When making an API call, you may pass StreamProcessorNotificationChannel
# data as a hash:
#
# {
# sns_topic_arn: "SNSTopicArn", # required
# }
#
# @!attribute [rw] sns_topic_arn
# The Amazon Resource Number (ARN) of the Amazon Amazon Simple
# Notification Service topic to which Amazon Rekognition posts the
# completion status.
# @return [String]
#
class StreamProcessorNotificationChannel < Struct.new(
:sns_topic_arn)
SENSITIVE = []
include Aws::Structure
end
# Information about the Amazon Kinesis Data Streams stream to which a
# Amazon Rekognition Video stream processor streams the results of a
# video analysis. For more information, see CreateStreamProcessor in the
# Amazon Rekognition Developer Guide.
#
# @note When making an API call, you may pass StreamProcessorOutput
# data as a hash:
#
# {
# kinesis_data_stream: {
# arn: "KinesisDataArn",
# },
# s3_destination: {
# bucket: "S3Bucket",
# key_prefix: "S3KeyPrefix",
# },
# }
#
# @!attribute [rw] kinesis_data_stream
# The Amazon Kinesis Data Streams stream to which the Amazon
# Rekognition stream processor streams the analysis results.
# @return [Types::KinesisDataStream]
#
# @!attribute [rw] s3_destination
# The Amazon S3 bucket location to which Amazon Rekognition publishes
# the detailed inference results of a video analysis operation.
# @return [Types::S3Destination]
#
class StreamProcessorOutput < Struct.new(
:kinesis_data_stream,
:s3_destination)
SENSITIVE = []
include Aws::Structure
end
# Input parameters used in a streaming video analyzed by a Amazon
# Rekognition stream processor. You can use `FaceSearch` to recognize
# faces in a streaming video, or you can use `ConnectedHome` to detect
# labels.
#
# @note When making an API call, you may pass StreamProcessorSettings
# data as a hash:
#
# {
# face_search: {
# collection_id: "CollectionId",
# face_match_threshold: 1.0,
# },
# connected_home: {
# labels: ["ConnectedHomeLabel"], # required
# min_confidence: 1.0,
# },
# }
#
# @!attribute [rw] face_search
# Face search settings to use on a streaming video.
# @return [Types::FaceSearchSettings]
#
# @!attribute [rw] connected_home
# Label detection settings to use on a streaming video. Defining the
# settings is required in the request parameter for
# CreateStreamProcessor. Including this setting in the
# `CreateStreamProcessor` request enables you to use the stream
# processor for label detection. You can then select what you want the
# stream processor to detect, such as people or pets. When the stream
# processor has started, one notification is sent for each object
# class specified. For example, if packages and pets are selected, one
# SNS notification is published the first time a package is detected
# and one SNS notification is published the first time a pet is
# detected, as well as an end-of-session summary.
# @return [Types::ConnectedHomeSettings]
#
class StreamProcessorSettings < Struct.new(
:face_search,
:connected_home)
SENSITIVE = []
include Aws::Structure
end
# The stream processor settings that you want to update. `ConnectedHome`
# settings can be updated to detect different labels with a different
# minimum confidence.
#
# @note When making an API call, you may pass StreamProcessorSettingsForUpdate
# data as a hash:
#
# {
# connected_home_for_update: {
# labels: ["ConnectedHomeLabel"],
# min_confidence: 1.0,
# },
# }
#
# @!attribute [rw] connected_home_for_update
# The label detection settings you want to use for your stream
# processor.
# @return [Types::ConnectedHomeSettingsForUpdate]
#
class StreamProcessorSettingsForUpdate < Struct.new(
:connected_home_for_update)
SENSITIVE = []
include Aws::Structure
end
# The S3 bucket that contains the training summary. The training summary
# includes aggregated evaluation metrics for the entire testing dataset
# and metrics for each individual label.
#
# You get the training summary S3 bucket location by calling
# DescribeProjectVersions.
#
# @!attribute [rw] s3_object
# Provides the S3 bucket name and object name.
#
# The region for the S3 bucket containing the S3 object must match the
# region you use for Amazon Rekognition operations.
#
# For Amazon Rekognition to process an S3 object, the user must have
# permission to access the S3 object. For more information, see How
# Amazon Rekognition works with IAM in the Amazon Rekognition
# Developer Guide.
# @return [Types::S3Object]
#
class Summary < Struct.new(
:s3_object)
SENSITIVE = []
include Aws::Structure
end
# Indicates whether or not the face is wearing sunglasses, and the
# confidence level in the determination.
#
# @!attribute [rw] value
# Boolean value that indicates whether the face is wearing sunglasses
# or not.
# @return [Boolean]
#
# @!attribute [rw] confidence
# Level of confidence in the determination.
# @return [Float]
#
class Sunglasses < Struct.new(
:value,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass TagResourceRequest
# data as a hash:
#
# {
# resource_arn: "ResourceArn", # required
# tags: { # required
# "TagKey" => "TagValue",
# },
# }
#
# @!attribute [rw] resource_arn
# Amazon Resource Name (ARN) of the model, collection, or stream
# processor that you want to assign the tags to.
# @return [String]
#
# @!attribute [rw] tags
# The key-value tags to assign to the resource.
# @return [Hash]
#
class TagResourceRequest < Struct.new(
:resource_arn,
:tags)
SENSITIVE = []
include Aws::Structure
end
class TagResourceResponse < Aws::EmptyStructure; end
# Information about a technical cue segment. For more information, see
# SegmentDetection.
#
# @!attribute [rw] type
# The type of the technical cue.
# @return [String]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition Video has in the accuracy of
# the detected segment.
# @return [Float]
#
class TechnicalCueSegment < Struct.new(
:type,
:confidence)
SENSITIVE = []
include Aws::Structure
end
# The dataset used for testing. Optionally, if `AutoCreate` is set,
# Amazon Rekognition Custom Labels uses the training dataset to create a
# test dataset with a temporary split of the training dataset.
#
# @note When making an API call, you may pass TestingData
# data as a hash:
#
# {
# assets: [
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# },
# ],
# auto_create: false,
# }
#
# @!attribute [rw] assets
# The assets used for testing.
# @return [Array]
#
# @!attribute [rw] auto_create
# If specified, Amazon Rekognition Custom Labels temporarily splits
# the training dataset (80%) to create a test dataset (20%) for the
# training job. After training completes, the test dataset is not
# stored and the training dataset reverts to its previous size.
# @return [Boolean]
#
class TestingData < Struct.new(
:assets,
:auto_create)
SENSITIVE = []
include Aws::Structure
end
# Sagemaker Groundtruth format manifest files for the input, output and
# validation datasets that are used and created during testing.
#
# @!attribute [rw] input
# The testing dataset that was supplied for training.
# @return [Types::TestingData]
#
# @!attribute [rw] output
# The subset of the dataset that was actually tested. Some images
# (assets) might not be tested due to file formatting and other
# issues.
# @return [Types::TestingData]
#
# @!attribute [rw] validation
# The location of the data validation manifest. The data validation
# manifest is created for the test dataset during model training.
# @return [Types::ValidationData]
#
class TestingDataResult < Struct.new(
:input,
:output,
:validation)
SENSITIVE = []
include Aws::Structure
end
# Information about a word or line of text detected by DetectText.
#
# The `DetectedText` field contains the text that Amazon Rekognition
# detected in the image.
#
# Every word and line has an identifier (`Id`). Each word belongs to a
# line and has a parent identifier (`ParentId`) that identifies the line
# of text in which the word appears. The word `Id` is also an index for
# the word within a line of words.
#
# For more information, see Detecting text in the Amazon Rekognition
# Developer Guide.
#
# @!attribute [rw] detected_text
# The word or line of text recognized by Amazon Rekognition.
# @return [String]
#
# @!attribute [rw] type
# The type of text that was detected.
# @return [String]
#
# @!attribute [rw] id
# The identifier for the detected text. The identifier is only unique
# for a single call to `DetectText`.
# @return [Integer]
#
# @!attribute [rw] parent_id
# The Parent identifier for the detected text identified by the value
# of `ID`. If the type of detected text is `LINE`, the value of
# `ParentId` is `Null`.
# @return [Integer]
#
# @!attribute [rw] confidence
# The confidence that Amazon Rekognition has in the accuracy of the
# detected text and the accuracy of the geometry points around the
# detected text.
# @return [Float]
#
# @!attribute [rw] geometry
# The location of the detected text on the image. Includes an axis
# aligned coarse bounding box surrounding the text and a finer grain
# polygon for more accurate spatial information.
# @return [Types::Geometry]
#
class TextDetection < Struct.new(
:detected_text,
:type,
:id,
:parent_id,
:confidence,
:geometry)
SENSITIVE = []
include Aws::Structure
end
# Information about text detected in a video. Incudes the detected text,
# the time in milliseconds from the start of the video that the text was
# detected, and where it was detected on the screen.
#
# @!attribute [rw] timestamp
# The time, in milliseconds from the start of the video, that the text
# was detected.
# @return [Integer]
#
# @!attribute [rw] text_detection
# Details about text detected in a video.
# @return [Types::TextDetection]
#
class TextDetectionResult < Struct.new(
:timestamp,
:text_detection)
SENSITIVE = []
include Aws::Structure
end
# Amazon Rekognition is temporarily unable to process the request. Try
# your call again.
#
class ThrottlingException < Aws::EmptyStructure; end
# The dataset used for training.
#
# @note When making an API call, you may pass TrainingData
# data as a hash:
#
# {
# assets: [
# {
# ground_truth_manifest: {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# },
# },
# ],
# }
#
# @!attribute [rw] assets
# A Sagemaker GroundTruth manifest file that contains the training
# images (assets).
# @return [Array]
#
class TrainingData < Struct.new(
:assets)
SENSITIVE = []
include Aws::Structure
end
# Sagemaker Groundtruth format manifest files for the input, output and
# validation datasets that are used and created during testing.
#
# @!attribute [rw] input
# The training assets that you supplied for training.
# @return [Types::TrainingData]
#
# @!attribute [rw] output
# The images (assets) that were actually trained by Amazon Rekognition
# Custom Labels.
# @return [Types::TrainingData]
#
# @!attribute [rw] validation
# The location of the data validation manifest. The data validation
# manifest is created for the training dataset during model training.
# @return [Types::ValidationData]
#
class TrainingDataResult < Struct.new(
:input,
:output,
:validation)
SENSITIVE = []
include Aws::Structure
end
# A face that IndexFaces detected, but didn't index. Use the `Reasons`
# response attribute to determine why a face wasn't indexed.
#
# @!attribute [rw] reasons
# An array of reasons that specify why a face wasn't indexed.
#
# * EXTREME\_POSE - The face is at a pose that can't be detected. For
# example, the head is turned too far away from the camera.
#
# * EXCEEDS\_MAX\_FACES - The number of faces detected is already
# higher than that specified by the `MaxFaces` input parameter for
# `IndexFaces`.
#
# * LOW\_BRIGHTNESS - The image is too dark.
#
# * LOW\_SHARPNESS - The image is too blurry.
#
# * LOW\_CONFIDENCE - The face was detected with a low confidence.
#
# * SMALL\_BOUNDING\_BOX - The bounding box around the face is too
# small.
# @return [Array]
#
# @!attribute [rw] face_detail
# The structure that contains attributes of a face that
# `IndexFaces`detected, but didn't index.
# @return [Types::FaceDetail]
#
class UnindexedFace < Struct.new(
:reasons,
:face_detail)
SENSITIVE = []
include Aws::Structure
end
# @note When making an API call, you may pass UntagResourceRequest
# data as a hash:
#
# {
# resource_arn: "ResourceArn", # required
# tag_keys: ["TagKey"], # required
# }
#
# @!attribute [rw] resource_arn
# Amazon Resource Name (ARN) of the model, collection, or stream
# processor that you want to remove the tags from.
# @return [String]
#
# @!attribute [rw] tag_keys
# A list of the tags that you want to remove.
# @return [Array]
#
class UntagResourceRequest < Struct.new(
:resource_arn,
:tag_keys)
SENSITIVE = []
include Aws::Structure
end
class UntagResourceResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass UpdateDatasetEntriesRequest
# data as a hash:
#
# {
# dataset_arn: "DatasetArn", # required
# changes: { # required
# ground_truth: "data", # required
# },
# }
#
# @!attribute [rw] dataset_arn
# The Amazon Resource Name (ARN) of the dataset that you want to
# update.
# @return [String]
#
# @!attribute [rw] changes
# The changes that you want to make to the dataset.
# @return [Types::DatasetChanges]
#
class UpdateDatasetEntriesRequest < Struct.new(
:dataset_arn,
:changes)
SENSITIVE = []
include Aws::Structure
end
class UpdateDatasetEntriesResponse < Aws::EmptyStructure; end
# @note When making an API call, you may pass UpdateStreamProcessorRequest
# data as a hash:
#
# {
# name: "StreamProcessorName", # required
# settings_for_update: {
# connected_home_for_update: {
# labels: ["ConnectedHomeLabel"],
# min_confidence: 1.0,
# },
# },
# regions_of_interest_for_update: [
# {
# bounding_box: {
# width: 1.0,
# height: 1.0,
# left: 1.0,
# top: 1.0,
# },
# polygon: [
# {
# x: 1.0,
# y: 1.0,
# },
# ],
# },
# ],
# data_sharing_preference_for_update: {
# opt_in: false, # required
# },
# parameters_to_delete: ["ConnectedHomeMinConfidence"], # accepts ConnectedHomeMinConfidence, RegionsOfInterest
# }
#
# @!attribute [rw] name
# Name of the stream processor that you want to update.
# @return [String]
#
# @!attribute [rw] settings_for_update
# The stream processor settings that you want to update. Label
# detection settings can be updated to detect different labels with a
# different minimum confidence.
# @return [Types::StreamProcessorSettingsForUpdate]
#
# @!attribute [rw] regions_of_interest_for_update
# Specifies locations in the frames where Amazon Rekognition checks
# for objects or people. This is an optional parameter for label
# detection stream processors.
# @return [Array]
#
# @!attribute [rw] data_sharing_preference_for_update
# Shows whether you are sharing data with Rekognition to improve model
# performance. You can choose this option at the account level or on a
# per-stream basis. Note that if you opt out at the account level this
# setting is ignored on individual streams.
# @return [Types::StreamProcessorDataSharingPreference]
#
# @!attribute [rw] parameters_to_delete
# A list of parameters you want to delete from the stream processor.
# @return [Array]
#
class UpdateStreamProcessorRequest < Struct.new(
:name,
:settings_for_update,
:regions_of_interest_for_update,
:data_sharing_preference_for_update,
:parameters_to_delete)
SENSITIVE = []
include Aws::Structure
end
class UpdateStreamProcessorResponse < Aws::EmptyStructure; end
# Contains the Amazon S3 bucket location of the validation data for a
# model training job.
#
# The validation data includes error information for individual JSON
# Lines in the dataset. For more information, see *Debugging a Failed
# Model Training* in the Amazon Rekognition Custom Labels Developer
# Guide.
#
# You get the `ValidationData` object for the training dataset
# (TrainingDataResult) and the test dataset (TestingDataResult) by
# calling DescribeProjectVersions.
#
# The assets array contains a single Asset object. The
# GroundTruthManifest field of the Asset object contains the S3 bucket
# location of the validation data.
#
# @!attribute [rw] assets
# The assets that comprise the validation data.
# @return [Array]
#
class ValidationData < Struct.new(
:assets)
SENSITIVE = []
include Aws::Structure
end
# Video file stored in an Amazon S3 bucket. Amazon Rekognition video
# start operations such as StartLabelDetection use `Video` to specify a
# video for analysis. The supported file formats are .mp4, .mov and
# .avi.
#
# @note When making an API call, you may pass Video
# data as a hash:
#
# {
# s3_object: {
# bucket: "S3Bucket",
# name: "S3ObjectName",
# version: "S3ObjectVersion",
# },
# }
#
# @!attribute [rw] s3_object
# The Amazon S3 bucket name and file name for the video.
# @return [Types::S3Object]
#
class Video < Struct.new(
:s3_object)
SENSITIVE = []
include Aws::Structure
end
# Information about a video that Amazon Rekognition analyzed.
# `Videometadata` is returned in every page of paginated responses from
# a Amazon Rekognition video operation.
#
# @!attribute [rw] codec
# Type of compression used in the analyzed video.
# @return [String]
#
# @!attribute [rw] duration_millis
# Length of the video in milliseconds.
# @return [Integer]
#
# @!attribute [rw] format
# Format of the analyzed video. Possible values are MP4, MOV and AVI.
# @return [String]
#
# @!attribute [rw] frame_rate
# Number of frames per second in the video.
# @return [Float]
#
# @!attribute [rw] frame_height
# Vertical pixel dimension of the video.
# @return [Integer]
#
# @!attribute [rw] frame_width
# Horizontal pixel dimension of the video.
# @return [Integer]
#
# @!attribute [rw] color_range
# A description of the range of luminance values in a video, either
# LIMITED (16 to 235) or FULL (0 to 255).
# @return [String]
#
class VideoMetadata < Struct.new(
:codec,
:duration_millis,
:format,
:frame_rate,
:frame_height,
:frame_width,
:color_range)
SENSITIVE = []
include Aws::Structure
end
# The file size or duration of the supplied media is too large. The
# maximum file size is 10GB. The maximum duration is 6 hours.
#
class VideoTooLargeException < Aws::EmptyStructure; end
end
end