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

weka.associations.AssociationRule 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 .
 */

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

package weka.associations;

import java.util.ArrayList;
import java.util.Collection;

/**
 * Abstract class for storing and manipulating an association rule.
 * 
 * @author Mark Hall (mhall{[at]}pentaho{[dot]}com).
 * @version $Revision: 8034 $
 */
public abstract class AssociationRule implements Comparable {

  /**
   * Get the premise of this rule.
   * 
   * @return the premise of this rule.
   */
  public abstract Collection getPremise();

  /**
   * Get the consequence of this rule.
   * 
   * @return the consequence of this rule.
   */
  public abstract Collection getConsequence();

  /**
   * Get the name of the primary metric of this rule (e.g. confidence).
   * 
   * @return the name of the primary metric of this rule.
   */
  public abstract String getPrimaryMetricName();

  /**
   * Get the value of the metric for this rule. 
   * 
   * @return the value of the metric for this rule.
   */
  public abstract double getPrimaryMetricValue();

  /**
   * Get the value of the named metric for this rule
   * 
   * @param metricName the metric to get the value for
   * @return the value of the named metric
   * @throws Exception if the requested metric is unknown for this rule
   */
  public abstract double getNamedMetricValue(String metricName)
      throws Exception;

  /**
   * Gets the number of metrics available for this rule.
   * 
   * @return the number of metrics available for this rule
   */
  public abstract int getNumberOfMetricsForRule();

  /**
   * Return the names of the metrics available for this rule.
   * 
   * @return the names of the metrics that are available for this rule.
   */
  public abstract String[] getMetricNamesForRule();

  /**
   * Get all the available metric values for this rule. Values are
   * returned in an array with entries that correspond to the metric
   * names returned by getMetricNamesForRule().
   * 
   * @return all the available metrics for this rule.
   * @throws Exception if a metric can't be computed for some reason.
   */
  public abstract double[] getMetricValuesForRule() throws Exception;

  /**
   * Get the support for the premise.
   * 
   * @return the support for the premise.
   */
  public abstract int getPremiseSupport();

  /**
   * Get the support for the consequence.
   * 
   * @return the support for the consequence.
   */
  public abstract int getConsequenceSupport();

  /**
   * Get the total support for this rule (premise + consequence).
   * 
   * @return the total support for this rule.
   */
  public abstract int getTotalSupport();

  /**
   * Get the total number of transactions in the data.
   * 
   * @return the total number of transactions in the data.
   */
  public abstract int getTotalTransactions();
  
  /**
   * Compare this rule to the supplied rule.
   * 
   * @param other the rule to compare to.
   * @return the result of the comparison.
   */
  public int compareTo(AssociationRule other) {
    return -Double.compare(getPrimaryMetricValue(), other.getPrimaryMetricValue());
  }
  
  /**
   * Return true if this rule is equal to the supplied one.
   * 
   * @return true if this rule is the same as the supplied rule.
   */
  public boolean equals(Object other) {
    if (!(other instanceof AssociationRule)) {
      return false;
    }
    
    AssociationRule otherRule = (AssociationRule)other;
    boolean result = getPremise().equals(otherRule.getPremise()) &&
      getConsequence().equals(otherRule.getConsequence()) && 
      (getPrimaryMetricValue() == otherRule.getPrimaryMetricValue());
    
    return result;
  }
  
  public boolean containsItems(ArrayList items, boolean useOr) {
    int numItems = items.size();
    int count = 0;
    
    for (Item i : getPremise()) {
      if (items.contains(i)) {
        if (useOr) {
          return true; // can stop here
        } else {
          count++;
        }
      }
    }
    
    for (Item i : getConsequence()) {
      if (items.contains(i)) {
        if (useOr) {
          return true; // can stop here
        } else {
          count++;
        }
      }
    }
    
    if (!useOr) {
      if (count == numItems) {
        return true;
      }
    }
    
    return false;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy