All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.lookoutforvision.model.DetectAnomalyResult Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon Lookout for Vision module holds the client classes that are used for communicating with Amazon Lookout for Vision Service

There is a newer version: 1.12.780
Show newest version
/*
 * 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.lookoutforvision.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* The prediction results from a call to DetectAnomalies. DetectAnomalyResult includes * classification information for the prediction (IsAnomalous and Confidence). If the model * you use is an image segementation model, DetectAnomalyResult also includes segmentation information ( * Anomalies and AnomalyMask). Classification information is calculated separately from * segmentation information and you shouldn't assume a relationship between them. *

* * @see AWS * API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class DetectAnomalyResult implements Serializable, Cloneable, StructuredPojo { /** *

* The source of the image that was analyzed. direct means that the images was supplied from the local * computer. No other values are supported. *

*/ private ImageSource source; /** *

* True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. *

*/ private Boolean isAnomalous; /** *

* The confidence that Lookout for Vision has in the accuracy of the classification in IsAnomalous. *

*/ private Float confidence; /** *

* If the model is an image segmentation model, Anomalies contains a list of anomaly types found in the * image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly type exist on * the image). The first element in the list is always an anomaly type representing the image background * ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically add the background * anomaly type to the response, and you don't need to declare a background anomaly type in your dataset. *

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. *

*/ private java.util.List anomalies; /** *

* If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an anomaly * type, see the color field of the PixelAnomaly object. *

*

* An image classification model doesn't return an Anomalies list. *

*/ private java.nio.ByteBuffer anomalyMask; /** *

* The source of the image that was analyzed. direct means that the images was supplied from the local * computer. No other values are supported. *

* * @param source * The source of the image that was analyzed. direct means that the images was supplied from the * local computer. No other values are supported. */ public void setSource(ImageSource source) { this.source = source; } /** *

* The source of the image that was analyzed. direct means that the images was supplied from the local * computer. No other values are supported. *

* * @return The source of the image that was analyzed. direct means that the images was supplied from * the local computer. No other values are supported. */ public ImageSource getSource() { return this.source; } /** *

* The source of the image that was analyzed. direct means that the images was supplied from the local * computer. No other values are supported. *

* * @param source * The source of the image that was analyzed. direct means that the images was supplied from the * local computer. No other values are supported. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withSource(ImageSource source) { setSource(source); return this; } /** *

* True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. *

* * @param isAnomalous * True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. */ public void setIsAnomalous(Boolean isAnomalous) { this.isAnomalous = isAnomalous; } /** *

* True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. *

* * @return True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. */ public Boolean getIsAnomalous() { return this.isAnomalous; } /** *

* True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. *

* * @param isAnomalous * True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withIsAnomalous(Boolean isAnomalous) { setIsAnomalous(isAnomalous); return this; } /** *

* True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. *

* * @return True if Amazon Lookout for Vision classifies the image as containing an anomaly, otherwise false. */ public Boolean isAnomalous() { return this.isAnomalous; } /** *

* The confidence that Lookout for Vision has in the accuracy of the classification in IsAnomalous. *

* * @param confidence * The confidence that Lookout for Vision has in the accuracy of the classification in * IsAnomalous. */ public void setConfidence(Float confidence) { this.confidence = confidence; } /** *

* The confidence that Lookout for Vision has in the accuracy of the classification in IsAnomalous. *

* * @return The confidence that Lookout for Vision has in the accuracy of the classification in * IsAnomalous. */ public Float getConfidence() { return this.confidence; } /** *

* The confidence that Lookout for Vision has in the accuracy of the classification in IsAnomalous. *

* * @param confidence * The confidence that Lookout for Vision has in the accuracy of the classification in * IsAnomalous. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withConfidence(Float confidence) { setConfidence(confidence); return this; } /** *

* If the model is an image segmentation model, Anomalies contains a list of anomaly types found in the * image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly type exist on * the image). The first element in the list is always an anomaly type representing the image background * ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically add the background * anomaly type to the response, and you don't need to declare a background anomaly type in your dataset. *

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. *

* * @return If the model is an image segmentation model, Anomalies contains a list of anomaly types * found in the image. There is one entry for each type of anomaly found (even if multiple instances of an * anomaly type exist on the image). The first element in the list is always an anomaly type representing * the image background ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision * automatically add the background anomaly type to the response, and you don't need to declare a background * anomaly type in your dataset.

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. */ public java.util.List getAnomalies() { return anomalies; } /** *

* If the model is an image segmentation model, Anomalies contains a list of anomaly types found in the * image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly type exist on * the image). The first element in the list is always an anomaly type representing the image background * ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically add the background * anomaly type to the response, and you don't need to declare a background anomaly type in your dataset. *

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. *

* * @param anomalies * If the model is an image segmentation model, Anomalies contains a list of anomaly types found * in the image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly * type exist on the image). The first element in the list is always an anomaly type representing the image * background ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically * add the background anomaly type to the response, and you don't need to declare a background anomaly type * in your dataset.

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. */ public void setAnomalies(java.util.Collection anomalies) { if (anomalies == null) { this.anomalies = null; return; } this.anomalies = new java.util.ArrayList(anomalies); } /** *

* If the model is an image segmentation model, Anomalies contains a list of anomaly types found in the * image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly type exist on * the image). The first element in the list is always an anomaly type representing the image background * ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically add the background * anomaly type to the response, and you don't need to declare a background anomaly type in your dataset. *

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setAnomalies(java.util.Collection)} or {@link #withAnomalies(java.util.Collection)} if you want to * override the existing values. *

* * @param anomalies * If the model is an image segmentation model, Anomalies contains a list of anomaly types found * in the image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly * type exist on the image). The first element in the list is always an anomaly type representing the image * background ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically * add the background anomaly type to the response, and you don't need to declare a background anomaly type * in your dataset.

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withAnomalies(Anomaly... anomalies) { if (this.anomalies == null) { setAnomalies(new java.util.ArrayList(anomalies.length)); } for (Anomaly ele : anomalies) { this.anomalies.add(ele); } return this; } /** *

* If the model is an image segmentation model, Anomalies contains a list of anomaly types found in the * image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly type exist on * the image). The first element in the list is always an anomaly type representing the image background * ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically add the background * anomaly type to the response, and you don't need to declare a background anomaly type in your dataset. *

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. *

* * @param anomalies * If the model is an image segmentation model, Anomalies contains a list of anomaly types found * in the image. There is one entry for each type of anomaly found (even if multiple instances of an anomaly * type exist on the image). The first element in the list is always an anomaly type representing the image * background ('background') and shouldn't be considered an anomaly. Amazon Lookout for Vision automatically * add the background anomaly type to the response, and you don't need to declare a background anomaly type * in your dataset.

*

* If the list has one entry ('background'), no anomalies were found on the image. *

*

*

* An image classification model doesn't return an Anomalies list. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withAnomalies(java.util.Collection anomalies) { setAnomalies(anomalies); return this; } /** *

* If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an anomaly * type, see the color field of the PixelAnomaly object. *

*

* An image classification model doesn't return an Anomalies list. *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param anomalyMask * If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an * anomaly type, see the color field of the PixelAnomaly object.

*

* An image classification model doesn't return an Anomalies list. */ public void setAnomalyMask(java.nio.ByteBuffer anomalyMask) { this.anomalyMask = anomalyMask; } /** *

* If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an anomaly * type, see the color field of the PixelAnomaly object. *

*

* An image classification model doesn't return an Anomalies list. *

*

* {@code ByteBuffer}s are stateful. Calling their {@code get} methods changes their {@code position}. We recommend * using {@link java.nio.ByteBuffer#asReadOnlyBuffer()} to create a read-only view of the buffer with an independent * {@code position}, and calling {@code get} methods on this rather than directly on the returned {@code ByteBuffer}. * Doing so will ensure that anyone else using the {@code ByteBuffer} will not be affected by changes to the * {@code position}. *

* * @return If the model is an image segmentation model, AnomalyMask contains pixel masks that covers * all anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an * anomaly type, see the color field of the PixelAnomaly object.

*

* An image classification model doesn't return an Anomalies list. */ public java.nio.ByteBuffer getAnomalyMask() { return this.anomalyMask; } /** *

* If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an anomaly * type, see the color field of the PixelAnomaly object. *

*

* An image classification model doesn't return an Anomalies list. *

*

* The AWS SDK for Java performs a Base64 encoding on this field before sending this request to the AWS service. * Users of the SDK should not perform Base64 encoding on this field. *

*

* Warning: ByteBuffers returned by the SDK are mutable. Changes to the content or position of the byte buffer will * be seen by all objects that have a reference to this object. It is recommended to call ByteBuffer.duplicate() or * ByteBuffer.asReadOnlyBuffer() before using or reading from the buffer. This behavior will be changed in a future * major version of the SDK. *

* * @param anomalyMask * If the model is an image segmentation model, AnomalyMask contains pixel masks that covers all * anomaly types found on the image. Each anomaly type has a different mask color. To map a color to an * anomaly type, see the color field of the PixelAnomaly object.

*

* An image classification model doesn't return an Anomalies list. * @return Returns a reference to this object so that method calls can be chained together. */ public DetectAnomalyResult withAnomalyMask(java.nio.ByteBuffer anomalyMask) { setAnomalyMask(anomalyMask); 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 (getSource() != null) sb.append("Source: ").append(getSource()).append(","); if (getIsAnomalous() != null) sb.append("IsAnomalous: ").append(getIsAnomalous()).append(","); if (getConfidence() != null) sb.append("Confidence: ").append(getConfidence()).append(","); if (getAnomalies() != null) sb.append("Anomalies: ").append(getAnomalies()).append(","); if (getAnomalyMask() != null) sb.append("AnomalyMask: ").append(getAnomalyMask()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof DetectAnomalyResult == false) return false; DetectAnomalyResult other = (DetectAnomalyResult) obj; if (other.getSource() == null ^ this.getSource() == null) return false; if (other.getSource() != null && other.getSource().equals(this.getSource()) == false) return false; if (other.getIsAnomalous() == null ^ this.getIsAnomalous() == null) return false; if (other.getIsAnomalous() != null && other.getIsAnomalous().equals(this.getIsAnomalous()) == false) return false; if (other.getConfidence() == null ^ this.getConfidence() == null) return false; if (other.getConfidence() != null && other.getConfidence().equals(this.getConfidence()) == false) return false; if (other.getAnomalies() == null ^ this.getAnomalies() == null) return false; if (other.getAnomalies() != null && other.getAnomalies().equals(this.getAnomalies()) == false) return false; if (other.getAnomalyMask() == null ^ this.getAnomalyMask() == null) return false; if (other.getAnomalyMask() != null && other.getAnomalyMask().equals(this.getAnomalyMask()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getSource() == null) ? 0 : getSource().hashCode()); hashCode = prime * hashCode + ((getIsAnomalous() == null) ? 0 : getIsAnomalous().hashCode()); hashCode = prime * hashCode + ((getConfidence() == null) ? 0 : getConfidence().hashCode()); hashCode = prime * hashCode + ((getAnomalies() == null) ? 0 : getAnomalies().hashCode()); hashCode = prime * hashCode + ((getAnomalyMask() == null) ? 0 : getAnomalyMask().hashCode()); return hashCode; } @Override public DetectAnomalyResult clone() { try { return (DetectAnomalyResult) 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.lookoutforvision.model.transform.DetectAnomalyResultMarshaller.getInstance().marshall(this, protocolMarshaller); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy