{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.SageMaker.Types.ResourceConfig -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.SageMaker.Types.ResourceConfig where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import Amazonka.SageMaker.Types.InstanceGroup import Amazonka.SageMaker.Types.TrainingInstanceType -- | Describes the resources, including machine learning (ML) compute -- instances and ML storage volumes, to use for model training. -- -- /See:/ 'newResourceConfig' smart constructor. data ResourceConfig = ResourceConfig' { -- | The number of ML compute instances to use. For distributed training, -- provide a value greater than 1. instanceCount :: Prelude.Maybe Prelude.Natural, -- | The configuration of a heterogeneous cluster in JSON format. instanceGroups :: Prelude.Maybe [InstanceGroup], -- | The ML compute instance type. -- -- SageMaker Training on Amazon Elastic Compute Cloud (EC2) P4de instances -- is in preview release starting December 9th, 2022. -- -- -- (currently in preview) are powered by 8 NVIDIA A100 GPUs with 80GB -- high-performance HBM2e GPU memory, which accelerate the speed of -- training ML models that need to be trained on large datasets of -- high-resolution data. In this preview release, Amazon SageMaker supports -- ML training jobs on P4de instances (@ml.p4de.24xlarge@) to reduce model -- training time. The @ml.p4de.24xlarge@ instances are available in the -- following Amazon Web Services Regions. -- -- - US East (N. Virginia) (us-east-1) -- -- - US West (Oregon) (us-west-2) -- -- To request quota limit increase and start using P4de instances, contact -- the SageMaker Training service team through your account team. instanceType :: Prelude.Maybe TrainingInstanceType, -- | The duration of time in seconds to retain configured resources in a warm -- pool for subsequent training jobs. keepAlivePeriodInSeconds :: Prelude.Maybe Prelude.Natural, -- | The Amazon Web Services KMS key that SageMaker uses to encrypt data on -- the storage volume attached to the ML compute instance(s) that run the -- training job. -- -- Certain Nitro-based instances include local storage, dependent on the -- instance type. Local storage volumes are encrypted using a hardware -- module on the instance. You can\'t request a @VolumeKmsKeyId@ when using -- an instance type with local storage. -- -- For a list of instance types that support local instance storage, see -- . -- -- For more information about local instance storage encryption, see -- . -- -- The @VolumeKmsKeyId@ can be in any of the following formats: -- -- - \/\/ KMS Key ID -- -- @\"1234abcd-12ab-34cd-56ef-1234567890ab\"@ -- -- - \/\/ Amazon Resource Name (ARN) of a KMS Key -- -- @\"arn:aws:kms:us-west-2:111122223333:key\/1234abcd-12ab-34cd-56ef-1234567890ab\"@ volumeKmsKeyId :: Prelude.Maybe Prelude.Text, -- | The size of the ML storage volume that you want to provision. -- -- ML storage volumes store model artifacts and incremental states. -- Training algorithms might also use the ML storage volume for scratch -- space. If you want to store the training data in the ML storage volume, -- choose @File@ as the @TrainingInputMode@ in the algorithm specification. -- -- When using an ML instance with -- , -- SageMaker doesn\'t provision Amazon EBS General Purpose SSD (gp2) -- storage. Available storage is fixed to the NVMe-type instance\'s storage -- capacity. SageMaker configures storage paths for training datasets, -- checkpoints, model artifacts, and outputs to use the entire capacity of -- the instance storage. For example, ML instance families with the -- NVMe-type instance storage include @ml.p4d@, @ml.g4dn@, and @ml.g5@. -- -- When using an ML instance with the EBS-only storage option and without -- instance storage, you must define the size of EBS volume through -- @VolumeSizeInGB@ in the @ResourceConfig@ API. For example, ML instance -- families that use EBS volumes include @ml.c5@ and @ml.p2@. -- -- To look up instance types and their instance storage types and volumes, -- see -- . -- -- To find the default local paths defined by the SageMaker training -- platform, see -- . volumeSizeInGB :: Prelude.Natural } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ResourceConfig' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'instanceCount', 'resourceConfig_instanceCount' - The number of ML compute instances to use. For distributed training, -- provide a value greater than 1. -- -- 'instanceGroups', 'resourceConfig_instanceGroups' - The configuration of a heterogeneous cluster in JSON format. -- -- 'instanceType', 'resourceConfig_instanceType' - The ML compute instance type. -- -- SageMaker Training on Amazon Elastic Compute Cloud (EC2) P4de instances -- is in preview release starting December 9th, 2022. -- -- -- (currently in preview) are powered by 8 NVIDIA A100 GPUs with 80GB -- high-performance HBM2e GPU memory, which accelerate the speed of -- training ML models that need to be trained on large datasets of -- high-resolution data. In this preview release, Amazon SageMaker supports -- ML training jobs on P4de instances (@ml.p4de.24xlarge@) to reduce model -- training time. The @ml.p4de.24xlarge@ instances are available in the -- following Amazon Web Services Regions. -- -- - US East (N. Virginia) (us-east-1) -- -- - US West (Oregon) (us-west-2) -- -- To request quota limit increase and start using P4de instances, contact -- the SageMaker Training service team through your account team. -- -- 'keepAlivePeriodInSeconds', 'resourceConfig_keepAlivePeriodInSeconds' - The duration of time in seconds to retain configured resources in a warm -- pool for subsequent training jobs. -- -- 'volumeKmsKeyId', 'resourceConfig_volumeKmsKeyId' - The Amazon Web Services KMS key that SageMaker uses to encrypt data on -- the storage volume attached to the ML compute instance(s) that run the -- training job. -- -- Certain Nitro-based instances include local storage, dependent on the -- instance type. Local storage volumes are encrypted using a hardware -- module on the instance. You can\'t request a @VolumeKmsKeyId@ when using -- an instance type with local storage. -- -- For a list of instance types that support local instance storage, see -- . -- -- For more information about local instance storage encryption, see -- . -- -- The @VolumeKmsKeyId@ can be in any of the following formats: -- -- - \/\/ KMS Key ID -- -- @\"1234abcd-12ab-34cd-56ef-1234567890ab\"@ -- -- - \/\/ Amazon Resource Name (ARN) of a KMS Key -- -- @\"arn:aws:kms:us-west-2:111122223333:key\/1234abcd-12ab-34cd-56ef-1234567890ab\"@ -- -- 'volumeSizeInGB', 'resourceConfig_volumeSizeInGB' - The size of the ML storage volume that you want to provision. -- -- ML storage volumes store model artifacts and incremental states. -- Training algorithms might also use the ML storage volume for scratch -- space. If you want to store the training data in the ML storage volume, -- choose @File@ as the @TrainingInputMode@ in the algorithm specification. -- -- When using an ML instance with -- , -- SageMaker doesn\'t provision Amazon EBS General Purpose SSD (gp2) -- storage. Available storage is fixed to the NVMe-type instance\'s storage -- capacity. SageMaker configures storage paths for training datasets, -- checkpoints, model artifacts, and outputs to use the entire capacity of -- the instance storage. For example, ML instance families with the -- NVMe-type instance storage include @ml.p4d@, @ml.g4dn@, and @ml.g5@. -- -- When using an ML instance with the EBS-only storage option and without -- instance storage, you must define the size of EBS volume through -- @VolumeSizeInGB@ in the @ResourceConfig@ API. For example, ML instance -- families that use EBS volumes include @ml.c5@ and @ml.p2@. -- -- To look up instance types and their instance storage types and volumes, -- see -- . -- -- To find the default local paths defined by the SageMaker training -- platform, see -- . newResourceConfig :: -- | 'volumeSizeInGB' Prelude.Natural -> ResourceConfig newResourceConfig pVolumeSizeInGB_ = ResourceConfig' { instanceCount = Prelude.Nothing, instanceGroups = Prelude.Nothing, instanceType = Prelude.Nothing, keepAlivePeriodInSeconds = Prelude.Nothing, volumeKmsKeyId = Prelude.Nothing, volumeSizeInGB = pVolumeSizeInGB_ } -- | The number of ML compute instances to use. For distributed training, -- provide a value greater than 1. resourceConfig_instanceCount :: Lens.Lens' ResourceConfig (Prelude.Maybe Prelude.Natural) resourceConfig_instanceCount = Lens.lens (\ResourceConfig' {instanceCount} -> instanceCount) (\s@ResourceConfig' {} a -> s {instanceCount = a} :: ResourceConfig) -- | The configuration of a heterogeneous cluster in JSON format. resourceConfig_instanceGroups :: Lens.Lens' ResourceConfig (Prelude.Maybe [InstanceGroup]) resourceConfig_instanceGroups = Lens.lens (\ResourceConfig' {instanceGroups} -> instanceGroups) (\s@ResourceConfig' {} a -> s {instanceGroups = a} :: ResourceConfig) Prelude.. Lens.mapping Lens.coerced -- | The ML compute instance type. -- -- SageMaker Training on Amazon Elastic Compute Cloud (EC2) P4de instances -- is in preview release starting December 9th, 2022. -- -- -- (currently in preview) are powered by 8 NVIDIA A100 GPUs with 80GB -- high-performance HBM2e GPU memory, which accelerate the speed of -- training ML models that need to be trained on large datasets of -- high-resolution data. In this preview release, Amazon SageMaker supports -- ML training jobs on P4de instances (@ml.p4de.24xlarge@) to reduce model -- training time. The @ml.p4de.24xlarge@ instances are available in the -- following Amazon Web Services Regions. -- -- - US East (N. Virginia) (us-east-1) -- -- - US West (Oregon) (us-west-2) -- -- To request quota limit increase and start using P4de instances, contact -- the SageMaker Training service team through your account team. resourceConfig_instanceType :: Lens.Lens' ResourceConfig (Prelude.Maybe TrainingInstanceType) resourceConfig_instanceType = Lens.lens (\ResourceConfig' {instanceType} -> instanceType) (\s@ResourceConfig' {} a -> s {instanceType = a} :: ResourceConfig) -- | The duration of time in seconds to retain configured resources in a warm -- pool for subsequent training jobs. resourceConfig_keepAlivePeriodInSeconds :: Lens.Lens' ResourceConfig (Prelude.Maybe Prelude.Natural) resourceConfig_keepAlivePeriodInSeconds = Lens.lens (\ResourceConfig' {keepAlivePeriodInSeconds} -> keepAlivePeriodInSeconds) (\s@ResourceConfig' {} a -> s {keepAlivePeriodInSeconds = a} :: ResourceConfig) -- | The Amazon Web Services KMS key that SageMaker uses to encrypt data on -- the storage volume attached to the ML compute instance(s) that run the -- training job. -- -- Certain Nitro-based instances include local storage, dependent on the -- instance type. Local storage volumes are encrypted using a hardware -- module on the instance. You can\'t request a @VolumeKmsKeyId@ when using -- an instance type with local storage. -- -- For a list of instance types that support local instance storage, see -- . -- -- For more information about local instance storage encryption, see -- . -- -- The @VolumeKmsKeyId@ can be in any of the following formats: -- -- - \/\/ KMS Key ID -- -- @\"1234abcd-12ab-34cd-56ef-1234567890ab\"@ -- -- - \/\/ Amazon Resource Name (ARN) of a KMS Key -- -- @\"arn:aws:kms:us-west-2:111122223333:key\/1234abcd-12ab-34cd-56ef-1234567890ab\"@ resourceConfig_volumeKmsKeyId :: Lens.Lens' ResourceConfig (Prelude.Maybe Prelude.Text) resourceConfig_volumeKmsKeyId = Lens.lens (\ResourceConfig' {volumeKmsKeyId} -> volumeKmsKeyId) (\s@ResourceConfig' {} a -> s {volumeKmsKeyId = a} :: ResourceConfig) -- | The size of the ML storage volume that you want to provision. -- -- ML storage volumes store model artifacts and incremental states. -- Training algorithms might also use the ML storage volume for scratch -- space. If you want to store the training data in the ML storage volume, -- choose @File@ as the @TrainingInputMode@ in the algorithm specification. -- -- When using an ML instance with -- , -- SageMaker doesn\'t provision Amazon EBS General Purpose SSD (gp2) -- storage. Available storage is fixed to the NVMe-type instance\'s storage -- capacity. SageMaker configures storage paths for training datasets, -- checkpoints, model artifacts, and outputs to use the entire capacity of -- the instance storage. For example, ML instance families with the -- NVMe-type instance storage include @ml.p4d@, @ml.g4dn@, and @ml.g5@. -- -- When using an ML instance with the EBS-only storage option and without -- instance storage, you must define the size of EBS volume through -- @VolumeSizeInGB@ in the @ResourceConfig@ API. For example, ML instance -- families that use EBS volumes include @ml.c5@ and @ml.p2@. -- -- To look up instance types and their instance storage types and volumes, -- see -- . -- -- To find the default local paths defined by the SageMaker training -- platform, see -- . resourceConfig_volumeSizeInGB :: Lens.Lens' ResourceConfig Prelude.Natural resourceConfig_volumeSizeInGB = Lens.lens (\ResourceConfig' {volumeSizeInGB} -> volumeSizeInGB) (\s@ResourceConfig' {} a -> s {volumeSizeInGB = a} :: ResourceConfig) instance Data.FromJSON ResourceConfig where parseJSON = Data.withObject "ResourceConfig" ( \x -> ResourceConfig' Prelude.<$> (x Data..:? "InstanceCount") Prelude.<*> (x Data..:? "InstanceGroups" Data..!= Prelude.mempty) Prelude.<*> (x Data..:? "InstanceType") Prelude.<*> (x Data..:? "KeepAlivePeriodInSeconds") Prelude.<*> (x Data..:? "VolumeKmsKeyId") Prelude.<*> (x Data..: "VolumeSizeInGB") ) instance Prelude.Hashable ResourceConfig where hashWithSalt _salt ResourceConfig' {..} = _salt `Prelude.hashWithSalt` instanceCount `Prelude.hashWithSalt` instanceGroups `Prelude.hashWithSalt` instanceType `Prelude.hashWithSalt` keepAlivePeriodInSeconds `Prelude.hashWithSalt` volumeKmsKeyId `Prelude.hashWithSalt` volumeSizeInGB instance Prelude.NFData ResourceConfig where rnf ResourceConfig' {..} = Prelude.rnf instanceCount `Prelude.seq` Prelude.rnf instanceGroups `Prelude.seq` Prelude.rnf instanceType `Prelude.seq` Prelude.rnf keepAlivePeriodInSeconds `Prelude.seq` Prelude.rnf volumeKmsKeyId `Prelude.seq` Prelude.rnf volumeSizeInGB instance Data.ToJSON ResourceConfig where toJSON ResourceConfig' {..} = Data.object ( Prelude.catMaybes [ ("InstanceCount" Data..=) Prelude.<$> instanceCount, ("InstanceGroups" Data..=) Prelude.<$> instanceGroups, ("InstanceType" Data..=) Prelude.<$> instanceType, ("KeepAlivePeriodInSeconds" Data..=) Prelude.<$> keepAlivePeriodInSeconds, ("VolumeKmsKeyId" Data..=) Prelude.<$> volumeKmsKeyId, Prelude.Just ("VolumeSizeInGB" Data..= volumeSizeInGB) ] )