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

weka.core.pmml.Constant Maven / Gradle / Ivy

/*
 *   This program is free software: you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation, either version 3 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program.  If not, see .
 */

/*
 *    Constant.java
 *    Copyright (C) 2008-2012 University of Waikato, Hamilton, New Zealand
 *
 */

package weka.core.pmml;

import java.util.ArrayList;

import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import weka.core.Attribute;

/**
 * Class encapsulating a Constant Expression.
 * 
 * @author Mark Hall (mhall{[at]}pentaho{[dot]}com
 * @version $Revision 1.0 $
 */
public class Constant extends Expression {
  
  /**
   * For serialization 
   */
  private static final long serialVersionUID = -304829687822452424L;
  
  protected String m_categoricalConst = null;
  protected double m_continuousConst = Double.NaN;

  /**
   * Construct an new Constant Expression.
   * 
   * @param constant the xml Element containing the Constant
   * @param opType the optype for the Constant
   * @param fieldDefs an ArrayList of Attributes for the fields that this
   * Expression might need to access (not needed for a constant!)
   * @throws Exception if the optype is specified as continuous
   * and there is a problem parsing the value of the Constant
   */
  public Constant(Element constant, FieldMetaInfo.Optype opType, ArrayList fieldDefs) 
    throws Exception {
    super(opType, fieldDefs);
    
    NodeList constL = constant.getChildNodes();
    String c = constL.item(0).getNodeValue();
    
    if (m_opType == FieldMetaInfo.Optype.CATEGORICAL ||
        m_opType == FieldMetaInfo.Optype.ORDINAL) {
      m_categoricalConst = c;
    } else {
      try {
        m_continuousConst = Double.parseDouble(c);
      } catch (IllegalArgumentException ex) {
        throw new Exception("[Constant] Unable to parse continuous constant: "
            + c);
      }
    }
  }
  
  /**
   * Return the structure of the result of applying this Expression
   * as an Attribute.
   * 
   * @return the structure of the result of applying this Expression as an
   * Attribute.
   */
  protected Attribute getOutputDef() {
    
    if (m_opType == FieldMetaInfo.Optype.CONTINUOUS) {
      return new Attribute("Constant: " + m_continuousConst);
    }
    
    ArrayList nom = new ArrayList();
    nom.add(m_categoricalConst);
    return new Attribute("Constant: " + m_categoricalConst, nom);
  }
  
  /**
   * Get the result of evaluating the expression. In the case
   * of a continuous optype, a real number is returned; in
   * the case of a categorical/ordinal optype, the index of the nominal
   * value is returned as a double.
   * 
   * @param incoming the incoming parameter values
   * @return the result of evaluating the expression
   */
  public double getResult(double[] incoming) {
    if (m_opType == FieldMetaInfo.Optype.CONTINUOUS) {
      return m_continuousConst;
    }
    return 0; // constant (first and only value of a nominal attribute)
  }
  
  /**
   * Gets the result of evaluating the expression when the
   * optype is categorical or ordinal as the actual String
   * value.
   * 
   * @param incoming the incoming parameter values 
   * @return the result of evaluating the expression
   * @throws Exception if the optype is continuous
   */
  public String getResultCategorical(double[] incoming) 
    throws Exception {
    if (m_opType == FieldMetaInfo.Optype.CONTINUOUS) {
      throw new IllegalArgumentException("[Constant] Cant't return result as "
          +"categorical/ordinal as optype is continuous!");
    }
    return m_categoricalConst;
  }
  
  public static void main(String[] args) {
    try {
      java.io.File f = new java.io.File(args[0]);
      javax.xml.parsers.DocumentBuilderFactory dbf = javax.xml.parsers.DocumentBuilderFactory.newInstance();
      javax.xml.parsers.DocumentBuilder db = dbf.newDocumentBuilder();
      org.w3c.dom.Document doc = db.parse(f);
      doc.getDocumentElement().normalize();
      NodeList constL = doc.getElementsByTagName("Constant");
      Node c = constL.item(0);
      
      if (c.getNodeType() == Node.ELEMENT_NODE) {
        Constant constC = new Constant((Element)c, FieldMetaInfo.Optype.CONTINUOUS, null);
        System.err.println("Value of first constant: " + constC.getResult(null));
      }
    } catch (Exception ex) {
      ex.printStackTrace();
    }
  }
  
  public String toString(String pad) {
    return pad + "Constant: " + ((m_categoricalConst != null)
        ? m_categoricalConst
        : "" + m_continuousConst); 
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy