⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 attributetypefilter.java

📁 :<<数据挖掘--实用机器学习技术及java实现>>一书的配套源程序
💻 JAVA
字号:
/* *    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 2 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, write to the Free Software *    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *//* *    AttributeTypeFilter.java *    Copyright (C) 1999 Intelligenesis Corp. * */package weka.filters;import weka.core.Attribute;import weka.core.Instance;import weka.core.SparseInstance;import weka.core.Instances;import weka.core.OptionHandler;import java.util.Enumeration;import weka.core.SelectedTag;import weka.core.Tag;import java.util.Vector;import weka.core.Option;import weka.core.Utils;import weka.core.FastVector;/**  * An instance filter that deletes all attributes of a specified type * from the dataset.<p> * * Valid filter-specific options are:<p> * * -T type <br> * Specify the attribute type to delete. Valid values are "nominal", "numeric", * and "string". (default "string")<p> * * @author Len Trigg (len@intelligenesis.net) * @version $Revision: 1.9 $ */public class AttributeTypeFilter extends Filter implements OptionHandler {  /** Stores which type of attribute to delete */  protected int m_DeleteType = Attribute.STRING;  /* Define possible attribute types to delete */  public static final Tag [] TAGS_ATTRIBUTES = {    new Tag(Attribute.STRING, "Delete string attributes"),    new Tag(Attribute.NOMINAL, "Delete nominal attributes"),    new Tag(Attribute.NUMERIC, "Delete numeric attributes")  };  /**   * Returns an enumeration describing the available options   *   * @return an enumeration of all the available options   */  public Enumeration listOptions() {    Vector newVector = new Vector(1);    newVector.addElement(new Option(              "\tSpecify the attribute type to delete. Valid values are:\n"	      + "\t\"nominal\", \"numeric\", and \"string\". \n"              + "(default \"string\")",              "T", 1, "-T <type>"));    return newVector.elements();  }  /**   * Parses a given list of options controlling the behaviour of this object.   * Valid options are:<p>   *   * -T type <br>   * Specify the attribute type to delete. Valid values are "nominal",    * "numeric", and "string". (default "string")<p>   *   * @param options the list of options as an array of strings   * @exception Exception if an option is not supported   */  public void setOptions(String[] options) throws Exception {    String attributeType = Utils.getOption('T', options);    if (attributeType.length() != 0) {      attributeType = attributeType.toLowerCase();      if (attributeType.equals("nominal")) {        setAttributeType(new SelectedTag(Attribute.NOMINAL, TAGS_ATTRIBUTES));      } else if (attributeType.equals("numeric")) {        setAttributeType(new SelectedTag(Attribute.NUMERIC, TAGS_ATTRIBUTES));      } else {        setAttributeType(new SelectedTag(Attribute.STRING, TAGS_ATTRIBUTES));      }    } else {      setAttributeType(new SelectedTag(Attribute.STRING, TAGS_ATTRIBUTES));    }        if (getInputFormat() != null) {      setInputFormat(getInputFormat());    }  }  /**   * Gets the current settings of the filter.   *   * @return an array of strings suitable for passing to setOptions   */  public String [] getOptions() {    String [] options = new String [2];    int current = 0;    options[current++] = "-T";    if (m_DeleteType == Attribute.NOMINAL) {      options[current++] = "nominal";    } else if (m_DeleteType == Attribute.NUMERIC) {      options[current++] = "numeric";    } else {      options[current++] = "string";    }    while (current < options.length) {      options[current++] = "";    }    return options;  }  /**   * Gets the type of attribute that will be deleted. The ID will be one of   * Attribute.STRING, Attribute.NOMINAL, or Attribute.NUMERIC.   *   * @return the selected attribute type.   */  public SelectedTag getAttributeType() {    return new SelectedTag(m_DeleteType, TAGS_ATTRIBUTES);  }  /**   * Sets the type of attribute to delete. Values other than   * Attribute.STRING, Attribute.NOMINAL, or Attribute.NUMERIC will be ignored.   *   * @param newAttributeType the type of attribute to delete.   */  public void setAttributeType(SelectedTag newType) {        if (newType.getTags() == TAGS_ATTRIBUTES) {      m_DeleteType = newType.getSelectedTag().getID();    }  }  /**   * Sets the format of the input instances.   *   * @param instanceInfo an Instances object containing the input instance   * structure (any instances contained in the object are ignored - only the   * structure is required).   * @return true if the outputFormat may be collected immediately   * @exception Exception if the format couldn't be set successfully   */  public boolean setInputFormat(Instances instanceInfo) throws Exception {    super.setInputFormat(instanceInfo);        // Create the output buffer    FastVector attributes = new FastVector();    int outputClass = -1;    for (int i = 0; i < instanceInfo.numAttributes(); i++) {      if (instanceInfo.attribute(i).type() != m_DeleteType) {        if (instanceInfo.classIndex() == i) {          outputClass = attributes.size();        }        attributes.addElement(instanceInfo.attribute(i));      }    }    Instances outputFormat = new Instances(instanceInfo.relationName(),					   attributes, 0);     outputFormat.setClassIndex(outputClass);    setOutputFormat(outputFormat);    return true;  }    /**   * Input an instance for filtering. Ordinarily the instance is processed   * and made available for output immediately. Some filters require all   * instances be read before producing output.   *   * @param instance the input instance   * @return true if the filtered instance may now be   * collected with output().   * @exception IllegalStateException if no input format has been defined.   */  public boolean input(Instance instance) {    if (getInputFormat() == null) {      throw new IllegalStateException("No input instance format defined");    }    if (m_NewBatch) {      resetQueue();      m_NewBatch = false;    }    double[] vals = new double[outputFormatPeek().numAttributes()];    int j = 0;    for (int i = 0; i < getInputFormat().numAttributes(); i++) {      if (getInputFormat().attribute(i).type() != m_DeleteType) {	vals[j++] = instance.value(i);      }    }    Instance inst = null;    if (instance instanceof SparseInstance) {      inst = new SparseInstance(instance.weight(), vals);    } else {      inst = new Instance(instance.weight(), vals);    }    if (m_DeleteType != Attribute.STRING) {      copyStringValues(inst, false, instance.dataset(), getInputStringIndex(),                       getOutputFormat(), getOutputStringIndex());    }    inst.setDataset(getOutputFormat());    push(inst);    return true;  }  /**   * Main method for testing this class.   *   * @param argv should contain arguments to the filter: use -h for help   */  public static void main(String [] argv) {    try {      if (Utils.getFlag('b', argv)) { 	Filter.batchFilterFile(new AttributeTypeFilter(), argv);       } else {	Filter.filterFile(new AttributeTypeFilter(), argv);      }    } catch (Exception ex) {      ex.printStackTrace();      System.out.println(ex.getMessage());    }  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -