
software.amazon.awssdk.services.sagemaker.model.CreateLabelingJobRequest Maven / Gradle / Ivy
Show all versions of sagemaker Show documentation
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package software.amazon.awssdk.services.sagemaker.model;
import java.beans.Transient;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class CreateLabelingJobRequest extends SageMakerRequest implements
ToCopyableBuilder {
private static final SdkField LABELING_JOB_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("LabelingJobName").getter(getter(CreateLabelingJobRequest::labelingJobName))
.setter(setter(Builder::labelingJobName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LabelingJobName").build()).build();
private static final SdkField LABEL_ATTRIBUTE_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("LabelAttributeName").getter(getter(CreateLabelingJobRequest::labelAttributeName))
.setter(setter(Builder::labelAttributeName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LabelAttributeName").build())
.build();
private static final SdkField INPUT_CONFIG_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("InputConfig")
.getter(getter(CreateLabelingJobRequest::inputConfig)).setter(setter(Builder::inputConfig))
.constructor(LabelingJobInputConfig::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("InputConfig").build()).build();
private static final SdkField OUTPUT_CONFIG_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("OutputConfig")
.getter(getter(CreateLabelingJobRequest::outputConfig)).setter(setter(Builder::outputConfig))
.constructor(LabelingJobOutputConfig::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("OutputConfig").build()).build();
private static final SdkField ROLE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("RoleArn").getter(getter(CreateLabelingJobRequest::roleArn)).setter(setter(Builder::roleArn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RoleArn").build()).build();
private static final SdkField LABEL_CATEGORY_CONFIG_S3_URI_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("LabelCategoryConfigS3Uri").getter(getter(CreateLabelingJobRequest::labelCategoryConfigS3Uri))
.setter(setter(Builder::labelCategoryConfigS3Uri))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LabelCategoryConfigS3Uri").build())
.build();
private static final SdkField STOPPING_CONDITIONS_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("StoppingConditions")
.getter(getter(CreateLabelingJobRequest::stoppingConditions)).setter(setter(Builder::stoppingConditions))
.constructor(LabelingJobStoppingConditions::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StoppingConditions").build())
.build();
private static final SdkField LABELING_JOB_ALGORITHMS_CONFIG_FIELD = SdkField
. builder(MarshallingType.SDK_POJO)
.memberName("LabelingJobAlgorithmsConfig")
.getter(getter(CreateLabelingJobRequest::labelingJobAlgorithmsConfig))
.setter(setter(Builder::labelingJobAlgorithmsConfig))
.constructor(LabelingJobAlgorithmsConfig::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LabelingJobAlgorithmsConfig")
.build()).build();
private static final SdkField HUMAN_TASK_CONFIG_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("HumanTaskConfig")
.getter(getter(CreateLabelingJobRequest::humanTaskConfig)).setter(setter(Builder::humanTaskConfig))
.constructor(HumanTaskConfig::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("HumanTaskConfig").build()).build();
private static final SdkField> TAGS_FIELD = SdkField
.> builder(MarshallingType.LIST)
.memberName("Tags")
.getter(getter(CreateLabelingJobRequest::tags))
.setter(setter(Builder::tags))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Tags").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.SDK_POJO)
.constructor(Tag::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(LABELING_JOB_NAME_FIELD,
LABEL_ATTRIBUTE_NAME_FIELD, INPUT_CONFIG_FIELD, OUTPUT_CONFIG_FIELD, ROLE_ARN_FIELD,
LABEL_CATEGORY_CONFIG_S3_URI_FIELD, STOPPING_CONDITIONS_FIELD, LABELING_JOB_ALGORITHMS_CONFIG_FIELD,
HUMAN_TASK_CONFIG_FIELD, TAGS_FIELD));
private final String labelingJobName;
private final String labelAttributeName;
private final LabelingJobInputConfig inputConfig;
private final LabelingJobOutputConfig outputConfig;
private final String roleArn;
private final String labelCategoryConfigS3Uri;
private final LabelingJobStoppingConditions stoppingConditions;
private final LabelingJobAlgorithmsConfig labelingJobAlgorithmsConfig;
private final HumanTaskConfig humanTaskConfig;
private final List tags;
private CreateLabelingJobRequest(BuilderImpl builder) {
super(builder);
this.labelingJobName = builder.labelingJobName;
this.labelAttributeName = builder.labelAttributeName;
this.inputConfig = builder.inputConfig;
this.outputConfig = builder.outputConfig;
this.roleArn = builder.roleArn;
this.labelCategoryConfigS3Uri = builder.labelCategoryConfigS3Uri;
this.stoppingConditions = builder.stoppingConditions;
this.labelingJobAlgorithmsConfig = builder.labelingJobAlgorithmsConfig;
this.humanTaskConfig = builder.humanTaskConfig;
this.tags = builder.tags;
}
/**
*
* The name of the labeling job. This name is used to identify the job in a list of labeling jobs. Labeling job
* names must be unique within an Amazon Web Services account and region. LabelingJobName
is not case
* sensitive. For example, Example-job and example-job are considered the same labeling job name by Ground Truth.
*
*
* @return The name of the labeling job. This name is used to identify the job in a list of labeling jobs. Labeling
* job names must be unique within an Amazon Web Services account and region. LabelingJobName
* is not case sensitive. For example, Example-job and example-job are considered the same labeling job name
* by Ground Truth.
*/
public final String labelingJobName() {
return labelingJobName;
}
/**
*
* The attribute name to use for the label in the output manifest file. This is the key for the key/value pair
* formed with the label that a worker assigns to the object. The LabelAttributeName
must meet the
* following requirements.
*
*
* -
*
* The name can't end with "-metadata".
*
*
* -
*
* If you are using one of the following built-in task types, the attribute
* name must end with "-ref". If the task type you are using is not listed below, the attribute name must
* not end with "-ref".
*
*
* -
*
* Image semantic segmentation (SemanticSegmentation)
, and adjustment (
* AdjustmentSemanticSegmentation
) and verification (VerificationSemanticSegmentation
)
* labeling jobs for this task type.
*
*
* -
*
* Video frame object detection (VideoObjectDetection
), and adjustment and verification (
* AdjustmentVideoObjectDetection
) labeling jobs for this task type.
*
*
* -
*
* Video frame object tracking (VideoObjectTracking
), and adjustment and verification (
* AdjustmentVideoObjectTracking
) labeling jobs for this task type.
*
*
* -
*
* 3D point cloud semantic segmentation (3DPointCloudSemanticSegmentation
), and adjustment and
* verification (Adjustment3DPointCloudSemanticSegmentation
) labeling jobs for this task type.
*
*
* -
*
* 3D point cloud object tracking (3DPointCloudObjectTracking
), and adjustment and verification (
* Adjustment3DPointCloudObjectTracking
) labeling jobs for this task type.
*
*
*
*
*
*
*
*
* If you are creating an adjustment or verification labeling job, you must use a different
* LabelAttributeName
than the one used in the original labeling job. The original labeling job is the
* Ground Truth labeling job that produced the labels that you want verified or adjusted. To learn more about
* adjustment and verification labeling jobs, see Verify and Adjust Labels.
*
*
*
* @return The attribute name to use for the label in the output manifest file. This is the key for the key/value
* pair formed with the label that a worker assigns to the object. The LabelAttributeName
must
* meet the following requirements.
*
* -
*
* The name can't end with "-metadata".
*
*
* -
*
* If you are using one of the following built-in task types, the
* attribute name must end with "-ref". If the task type you are using is not listed below, the
* attribute name must not end with "-ref".
*
*
* -
*
* Image semantic segmentation (SemanticSegmentation)
, and adjustment (
* AdjustmentSemanticSegmentation
) and verification (
* VerificationSemanticSegmentation
) labeling jobs for this task type.
*
*
* -
*
* Video frame object detection (VideoObjectDetection
), and adjustment and verification (
* AdjustmentVideoObjectDetection
) labeling jobs for this task type.
*
*
* -
*
* Video frame object tracking (VideoObjectTracking
), and adjustment and verification (
* AdjustmentVideoObjectTracking
) labeling jobs for this task type.
*
*
* -
*
* 3D point cloud semantic segmentation (3DPointCloudSemanticSegmentation
), and adjustment and
* verification (Adjustment3DPointCloudSemanticSegmentation
) labeling jobs for this task type.
*
*
* -
*
* 3D point cloud object tracking (3DPointCloudObjectTracking
), and adjustment and verification
* (Adjustment3DPointCloudObjectTracking
) labeling jobs for this task type.
*
*
*
*
*
*
*
*
* If you are creating an adjustment or verification labeling job, you must use a different
* LabelAttributeName
than the one used in the original labeling job. The original labeling job
* is the Ground Truth labeling job that produced the labels that you want verified or adjusted. To learn
* more about adjustment and verification labeling jobs, see Verify and Adjust
* Labels.
*
*/
public final String labelAttributeName() {
return labelAttributeName;
}
/**
*
* Input data for the labeling job, such as the Amazon S3 location of the data objects and the location of the
* manifest file that describes the data objects.
*
*
* You must specify at least one of the following: S3DataSource
or SnsDataSource
.
*
*
* -
*
* Use SnsDataSource
to specify an SNS input topic for a streaming labeling job. If you do not specify
* and SNS input topic ARN, Ground Truth will create a one-time labeling job that stops after all data objects in
* the input manifest file have been labeled.
*
*
* -
*
* Use S3DataSource
to specify an input manifest file for both streaming and one-time labeling jobs.
* Adding an S3DataSource
is optional if you use SnsDataSource
to create a streaming
* labeling job.
*
*
*
*
* If you use the Amazon Mechanical Turk workforce, your input data should not include confidential information,
* personal information or protected health information. Use ContentClassifiers
to specify that your
* data is free of personally identifiable information and adult content.
*
*
* @return Input data for the labeling job, such as the Amazon S3 location of the data objects and the location of
* the manifest file that describes the data objects.
*
* You must specify at least one of the following: S3DataSource
or SnsDataSource
.
*
*
* -
*
* Use SnsDataSource
to specify an SNS input topic for a streaming labeling job. If you do not
* specify and SNS input topic ARN, Ground Truth will create a one-time labeling job that stops after all
* data objects in the input manifest file have been labeled.
*
*
* -
*
* Use S3DataSource
to specify an input manifest file for both streaming and one-time labeling
* jobs. Adding an S3DataSource
is optional if you use SnsDataSource
to create a
* streaming labeling job.
*
*
*
*
* If you use the Amazon Mechanical Turk workforce, your input data should not include confidential
* information, personal information or protected health information. Use ContentClassifiers
to
* specify that your data is free of personally identifiable information and adult content.
*/
public final LabelingJobInputConfig inputConfig() {
return inputConfig;
}
/**
*
* The location of the output data and the Amazon Web Services Key Management Service key ID for the key used to
* encrypt the output data, if any.
*
*
* @return The location of the output data and the Amazon Web Services Key Management Service key ID for the key
* used to encrypt the output data, if any.
*/
public final LabelingJobOutputConfig outputConfig() {
return outputConfig;
}
/**
*
* The Amazon Resource Number (ARN) that Amazon SageMaker assumes to perform tasks on your behalf during data
* labeling. You must grant this role the necessary permissions so that Amazon SageMaker can successfully complete
* data labeling.
*
*
* @return The Amazon Resource Number (ARN) that Amazon SageMaker assumes to perform tasks on your behalf during
* data labeling. You must grant this role the necessary permissions so that Amazon SageMaker can
* successfully complete data labeling.
*/
public final String roleArn() {
return roleArn;
}
/**
*
* The S3 URI of the file, referred to as a label category configuration file, that defines the categories
* used to label the data objects.
*
*
* For 3D point cloud and video frame task types, you can add label category attributes and frame attributes to your
* label category configuration file. To learn how, see Create a
* Labeling Category Configuration File for 3D Point Cloud Labeling Jobs.
*
*
* For named entity recognition jobs, in addition to "labels"
, you must provide worker instructions in
* the label category configuration file using the "instructions"
parameter:
* "instructions": {"shortInstruction":"<h1>Add header</h1><p>Add Instructions</p>", "fullInstruction":"<p>Add additional instructions.</p>"}
* . For details and an example, see Create a
* Named Entity Recognition Labeling Job (API) .
*
*
* For all other built-in task
* types and custom
* tasks, your label category configuration file must be a JSON file in the following format. Identify the
* labels you want to use by replacing label_1
, label_2
,...
,
* label_n
with your label categories.
*
*
* {
*
*
* "document-version": "2018-11-28",
*
*
* "labels": [{"label": "label_1"},{"label": "label_2"},...{"label": "label_n"}]
*
*
* }
*
*
* Note the following about the label category configuration file:
*
*
* -
*
* For image classification and text classification (single and multi-label) you must specify at least two label
* categories. For all other task types, the minimum number of label categories required is one.
*
*
* -
*
* Each label category must be unique, you cannot specify duplicate label categories.
*
*
* -
*
* If you create a 3D point cloud or video frame adjustment or verification labeling job, you must include
* auditLabelAttributeName
in the label category configuration. Use this parameter to enter the LabelAttributeName
of the labeling job you want to adjust or verify annotations of.
*
*
*
*
* @return The S3 URI of the file, referred to as a label category configuration file, that defines the
* categories used to label the data objects.
*
* For 3D point cloud and video frame task types, you can add label category attributes and frame attributes
* to your label category configuration file. To learn how, see Create
* a Labeling Category Configuration File for 3D Point Cloud Labeling Jobs.
*
*
* For named entity recognition jobs, in addition to "labels"
, you must provide worker
* instructions in the label category configuration file using the "instructions"
parameter:
* "instructions": {"shortInstruction":"<h1>Add header</h1><p>Add Instructions</p>", "fullInstruction":"<p>Add additional instructions.</p>"}
* . For details and an example, see Create a Named Entity Recognition Labeling Job (API) .
*
*
* For all other built-in task
* types and custom
* tasks, your label category configuration file must be a JSON file in the following format. Identify
* the labels you want to use by replacing label_1
, label_2
,...
,
* label_n
with your label categories.
*
*
* {
*
*
* "document-version": "2018-11-28",
*
*
* "labels": [{"label": "label_1"},{"label": "label_2"},...{"label": "label_n"}]
*
*
* }
*
*
* Note the following about the label category configuration file:
*
*
* -
*
* For image classification and text classification (single and multi-label) you must specify at least two
* label categories. For all other task types, the minimum number of label categories required is one.
*
*
* -
*
* Each label category must be unique, you cannot specify duplicate label categories.
*
*
* -
*
* If you create a 3D point cloud or video frame adjustment or verification labeling job, you must include
* auditLabelAttributeName
in the label category configuration. Use this parameter to enter the
* LabelAttributeName
of the labeling job you want to adjust or verify annotations of.
*
*
*/
public final String labelCategoryConfigS3Uri() {
return labelCategoryConfigS3Uri;
}
/**
*
* A set of conditions for stopping the labeling job. If any of the conditions are met, the job is automatically
* stopped. You can use these conditions to control the cost of data labeling.
*
*
* @return A set of conditions for stopping the labeling job. If any of the conditions are met, the job is
* automatically stopped. You can use these conditions to control the cost of data labeling.
*/
public final LabelingJobStoppingConditions stoppingConditions() {
return stoppingConditions;
}
/**
*
* Configures the information required to perform automated data labeling.
*
*
* @return Configures the information required to perform automated data labeling.
*/
public final LabelingJobAlgorithmsConfig labelingJobAlgorithmsConfig() {
return labelingJobAlgorithmsConfig;
}
/**
*
* Configures the labeling task and how it is presented to workers; including, but not limited to price, keywords,
* and batch size (task count).
*
*
* @return Configures the labeling task and how it is presented to workers; including, but not limited to price,
* keywords, and batch size (task count).
*/
public final HumanTaskConfig humanTaskConfig() {
return humanTaskConfig;
}
/**
* For responses, this returns true if the service returned a value for the Tags property. This DOES NOT check that
* the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). This is useful
* because the SDK will never return a null collection or map, but you may need to differentiate between the service
* returning nothing (or null) and the service returning an empty collection or map. For requests, this returns true
* if a value for the property was specified in the request builder, and false if a value was not specified.
*/
public final boolean hasTags() {
return tags != null && !(tags instanceof SdkAutoConstructList);
}
/**
*
* An array of key/value pairs. For more information, see Using
* Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide.
*
*
* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
*
*
* This method will never return null. If you would like to know whether the service returned this field (so that
* you can differentiate between null and empty), you can use the {@link #hasTags} method.
*
*
* @return An array of key/value pairs. For more information, see Using Cost Allocation Tags in the Amazon Web Services Billing and Cost Management User Guide.
*/
public final List tags() {
return tags;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(labelingJobName());
hashCode = 31 * hashCode + Objects.hashCode(labelAttributeName());
hashCode = 31 * hashCode + Objects.hashCode(inputConfig());
hashCode = 31 * hashCode + Objects.hashCode(outputConfig());
hashCode = 31 * hashCode + Objects.hashCode(roleArn());
hashCode = 31 * hashCode + Objects.hashCode(labelCategoryConfigS3Uri());
hashCode = 31 * hashCode + Objects.hashCode(stoppingConditions());
hashCode = 31 * hashCode + Objects.hashCode(labelingJobAlgorithmsConfig());
hashCode = 31 * hashCode + Objects.hashCode(humanTaskConfig());
hashCode = 31 * hashCode + Objects.hashCode(hasTags() ? tags() : null);
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof CreateLabelingJobRequest)) {
return false;
}
CreateLabelingJobRequest other = (CreateLabelingJobRequest) obj;
return Objects.equals(labelingJobName(), other.labelingJobName())
&& Objects.equals(labelAttributeName(), other.labelAttributeName())
&& Objects.equals(inputConfig(), other.inputConfig()) && Objects.equals(outputConfig(), other.outputConfig())
&& Objects.equals(roleArn(), other.roleArn())
&& Objects.equals(labelCategoryConfigS3Uri(), other.labelCategoryConfigS3Uri())
&& Objects.equals(stoppingConditions(), other.stoppingConditions())
&& Objects.equals(labelingJobAlgorithmsConfig(), other.labelingJobAlgorithmsConfig())
&& Objects.equals(humanTaskConfig(), other.humanTaskConfig()) && hasTags() == other.hasTags()
&& Objects.equals(tags(), other.tags());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public final String toString() {
return ToString.builder("CreateLabelingJobRequest").add("LabelingJobName", labelingJobName())
.add("LabelAttributeName", labelAttributeName()).add("InputConfig", inputConfig())
.add("OutputConfig", outputConfig()).add("RoleArn", roleArn())
.add("LabelCategoryConfigS3Uri", labelCategoryConfigS3Uri()).add("StoppingConditions", stoppingConditions())
.add("LabelingJobAlgorithmsConfig", labelingJobAlgorithmsConfig()).add("HumanTaskConfig", humanTaskConfig())
.add("Tags", hasTags() ? tags() : null).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "LabelingJobName":
return Optional.ofNullable(clazz.cast(labelingJobName()));
case "LabelAttributeName":
return Optional.ofNullable(clazz.cast(labelAttributeName()));
case "InputConfig":
return Optional.ofNullable(clazz.cast(inputConfig()));
case "OutputConfig":
return Optional.ofNullable(clazz.cast(outputConfig()));
case "RoleArn":
return Optional.ofNullable(clazz.cast(roleArn()));
case "LabelCategoryConfigS3Uri":
return Optional.ofNullable(clazz.cast(labelCategoryConfigS3Uri()));
case "StoppingConditions":
return Optional.ofNullable(clazz.cast(stoppingConditions()));
case "LabelingJobAlgorithmsConfig":
return Optional.ofNullable(clazz.cast(labelingJobAlgorithmsConfig()));
case "HumanTaskConfig":
return Optional.ofNullable(clazz.cast(humanTaskConfig()));
case "Tags":
return Optional.ofNullable(clazz.cast(tags()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function