
software.amazon.awssdk.services.sagemaker.model.ProductionVariant Maven / Gradle / Ivy
/*
* 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.io.Serializable;
import java.util.Arrays;
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 software.amazon.awssdk.annotations.Generated;
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.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
* Identifies a model that you want to host and the resources to deploy for hosting it. If you are deploying multiple
* models, tell Amazon SageMaker how to distribute traffic among the models by specifying variant weights.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class ProductionVariant implements SdkPojo, Serializable,
ToCopyableBuilder {
private static final SdkField VARIANT_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("VariantName").getter(getter(ProductionVariant::variantName)).setter(setter(Builder::variantName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("VariantName").build()).build();
private static final SdkField MODEL_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ModelName").getter(getter(ProductionVariant::modelName)).setter(setter(Builder::modelName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ModelName").build()).build();
private static final SdkField INITIAL_INSTANCE_COUNT_FIELD = SdkField. builder(MarshallingType.INTEGER)
.memberName("InitialInstanceCount").getter(getter(ProductionVariant::initialInstanceCount))
.setter(setter(Builder::initialInstanceCount))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("InitialInstanceCount").build())
.build();
private static final SdkField INSTANCE_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("InstanceType").getter(getter(ProductionVariant::instanceTypeAsString))
.setter(setter(Builder::instanceType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("InstanceType").build()).build();
private static final SdkField INITIAL_VARIANT_WEIGHT_FIELD = SdkField. builder(MarshallingType.FLOAT)
.memberName("InitialVariantWeight").getter(getter(ProductionVariant::initialVariantWeight))
.setter(setter(Builder::initialVariantWeight))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("InitialVariantWeight").build())
.build();
private static final SdkField ACCELERATOR_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("AcceleratorType").getter(getter(ProductionVariant::acceleratorTypeAsString))
.setter(setter(Builder::acceleratorType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AcceleratorType").build()).build();
private static final SdkField CORE_DUMP_CONFIG_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("CoreDumpConfig")
.getter(getter(ProductionVariant::coreDumpConfig)).setter(setter(Builder::coreDumpConfig))
.constructor(ProductionVariantCoreDumpConfig::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CoreDumpConfig").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(VARIANT_NAME_FIELD,
MODEL_NAME_FIELD, INITIAL_INSTANCE_COUNT_FIELD, INSTANCE_TYPE_FIELD, INITIAL_VARIANT_WEIGHT_FIELD,
ACCELERATOR_TYPE_FIELD, CORE_DUMP_CONFIG_FIELD));
private static final long serialVersionUID = 1L;
private final String variantName;
private final String modelName;
private final Integer initialInstanceCount;
private final String instanceType;
private final Float initialVariantWeight;
private final String acceleratorType;
private final ProductionVariantCoreDumpConfig coreDumpConfig;
private ProductionVariant(BuilderImpl builder) {
this.variantName = builder.variantName;
this.modelName = builder.modelName;
this.initialInstanceCount = builder.initialInstanceCount;
this.instanceType = builder.instanceType;
this.initialVariantWeight = builder.initialVariantWeight;
this.acceleratorType = builder.acceleratorType;
this.coreDumpConfig = builder.coreDumpConfig;
}
/**
*
* The name of the production variant.
*
*
* @return The name of the production variant.
*/
public final String variantName() {
return variantName;
}
/**
*
* The name of the model that you want to host. This is the name that you specified when creating the model.
*
*
* @return The name of the model that you want to host. This is the name that you specified when creating the model.
*/
public final String modelName() {
return modelName;
}
/**
*
* Number of instances to launch initially.
*
*
* @return Number of instances to launch initially.
*/
public final Integer initialInstanceCount() {
return initialInstanceCount;
}
/**
*
* The ML compute instance type.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #instanceType} will
* return {@link ProductionVariantInstanceType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is
* available from {@link #instanceTypeAsString}.
*
*
* @return The ML compute instance type.
* @see ProductionVariantInstanceType
*/
public final ProductionVariantInstanceType instanceType() {
return ProductionVariantInstanceType.fromValue(instanceType);
}
/**
*
* The ML compute instance type.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #instanceType} will
* return {@link ProductionVariantInstanceType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is
* available from {@link #instanceTypeAsString}.
*
*
* @return The ML compute instance type.
* @see ProductionVariantInstanceType
*/
public final String instanceTypeAsString() {
return instanceType;
}
/**
*
* Determines initial traffic distribution among all of the models that you specify in the endpoint configuration.
* The traffic to a production variant is determined by the ratio of the VariantWeight
to the sum of
* all VariantWeight
values across all ProductionVariants. If unspecified, it defaults to 1.0.
*
*
* @return Determines initial traffic distribution among all of the models that you specify in the endpoint
* configuration. The traffic to a production variant is determined by the ratio of the
* VariantWeight
to the sum of all VariantWeight
values across all
* ProductionVariants. If unspecified, it defaults to 1.0.
*/
public final Float initialVariantWeight() {
return initialVariantWeight;
}
/**
*
* The size of the Elastic Inference (EI) instance to use for the production variant. EI instances provide on-demand
* GPU computing for inference. For more information, see Using Elastic Inference in Amazon SageMaker.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #acceleratorType}
* will return {@link ProductionVariantAcceleratorType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the
* service is available from {@link #acceleratorTypeAsString}.
*
*
* @return The size of the Elastic Inference (EI) instance to use for the production variant. EI instances provide
* on-demand GPU computing for inference. For more information, see Using Elastic Inference in Amazon
* SageMaker.
* @see ProductionVariantAcceleratorType
*/
public final ProductionVariantAcceleratorType acceleratorType() {
return ProductionVariantAcceleratorType.fromValue(acceleratorType);
}
/**
*
* The size of the Elastic Inference (EI) instance to use for the production variant. EI instances provide on-demand
* GPU computing for inference. For more information, see Using Elastic Inference in Amazon SageMaker.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #acceleratorType}
* will return {@link ProductionVariantAcceleratorType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the
* service is available from {@link #acceleratorTypeAsString}.
*
*
* @return The size of the Elastic Inference (EI) instance to use for the production variant. EI instances provide
* on-demand GPU computing for inference. For more information, see Using Elastic Inference in Amazon
* SageMaker.
* @see ProductionVariantAcceleratorType
*/
public final String acceleratorTypeAsString() {
return acceleratorType;
}
/**
*
* Specifies configuration for a core dump from the model container when the process crashes.
*
*
* @return Specifies configuration for a core dump from the model container when the process crashes.
*/
public final ProductionVariantCoreDumpConfig coreDumpConfig() {
return coreDumpConfig;
}
@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 + Objects.hashCode(variantName());
hashCode = 31 * hashCode + Objects.hashCode(modelName());
hashCode = 31 * hashCode + Objects.hashCode(initialInstanceCount());
hashCode = 31 * hashCode + Objects.hashCode(instanceTypeAsString());
hashCode = 31 * hashCode + Objects.hashCode(initialVariantWeight());
hashCode = 31 * hashCode + Objects.hashCode(acceleratorTypeAsString());
hashCode = 31 * hashCode + Objects.hashCode(coreDumpConfig());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof ProductionVariant)) {
return false;
}
ProductionVariant other = (ProductionVariant) obj;
return Objects.equals(variantName(), other.variantName()) && Objects.equals(modelName(), other.modelName())
&& Objects.equals(initialInstanceCount(), other.initialInstanceCount())
&& Objects.equals(instanceTypeAsString(), other.instanceTypeAsString())
&& Objects.equals(initialVariantWeight(), other.initialVariantWeight())
&& Objects.equals(acceleratorTypeAsString(), other.acceleratorTypeAsString())
&& Objects.equals(coreDumpConfig(), other.coreDumpConfig());
}
/**
* 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("ProductionVariant").add("VariantName", variantName()).add("ModelName", modelName())
.add("InitialInstanceCount", initialInstanceCount()).add("InstanceType", instanceTypeAsString())
.add("InitialVariantWeight", initialVariantWeight()).add("AcceleratorType", acceleratorTypeAsString())
.add("CoreDumpConfig", coreDumpConfig()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "VariantName":
return Optional.ofNullable(clazz.cast(variantName()));
case "ModelName":
return Optional.ofNullable(clazz.cast(modelName()));
case "InitialInstanceCount":
return Optional.ofNullable(clazz.cast(initialInstanceCount()));
case "InstanceType":
return Optional.ofNullable(clazz.cast(instanceTypeAsString()));
case "InitialVariantWeight":
return Optional.ofNullable(clazz.cast(initialVariantWeight()));
case "AcceleratorType":
return Optional.ofNullable(clazz.cast(acceleratorTypeAsString()));
case "CoreDumpConfig":
return Optional.ofNullable(clazz.cast(coreDumpConfig()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function