Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
SPDX-License-Identifier: CC-BY-SA-4.0
Starts a transform job. A transform job uses a trained model to get inferences on a dataset and saves these results to an Amazon S3 location that you specify.
To perform batch transformations, you create a transform job and use the data that you have readily available.
In the request body, you provide the following: + TransformJobName
- Identifies the transform job. The name must be unique within an AWS Region in an AWS account. + ModelName
- Identifies the model to use. ModelName
must be the name of an existing Amazon SageMaker model in the same AWS Region and AWS account. For information on creating a model, see CreateModel. + TransformInput
- Describes the dataset to be transformed and the Amazon S3 location where it is stored. + TransformOutput
- Identifies the Amazon S3 location where you want Amazon SageMaker to save the results from the transform job. + TransformResources
- Identifies the ML compute instances for the transform job.
For more information about how batch transformation works Amazon SageMaker, see How It Works.
{
"[BatchStrategy](#SageMaker-CreateTransformJob-request-BatchStrategy)": "string",
"[DataProcessing](#SageMaker-CreateTransformJob-request-DataProcessing)": {
"[InputFilter](API_DataProcessing.md#SageMaker-Type-DataProcessing-InputFilter)": "string",
"[JoinSource](API_DataProcessing.md#SageMaker-Type-DataProcessing-JoinSource)": "string",
"[OutputFilter](API_DataProcessing.md#SageMaker-Type-DataProcessing-OutputFilter)": "string"
},
"[Environment](#SageMaker-CreateTransformJob-request-Environment)": {
"string" : "string"
},
"[MaxConcurrentTransforms](#SageMaker-CreateTransformJob-request-MaxConcurrentTransforms)": number,
"[MaxPayloadInMB](#SageMaker-CreateTransformJob-request-MaxPayloadInMB)": number,
"[ModelName](#SageMaker-CreateTransformJob-request-ModelName)": "string",
"[Tags](#SageMaker-CreateTransformJob-request-Tags)": [
{
"[Key](API_Tag.md#SageMaker-Type-Tag-Key)": "string",
"[Value](API_Tag.md#SageMaker-Type-Tag-Value)": "string"
}
],
"[TransformInput](#SageMaker-CreateTransformJob-request-TransformInput)": {
"[CompressionType](API_TransformInput.md#SageMaker-Type-TransformInput-CompressionType)": "string",
"[ContentType](API_TransformInput.md#SageMaker-Type-TransformInput-ContentType)": "string",
"[DataSource](API_TransformInput.md#SageMaker-Type-TransformInput-DataSource)": {
"[S3DataSource](API_TransformDataSource.md#SageMaker-Type-TransformDataSource-S3DataSource)": {
"[S3DataType](API_TransformS3DataSource.md#SageMaker-Type-TransformS3DataSource-S3DataType)": "string",
"[S3Uri](API_TransformS3DataSource.md#SageMaker-Type-TransformS3DataSource-S3Uri)": "string"
}
},
"[SplitType](API_TransformInput.md#SageMaker-Type-TransformInput-SplitType)": "string"
},
"[TransformJobName](#SageMaker-CreateTransformJob-request-TransformJobName)": "string",
"[TransformOutput](#SageMaker-CreateTransformJob-request-TransformOutput)": {
"[Accept](API_TransformOutput.md#SageMaker-Type-TransformOutput-Accept)": "string",
"[AssembleWith](API_TransformOutput.md#SageMaker-Type-TransformOutput-AssembleWith)": "string",
"[KmsKeyId](API_TransformOutput.md#SageMaker-Type-TransformOutput-KmsKeyId)": "string",
"[S3OutputPath](API_TransformOutput.md#SageMaker-Type-TransformOutput-S3OutputPath)": "string"
},
"[TransformResources](#SageMaker-CreateTransformJob-request-TransformResources)": {
"[InstanceCount](API_TransformResources.md#SageMaker-Type-TransformResources-InstanceCount)": number,
"[InstanceType](API_TransformResources.md#SageMaker-Type-TransformResources-InstanceType)": "string",
"[VolumeKmsKeyId](API_TransformResources.md#SageMaker-Type-TransformResources-VolumeKmsKeyId)": "string"
}
}
For information about the parameters that are common to all actions, see Common Parameters.
The request accepts the following data in JSON format.
** BatchStrategy ** Specifies the number of records to include in a mini-batch for an HTTP inference request. A record ** is a single unit of input data that inference can be made on. For example, a single line in a CSV file is a record.
To enable the batch strategy, you must set SplitType
to Line
, RecordIO
, or TFRecord
.
To use only one record when making an HTTP invocation request to a container, set BatchStrategy
to SingleRecord
and SplitType
to Line
.
To fit as many records in a mini-batch as can fit within the MaxPayloadInMB
limit, set BatchStrategy
to MultiRecord
and SplitType
to Line
.
Type: String
Valid Values:MultiRecord | SingleRecord
Required: No
** DataProcessing ** The data structure used to specify the data to be used for inference in a batch transform job and to associate the data that is relevant to the prediction results in the output. The input filter provided allows you to exclude input data that is not needed for inference in a batch transform job. The output filter provided allows you to include input data relevant to interpreting the predictions in the output from the job. For more information, see Associate Prediction Results with their Corresponding Input Records.
Type: DataProcessing object
Required: No
** Environment ** The environment variables to set in the Docker container. We support up to 16 key and values entries in the map.
Type: String to string map
Key Length Constraints: Maximum length of 1024.
Key Pattern: [a-zA-Z_][a-zA-Z0-9_]*
Value Length Constraints: Maximum length of 10240.
Value Pattern: [\S\s]*
Required: No
** MaxConcurrentTransforms ** The maximum number of parallel requests that can be sent to each instance in a transform job. If MaxConcurrentTransforms
is set to 0
or left unset, Amazon SageMaker checks the optional execution-parameters to determine the optimal settings for your chosen algorithm. If the execution-parameters endpoint is not enabled, the default value is 1
. For more information on execution-parameters, see How Containers Serve Requests. For built-in algorithms, you don’t need to set a value for MaxConcurrentTransforms
.
Type: Integer
Valid Range: Minimum value of 0.
Required: No
** MaxPayloadInMB ** The maximum allowed size of the payload, in MB. A payload is the data portion of a record (without metadata). The value in MaxPayloadInMB
must be greater than, or equal to, the size of a single record. To estimate the size of a record in MB, divide the size of your dataset by the number of records. To ensure that the records fit within the maximum payload size, we recommend using a slightly larger value. The default value is 6
MB.
For cases where the payload might be arbitrarily large and is transmitted using HTTP chunked encoding, set the value to 0
. This feature works only in supported algorithms. Currently, Amazon SageMaker built-in algorithms do not support HTTP chunked encoding.
Type: Integer
Valid Range: Minimum value of 0.
Required: No
** ModelName ** The name of the model that you want to use for the transform job. ModelName
must be the name of an existing Amazon SageMaker model within an AWS Region in an AWS account.
Type: String
Length Constraints: Maximum length of 63.
Pattern: ^[a-zA-Z0-9](-*[a-zA-Z0-9])*
Required: Yes
** Tags ** (Optional) An array of key-value pairs. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost Management User Guide.
Type: Array of Tag objects
Array Members: Minimum number of 0 items. Maximum number of 50 items.
Required: No
** TransformInput ** Describes the input source and the way the transform job consumes it.
Type: TransformInput object
Required: Yes
** TransformJobName ** The name of the transform job. The name must be unique within an AWS Region in an AWS account.
Type: String
Length Constraints: Minimum length of 1. Maximum length of 63.
Pattern: ^[a-zA-Z0-9](-*[a-zA-Z0-9])*
Required: Yes
** TransformOutput ** Describes the results of the transform job.
Type: TransformOutput object
Required: Yes
** TransformResources ** Describes the resources, including ML instance types and ML instance count, to use for the transform job.
Type: TransformResources object
Required: Yes
{
"[TransformJobArn](#SageMaker-CreateTransformJob-response-TransformJobArn)": "string"
}
If the action is successful, the service sends back an HTTP 200 response.
The following data is returned in JSON format by the service.
** TransformJobArn ** The Amazon Resource Name (ARN) of the transform job.
Type: String
Length Constraints: Maximum length of 256.
Pattern: arn:aws[a-z\-]*:sagemaker:[a-z0-9\-]*:[0-9]{12}:transform-job/.*
For information about the errors that are common to all actions, see Common Errors.
ResourceInUse
Resource being accessed is in use.
HTTP Status Code: 400
ResourceLimitExceeded
You have exceeded an Amazon SageMaker resource limit. For example, you might have too many training jobs created.
HTTP Status Code: 400
For more information about using this API in one of the language-specific AWS SDKs, see the following: + AWS Command Line Interface + AWS SDK for .NET + AWS SDK for C++ + AWS SDK for Go + AWS SDK for Go - Pilot + AWS SDK for Java + AWS SDK for JavaScript + AWS SDK for PHP V3 + AWS SDK for Python + AWS SDK for Ruby V2