|
|
|||||||||||||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||||||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||||||||||||||
java.lang.Objectde.lmu.ifi.dbs.elki.logging.AbstractLoggable
de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizable
de.lmu.ifi.dbs.elki.algorithm.AbstractAlgorithm<BitVector>
de.lmu.ifi.dbs.elki.algorithm.APRIORI
public class APRIORI
Provides the APRIORI algorithm for Mining Association Rules.
Reference:
R. Agrawal, R. Srikant: Fast Algorithms for Mining Association Rules in Large Databases.
In Proc. 20th Int. Conf. on Very Large Data Bases (VLDB '94), Santiago de Chile, Chile 1994.
| Field Summary | |
|---|---|
private double |
minfreq
Holds the value of MINFREQ_PARAM. |
static OptionID |
MINFREQ_ID
OptionID for MINFREQ_PARAM |
private DoubleParameter |
MINFREQ_PARAM
Optional parameter to specify the threshold for minimum frequency, must be a double greater than or equal to 0 and less than or equal to 1. |
private int |
minsupp
Holds the value of MINSUPP_PARAM. |
static OptionID |
MINSUPP_ID
OptionID for MINSUPP_PARAM |
private IntParameter |
MINSUPP_PARAM
Parameter to specify the threshold for minimum support as minimally required number of transactions, must be an integer equal to or greater than 0. |
private AprioriResult |
result
The result. |
private Map<BitSet,Integer> |
support
Keeps the support of all evaluated bitsets. |
| Fields inherited from class de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizable |
|---|
optionHandler |
| Fields inherited from class de.lmu.ifi.dbs.elki.logging.AbstractLoggable |
|---|
debug |
| Constructor Summary | |
|---|---|
APRIORI()
Provides the apriori algorithm, adding parameters MINFREQ_PARAM and
MINSUPP_PARAM to the option handler
additionally to parameters of super class. |
|
| Method Summary | |
|---|---|
protected BitSet[] |
frequentItemsets(BitSet[] candidates,
Database<BitVector> database)
Returns the frequent BitSets out of the given BitSets with respect to the given database. |
Description |
getDescription()
Returns a description of the algorithm. |
AprioriResult |
getResult()
Returns the result of the algorithm. |
protected BitSet[] |
join(BitSet[] frequentItemsets)
Returns a set of BitSets generated by joining pairs of given BitSets (relying on the given BitSets being sorted), increasing the length by 1. |
protected BitSet[] |
prune(BitSet[] candidates,
int size)
Prunes a given set of candidates to keep only those BitSets where all subsets of bits flipping one bit are frequent already. |
protected void |
runInTime(Database<BitVector> database)
The run method encapsulated in measure of runtime. |
String[] |
setParameters(String[] args)
Calls AbstractAlgorithm#setParameters(args)
and sets additionally the values of the parameters
MINFREQ_PARAM and MINSUPP_PARAM. |
| Methods inherited from class de.lmu.ifi.dbs.elki.algorithm.AbstractAlgorithm |
|---|
description, isTime, isVerbose, run, setTime, setVerbose |
| Methods inherited from class de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizable |
|---|
addOption, checkGlobalParameterConstraints, deleteOption, description, description, getAttributeSettings, getParameters, getParameterValue, getPossibleOptions, inlineDescription, isSet, setParameters |
| Methods inherited from class de.lmu.ifi.dbs.elki.logging.AbstractLoggable |
|---|
debugFine, debugFiner, debugFinest, exception, message, progress, progress, progress, verbose, verbose, warning |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Methods inherited from interface de.lmu.ifi.dbs.elki.utilities.optionhandling.Parameterizable |
|---|
checkGlobalParameterConstraints, getAttributeSettings, getParameters, getPossibleOptions, inlineDescription |
| Field Detail |
|---|
public static final OptionID MINFREQ_ID
MINFREQ_PARAM
private final DoubleParameter MINFREQ_PARAM
MINSUPP_PARAM).
Key: -apriori.minfreq
private double minfreq
MINFREQ_PARAM.
public static final OptionID MINSUPP_ID
MINSUPP_PARAM
private final IntParameter MINSUPP_PARAM
MINFREQ_PARAM
- setting MINSUPP_PARAM is slightly preferable over setting
MINFREQ_PARAM in terms of efficiency.
Key: -apriori.minsupp
private int minsupp
MINSUPP_PARAM.
private AprioriResult result
private Map<BitSet,Integer> support
| Constructor Detail |
|---|
public APRIORI()
MINFREQ_PARAM and
MINSUPP_PARAM to the option handler
additionally to parameters of super class.
| Method Detail |
|---|
protected void runInTime(Database<BitVector> database)
throws IllegalStateException
AbstractAlgorithm
runInTime in class AbstractAlgorithm<BitVector>database - the database to run the algorithm on
IllegalStateException - if the algorithm has not been initialized
properly (e.g. the setParameters(String[]) method has been failed
to be called).Algorithm.run(de.lmu.ifi.dbs.elki.database.Database)
protected BitSet[] prune(BitSet[] candidates,
int size)
candidates - the candidates to be prunedsize - size of the database
protected BitSet[] join(BitSet[] frequentItemsets)
frequentItemsets - the BitSets to be joined
protected BitSet[] frequentItemsets(BitSet[] candidates,
Database<BitVector> database)
candidates - the candidates to be evaluateddatabase - the database to evaluate the candidates on
public AprioriResult getResult()
Algorithm
Algorithm.getResult()public Description getDescription()
Algorithm
Algorithm.getDescription()
public String[] setParameters(String[] args)
throws ParameterException
AbstractAlgorithm#setParameters(args)
and sets additionally the values of the parameters
MINFREQ_PARAM and MINSUPP_PARAM.
setParameters in interface ParameterizablesetParameters in class AbstractAlgorithm<BitVector>args - parameters to set the attributes accordingly to
ParameterException - in case of wrong parameter-settingParameterizable.setParameters(String[])
|
|
||||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||||