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

simplenlg.framework.InflectedWordElement Maven / Gradle / Ivy

The newest version!
/*
 * The contents of this file are subject to the Mozilla Public License
 * Version 2.0 (the "License"); you may not use this file except in
 * compliance with the License. You may obtain a copy of the License at
 * https://www.mozilla.org/en-US/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
 * License for the specific language governing rights and limitations
 * under the License.
 *
 * The Original Code is "Simplenlg".
 *
 * The Initial Developer of the Original Code is Ehud Reiter, Albert Gatt and Dave Westwater.
 * Portions created by Ehud Reiter, Albert Gatt and Dave Westwater are Copyright (C) 2010-11 The University of Aberdeen. All Rights Reserved.
 *
 * Contributor(s): Ehud Reiter, Albert Gatt, Dave Westwater, Roman Kutlak, Margaret Mitchell, and Saad Mahamood.
 */
package simplenlg.framework;

import java.util.List;

import simplenlg.features.InternalFeature;
import simplenlg.features.LexicalFeature;

/**
 * 

* This class defines the NLGElement that is used to represent an * word that requires inflection by the morphology. It has convenience methods * for retrieving the base form of the word (for example, kiss, * eat) and for setting and retrieving the base word. The base word is * a WordElement constructed by the lexicon. *

* * @author D. Westwater, University of Aberdeen. * @version 4.0 */ public class InflectedWordElement extends NLGElement { /** * Constructs a new inflected word using the giving word as the base form. * Constructing the word also requires a lexical category (such as noun, * verb). * * @param word the base form for this inflected word. * @param category the lexical category for the word. */ public InflectedWordElement(String word, LexicalCategory category) { super(); setFeature(LexicalFeature.BASE_FORM, word); setCategory(category); } /** * Constructs a new inflected word from a WordElement * * @param word underlying wordelement */ public InflectedWordElement(WordElement word) { super(); setFeature(InternalFeature.BASE_WORD, word); // AG: changed to use the default spelling variant // setFeature(LexicalFeature.BASE_FORM, word.getBaseForm()); String defaultSpelling = word.getDefaultSpellingVariant(); setFeature(LexicalFeature.BASE_FORM, defaultSpelling); setCategory(word.getCategory()); } /** * This method returns null as the inflected word has no child components. */ @Override public List getChildren() { return null; } @Override public String toString() { return "InflectedWordElement[" + getBaseForm() + ':' //$NON-NLS-1$ + getCategory().toString() + ']'; } @Override public String printTree(String indent) { StringBuffer print = new StringBuffer(); print.append("InflectedWordElement: base=").append(getBaseForm()) //$NON-NLS-1$ .append(", category=").append(getCategory().toString()).append( //$NON-NLS-1$ ", ").append(super.toString()).append( '\n'); //$NON-NLS-1$ return print.toString(); } /** * Retrieves the base form for this element. The base form is the originally * supplied word. * * @return a String forming the base form of the element. */ public String getBaseForm() { return getFeatureAsString(LexicalFeature.BASE_FORM); } /** * Sets the base word for this element. * * @param word the WordElement representing the base word as * read from the lexicon. */ public void setBaseWord(WordElement word) { setFeature(InternalFeature.BASE_WORD, word); } /** * Retrieves the base word for this element. * * @return the WordElement representing the base word as read * from the lexicon. */ public WordElement getBaseWord() { NLGElement baseWord = this.getFeatureAsElement(InternalFeature.BASE_WORD); return baseWord instanceof WordElement ? (WordElement) baseWord : null; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy