com.amazonaws.services.sagemaker.model.ExperimentConfig Maven / Gradle / Ivy
/*
* Copyright 2019-2024 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 com.amazonaws.services.sagemaker.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;
/**
*
* Associates a SageMaker job as a trial component with an experiment and trial. Specified when you call the following
* APIs:
*
*
* -
*
*
* -
*
*
* -
*
*
*
*
* @see AWS API
* Documentation
*/
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class ExperimentConfig implements Serializable, Cloneable, StructuredPojo {
/**
*
* The name of an existing experiment to associate with the trial component.
*
*/
private String experimentName;
/**
*
* The name of an existing trial to associate the trial component with. If not specified, a new trial is created.
*
*/
private String trialName;
/**
*
* The display name for the trial component. If this key isn't specified, the display name is the trial component
* name.
*
*/
private String trialComponentDisplayName;
/**
*
* The name of the experiment run to associate with the trial component.
*
*/
private String runName;
/**
*
* The name of an existing experiment to associate with the trial component.
*
*
* @param experimentName
* The name of an existing experiment to associate with the trial component.
*/
public void setExperimentName(String experimentName) {
this.experimentName = experimentName;
}
/**
*
* The name of an existing experiment to associate with the trial component.
*
*
* @return The name of an existing experiment to associate with the trial component.
*/
public String getExperimentName() {
return this.experimentName;
}
/**
*
* The name of an existing experiment to associate with the trial component.
*
*
* @param experimentName
* The name of an existing experiment to associate with the trial component.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ExperimentConfig withExperimentName(String experimentName) {
setExperimentName(experimentName);
return this;
}
/**
*
* The name of an existing trial to associate the trial component with. If not specified, a new trial is created.
*
*
* @param trialName
* The name of an existing trial to associate the trial component with. If not specified, a new trial is
* created.
*/
public void setTrialName(String trialName) {
this.trialName = trialName;
}
/**
*
* The name of an existing trial to associate the trial component with. If not specified, a new trial is created.
*
*
* @return The name of an existing trial to associate the trial component with. If not specified, a new trial is
* created.
*/
public String getTrialName() {
return this.trialName;
}
/**
*
* The name of an existing trial to associate the trial component with. If not specified, a new trial is created.
*
*
* @param trialName
* The name of an existing trial to associate the trial component with. If not specified, a new trial is
* created.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ExperimentConfig withTrialName(String trialName) {
setTrialName(trialName);
return this;
}
/**
*
* The display name for the trial component. If this key isn't specified, the display name is the trial component
* name.
*
*
* @param trialComponentDisplayName
* The display name for the trial component. If this key isn't specified, the display name is the trial
* component name.
*/
public void setTrialComponentDisplayName(String trialComponentDisplayName) {
this.trialComponentDisplayName = trialComponentDisplayName;
}
/**
*
* The display name for the trial component. If this key isn't specified, the display name is the trial component
* name.
*
*
* @return The display name for the trial component. If this key isn't specified, the display name is the trial
* component name.
*/
public String getTrialComponentDisplayName() {
return this.trialComponentDisplayName;
}
/**
*
* The display name for the trial component. If this key isn't specified, the display name is the trial component
* name.
*
*
* @param trialComponentDisplayName
* The display name for the trial component. If this key isn't specified, the display name is the trial
* component name.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ExperimentConfig withTrialComponentDisplayName(String trialComponentDisplayName) {
setTrialComponentDisplayName(trialComponentDisplayName);
return this;
}
/**
*
* The name of the experiment run to associate with the trial component.
*
*
* @param runName
* The name of the experiment run to associate with the trial component.
*/
public void setRunName(String runName) {
this.runName = runName;
}
/**
*
* The name of the experiment run to associate with the trial component.
*
*
* @return The name of the experiment run to associate with the trial component.
*/
public String getRunName() {
return this.runName;
}
/**
*
* The name of the experiment run to associate with the trial component.
*
*
* @param runName
* The name of the experiment run to associate with the trial component.
* @return Returns a reference to this object so that method calls can be chained together.
*/
public ExperimentConfig withRunName(String runName) {
setRunName(runName);
return this;
}
/**
* 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.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
if (getExperimentName() != null)
sb.append("ExperimentName: ").append(getExperimentName()).append(",");
if (getTrialName() != null)
sb.append("TrialName: ").append(getTrialName()).append(",");
if (getTrialComponentDisplayName() != null)
sb.append("TrialComponentDisplayName: ").append(getTrialComponentDisplayName()).append(",");
if (getRunName() != null)
sb.append("RunName: ").append(getRunName());
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof ExperimentConfig == false)
return false;
ExperimentConfig other = (ExperimentConfig) obj;
if (other.getExperimentName() == null ^ this.getExperimentName() == null)
return false;
if (other.getExperimentName() != null && other.getExperimentName().equals(this.getExperimentName()) == false)
return false;
if (other.getTrialName() == null ^ this.getTrialName() == null)
return false;
if (other.getTrialName() != null && other.getTrialName().equals(this.getTrialName()) == false)
return false;
if (other.getTrialComponentDisplayName() == null ^ this.getTrialComponentDisplayName() == null)
return false;
if (other.getTrialComponentDisplayName() != null && other.getTrialComponentDisplayName().equals(this.getTrialComponentDisplayName()) == false)
return false;
if (other.getRunName() == null ^ this.getRunName() == null)
return false;
if (other.getRunName() != null && other.getRunName().equals(this.getRunName()) == false)
return false;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
hashCode = prime * hashCode + ((getExperimentName() == null) ? 0 : getExperimentName().hashCode());
hashCode = prime * hashCode + ((getTrialName() == null) ? 0 : getTrialName().hashCode());
hashCode = prime * hashCode + ((getTrialComponentDisplayName() == null) ? 0 : getTrialComponentDisplayName().hashCode());
hashCode = prime * hashCode + ((getRunName() == null) ? 0 : getRunName().hashCode());
return hashCode;
}
@Override
public ExperimentConfig clone() {
try {
return (ExperimentConfig) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e);
}
}
@com.amazonaws.annotation.SdkInternalApi
@Override
public void marshall(ProtocolMarshaller protocolMarshaller) {
com.amazonaws.services.sagemaker.model.transform.ExperimentConfigMarshaller.getInstance().marshall(this, protocolMarshaller);
}
}