TrainingJobDefinition
Defines the input needed to run a training job using the algorithm.
Contents
- InputDataConfig
-
An array of
Channel
objects, each of which specifies an input source.Type: Array of Channel objects
Array Members: Minimum number of 1 item. Maximum number of 20 items.
Required: Yes
- OutputDataConfig
-
the path to the S3 bucket where you want to store model artifacts. SageMaker creates subfolders for the artifacts.
Type: OutputDataConfig object
Required: Yes
- ResourceConfig
-
The resources, including the ML compute instances and ML storage volumes, to use for model training.
Type: ResourceConfig object
Required: Yes
- StoppingCondition
-
Specifies a limit to how long a model training job can run. It also specifies how long a managed Spot training job has to complete. When the job reaches the time limit, SageMaker ends the training job. Use this API to cap model training costs.
To stop a job, SageMaker sends the algorithm the SIGTERM signal, which delays job termination for 120 seconds. Algorithms can use this 120-second window to save the model artifacts.
Type: StoppingCondition object
Required: Yes
- TrainingInputMode
-
The training input mode that the algorithm supports. For more information about input modes, see Algorithms.
Pipe mode
If an algorithm supports
Pipe
mode, Amazon SageMaker streams data directly from Amazon S3 to the container.File mode
If an algorithm supports
File
mode, SageMaker downloads the training data from S3 to the provisioned ML storage volume, and mounts the directory to the Docker volume for the training container.You must provision the ML storage volume with sufficient capacity to accommodate the data downloaded from S3. In addition to the training data, the ML storage volume also stores the output model. The algorithm container uses the ML storage volume to also store intermediate information, if any.
For distributed algorithms, training data is distributed uniformly. Your training duration is predictable if the input data objects sizes are approximately the same. SageMaker does not split the files any further for model training. If the object sizes are skewed, training won't be optimal as the data distribution is also skewed when one host in a training cluster is overloaded, thus becoming a bottleneck in training.
FastFile mode
If an algorithm supports
FastFile
mode, SageMaker streams data directly from S3 to the container with no code changes, and provides file system access to the data. Users can author their training script to interact with these files as if they were stored on disk.FastFile
mode works best when the data is read sequentially. Augmented manifest files aren't supported. The startup time is lower when there are fewer files in the S3 bucket provided.Type: String
Valid Values:
Pipe | File | FastFile
Required: Yes
- HyperParameters
-
The hyperparameters used for the training job.
Type: String to string map
Map Entries: Minimum number of 0 items. Maximum number of 100 items.
Key Length Constraints: Maximum length of 256.
Key Pattern:
.*
Value Length Constraints: Maximum length of 2500.
Value Pattern:
.*
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following: