201 lines
7.3 KiB
C++
201 lines
7.3 KiB
C++
/**
|
|
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
* SPDX-License-Identifier: Apache-2.0.
|
|
*/
|
|
|
|
#pragma once
|
|
#include <aws/sagemaker/SageMaker_EXPORTS.h>
|
|
#include <aws/sagemaker/model/ProcessingInstanceType.h>
|
|
#include <aws/core/utils/memory/stl/AWSString.h>
|
|
#include <utility>
|
|
|
|
namespace Aws
|
|
{
|
|
namespace Utils
|
|
{
|
|
namespace Json
|
|
{
|
|
class JsonValue;
|
|
class JsonView;
|
|
} // namespace Json
|
|
} // namespace Utils
|
|
namespace SageMaker
|
|
{
|
|
namespace Model
|
|
{
|
|
|
|
/**
|
|
* <p>Configuration for the cluster used to run a processing job.</p><p><h3>See
|
|
* Also:</h3> <a
|
|
* href="http://docs.aws.amazon.com/goto/WebAPI/sagemaker-2017-07-24/ProcessingClusterConfig">AWS
|
|
* API Reference</a></p>
|
|
*/
|
|
class AWS_SAGEMAKER_API ProcessingClusterConfig
|
|
{
|
|
public:
|
|
ProcessingClusterConfig();
|
|
ProcessingClusterConfig(Aws::Utils::Json::JsonView jsonValue);
|
|
ProcessingClusterConfig& operator=(Aws::Utils::Json::JsonView jsonValue);
|
|
Aws::Utils::Json::JsonValue Jsonize() const;
|
|
|
|
|
|
/**
|
|
* <p>The number of ML compute instances to use in the processing job. For
|
|
* distributed processing jobs, specify a value greater than 1. The default value
|
|
* is 1.</p>
|
|
*/
|
|
inline int GetInstanceCount() const{ return m_instanceCount; }
|
|
|
|
/**
|
|
* <p>The number of ML compute instances to use in the processing job. For
|
|
* distributed processing jobs, specify a value greater than 1. The default value
|
|
* is 1.</p>
|
|
*/
|
|
inline bool InstanceCountHasBeenSet() const { return m_instanceCountHasBeenSet; }
|
|
|
|
/**
|
|
* <p>The number of ML compute instances to use in the processing job. For
|
|
* distributed processing jobs, specify a value greater than 1. The default value
|
|
* is 1.</p>
|
|
*/
|
|
inline void SetInstanceCount(int value) { m_instanceCountHasBeenSet = true; m_instanceCount = value; }
|
|
|
|
/**
|
|
* <p>The number of ML compute instances to use in the processing job. For
|
|
* distributed processing jobs, specify a value greater than 1. The default value
|
|
* is 1.</p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithInstanceCount(int value) { SetInstanceCount(value); return *this;}
|
|
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline const ProcessingInstanceType& GetInstanceType() const{ return m_instanceType; }
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline bool InstanceTypeHasBeenSet() const { return m_instanceTypeHasBeenSet; }
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline void SetInstanceType(const ProcessingInstanceType& value) { m_instanceTypeHasBeenSet = true; m_instanceType = value; }
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline void SetInstanceType(ProcessingInstanceType&& value) { m_instanceTypeHasBeenSet = true; m_instanceType = std::move(value); }
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithInstanceType(const ProcessingInstanceType& value) { SetInstanceType(value); return *this;}
|
|
|
|
/**
|
|
* <p>The ML compute instance type for the processing job.</p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithInstanceType(ProcessingInstanceType&& value) { SetInstanceType(std::move(value)); return *this;}
|
|
|
|
|
|
/**
|
|
* <p>The size of the ML storage volume in gigabytes that you want to provision.
|
|
* You must specify sufficient ML storage for your scenario.</p>
|
|
*/
|
|
inline int GetVolumeSizeInGB() const{ return m_volumeSizeInGB; }
|
|
|
|
/**
|
|
* <p>The size of the ML storage volume in gigabytes that you want to provision.
|
|
* You must specify sufficient ML storage for your scenario.</p>
|
|
*/
|
|
inline bool VolumeSizeInGBHasBeenSet() const { return m_volumeSizeInGBHasBeenSet; }
|
|
|
|
/**
|
|
* <p>The size of the ML storage volume in gigabytes that you want to provision.
|
|
* You must specify sufficient ML storage for your scenario.</p>
|
|
*/
|
|
inline void SetVolumeSizeInGB(int value) { m_volumeSizeInGBHasBeenSet = true; m_volumeSizeInGB = value; }
|
|
|
|
/**
|
|
* <p>The size of the ML storage volume in gigabytes that you want to provision.
|
|
* You must specify sufficient ML storage for your scenario.</p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithVolumeSizeInGB(int value) { SetVolumeSizeInGB(value); return *this;}
|
|
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline const Aws::String& GetVolumeKmsKeyId() const{ return m_volumeKmsKeyId; }
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline bool VolumeKmsKeyIdHasBeenSet() const { return m_volumeKmsKeyIdHasBeenSet; }
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline void SetVolumeKmsKeyId(const Aws::String& value) { m_volumeKmsKeyIdHasBeenSet = true; m_volumeKmsKeyId = value; }
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline void SetVolumeKmsKeyId(Aws::String&& value) { m_volumeKmsKeyIdHasBeenSet = true; m_volumeKmsKeyId = std::move(value); }
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline void SetVolumeKmsKeyId(const char* value) { m_volumeKmsKeyIdHasBeenSet = true; m_volumeKmsKeyId.assign(value); }
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithVolumeKmsKeyId(const Aws::String& value) { SetVolumeKmsKeyId(value); return *this;}
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithVolumeKmsKeyId(Aws::String&& value) { SetVolumeKmsKeyId(std::move(value)); return *this;}
|
|
|
|
/**
|
|
* <p>The AWS Key Management Service (AWS KMS) key that Amazon SageMaker uses to
|
|
* encrypt data on the storage volume attached to the ML compute instance(s) that
|
|
* run the processing job. </p>
|
|
*/
|
|
inline ProcessingClusterConfig& WithVolumeKmsKeyId(const char* value) { SetVolumeKmsKeyId(value); return *this;}
|
|
|
|
private:
|
|
|
|
int m_instanceCount;
|
|
bool m_instanceCountHasBeenSet;
|
|
|
|
ProcessingInstanceType m_instanceType;
|
|
bool m_instanceTypeHasBeenSet;
|
|
|
|
int m_volumeSizeInGB;
|
|
bool m_volumeSizeInGBHasBeenSet;
|
|
|
|
Aws::String m_volumeKmsKeyId;
|
|
bool m_volumeKmsKeyIdHasBeenSet;
|
|
};
|
|
|
|
} // namespace Model
|
|
} // namespace SageMaker
|
|
} // namespace Aws
|