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

com.amazonaws.services.cloudsearchv2.model.AnalysisOptions Maven / Gradle / Ivy

Go to download

The Amazon Web Services SDK for Java provides Java APIs for building software on AWS' cost-effective, scalable, and reliable infrastructure products. The AWS Java SDK allows developers to code against APIs for all of Amazon's infrastructure web services (Amazon S3, Amazon EC2, Amazon SQS, Amazon Relational Database Service, Amazon AutoScaling, etc).

The newest version!
/*
 * Copyright 2010-2014 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.cloudsearchv2.model;

import java.io.Serializable;

/**
 * 

* Synonyms, stopwords, and stemming options for an analysis scheme. *

*/ public class AnalysisOptions implements Serializable { /** * A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. */ private String synonyms; /** * A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. */ private String stopwords; /** * A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. */ private String stemmingDictionary; /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Constraints:
* Allowed Values: none, minimal, light, full */ private String algorithmicStemming; /** * A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. * * @return A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. */ public String getSynonyms() { return synonyms; } /** * A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. * * @param synonyms A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. */ public void setSynonyms(String synonyms) { this.synonyms = synonyms; } /** * A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. *

* Returns a reference to this object so that method calls can be chained together. * * @param synonyms A JSON object that defines synonym groups and aliases. A synonym group * is an array of arrays, where each sub-array is a group of terms where * each term in the group is considered a synonym of every other term in * the group. The aliases value is an object that contains a collection * of string:value pairs where the string specifies a term and the array * of values specifies each of the aliases for that term. An alias is * considered a synonym of the specified term, but the term is not * considered a synonym of the alias. * * @return A reference to this updated object so that method calls can be chained * together. */ public AnalysisOptions withSynonyms(String synonyms) { this.synonyms = synonyms; return this; } /** * A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. * * @return A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. */ public String getStopwords() { return stopwords; } /** * A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. * * @param stopwords A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. */ public void setStopwords(String stopwords) { this.stopwords = stopwords; } /** * A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. *

* Returns a reference to this object so that method calls can be chained together. * * @param stopwords A JSON array of terms to ignore during indexing and searching. For * example, ["a", "an", "the", "of"]. The stopwords dictionary must * explicitly list each word you want to ignore. Wildcards and regular * expressions are not supported. * * @return A reference to this updated object so that method calls can be chained * together. */ public AnalysisOptions withStopwords(String stopwords) { this.stopwords = stopwords; return this; } /** * A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. * * @return A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. */ public String getStemmingDictionary() { return stemmingDictionary; } /** * A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. * * @param stemmingDictionary A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. */ public void setStemmingDictionary(String stemmingDictionary) { this.stemmingDictionary = stemmingDictionary; } /** * A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. *

* Returns a reference to this object so that method calls can be chained together. * * @param stemmingDictionary A JSON object that contains a collection of string:value pairs that * each map a term to its stem. For example, {"term1": "stem1", "term2": * "stem2", "term3": "stem3"}. The stemming dictionary is applied in * addition to any algorithmic stemming. This enables you to override the * results of the algorithmic stemming to correct specific cases of * overstemming or understemming. The maximum size of a stemming * dictionary is 500 KB. * * @return A reference to this updated object so that method calls can be chained * together. */ public AnalysisOptions withStemmingDictionary(String stemmingDictionary) { this.stemmingDictionary = stemmingDictionary; return this; } /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Constraints:
* Allowed Values: none, minimal, light, full * * @return The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide * * @see AlgorithmicStemming */ public String getAlgorithmicStemming() { return algorithmicStemming; } /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Constraints:
* Allowed Values: none, minimal, light, full * * @param algorithmicStemming The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide * * @see AlgorithmicStemming */ public void setAlgorithmicStemming(String algorithmicStemming) { this.algorithmicStemming = algorithmicStemming; } /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Allowed Values: none, minimal, light, full * * @param algorithmicStemming The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide * * @return A reference to this updated object so that method calls can be chained * together. * * @see AlgorithmicStemming */ public AnalysisOptions withAlgorithmicStemming(String algorithmicStemming) { this.algorithmicStemming = algorithmicStemming; return this; } /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Constraints:
* Allowed Values: none, minimal, light, full * * @param algorithmicStemming The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide * * @see AlgorithmicStemming */ public void setAlgorithmicStemming(AlgorithmicStemming algorithmicStemming) { this.algorithmicStemming = algorithmicStemming.toString(); } /** * The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Allowed Values: none, minimal, light, full * * @param algorithmicStemming The level of algorithmic stemming to perform: none, * minimal, light, or full. The * available levels vary depending on the language. For more information, * see Langage Specific Text Processing Settings in the * Amazon CloudSearch Developer Guide * * @return A reference to this updated object so that method calls can be chained * together. * * @see AlgorithmicStemming */ public AnalysisOptions withAlgorithmicStemming(AlgorithmicStemming algorithmicStemming) { this.algorithmicStemming = algorithmicStemming.toString(); return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getSynonyms() != null) sb.append("Synonyms: " + getSynonyms() + ","); if (getStopwords() != null) sb.append("Stopwords: " + getStopwords() + ","); if (getStemmingDictionary() != null) sb.append("StemmingDictionary: " + getStemmingDictionary() + ","); if (getAlgorithmicStemming() != null) sb.append("AlgorithmicStemming: " + getAlgorithmicStemming() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getSynonyms() == null) ? 0 : getSynonyms().hashCode()); hashCode = prime * hashCode + ((getStopwords() == null) ? 0 : getStopwords().hashCode()); hashCode = prime * hashCode + ((getStemmingDictionary() == null) ? 0 : getStemmingDictionary().hashCode()); hashCode = prime * hashCode + ((getAlgorithmicStemming() == null) ? 0 : getAlgorithmicStemming().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof AnalysisOptions == false) return false; AnalysisOptions other = (AnalysisOptions)obj; if (other.getSynonyms() == null ^ this.getSynonyms() == null) return false; if (other.getSynonyms() != null && other.getSynonyms().equals(this.getSynonyms()) == false) return false; if (other.getStopwords() == null ^ this.getStopwords() == null) return false; if (other.getStopwords() != null && other.getStopwords().equals(this.getStopwords()) == false) return false; if (other.getStemmingDictionary() == null ^ this.getStemmingDictionary() == null) return false; if (other.getStemmingDictionary() != null && other.getStemmingDictionary().equals(this.getStemmingDictionary()) == false) return false; if (other.getAlgorithmicStemming() == null ^ this.getAlgorithmicStemming() == null) return false; if (other.getAlgorithmicStemming() != null && other.getAlgorithmicStemming().equals(this.getAlgorithmicStemming()) == false) return false; return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy