6.2 Mining single-dimensional Boolean association rules from transactional databases
6.2.1 The Apriori algorithm: Finding frequent itemsets
Aprioriis an inuential algorithm for mining frequent itemsets for Boolean association rules. The name of the algorithm is based on the fact that the algorithm uses prior knowledgeof frequent itemset properties, as we shall see below. Apriori employs an iterative approach known as alevel-wisesearch, where k-itemsets are used to explore (k+1)-itemsets. First, the set of frequent 1-itemsets is found. This set is denoted L1. L1 is used to nd L2, the frequent 2-itemsets, which is used to ndL3, and so on, until no more frequentk-itemsets can be found. The nding of eachLk requires one full scan of the database.
To improve the eciency of the level-wise generation of frequent itemsets, an important property called the Apriori property, presented below, is used to reduce the search space.
The Apriori property. All non-empty subsets of a frequent itemset must also be frequent.
This property is based on the following observation. By denition, if an itemsetI does not satisfy the minimum support threshold, s, then I is not frequent, i.e., ProbfIg< s. If an itemA is added to the itemset I, then the resulting itemset (i.e., I [A) cannot occur more frequently than I. Therefore, I [A is not frequent either, i.e., ProbfI[Ag< s.
This property belongs to a special category of properties calledanti-monotonein the sense thatif a set cannot pass a test, all of its supersets will fail the same test as well. It is called anti-monotone because the property is monotonic in the context of failing a test.
\How is the Apriori property used in the algorithm?"To understand this, we must look at howLk,1 is used to ndLk. A two step process is followed, consisting ofjoinandpruneactions.
1. The join step: To ndLk, a set ofcandidatek-itemsets is generated by joining Lk,1 with itself. This set of candidates is denotedCk. The join,Lk,11Lk,1, is performed, where members ofLk,1are joinable if they have (k,2) items in common, that is,Lk,11Lk,1=fA1BjA;B2Lk,1;jA\Bj=k,2g.
www.elsolucionario.net
2. The prune step: Ck is a superset of Lk, that is, its members may or may not be frequent, but all of the frequent k-itemsets are included inCk. A scan of the database to determine the count of each candidate inCk
would result in the determination ofLk (i.e., all candidates having a count no less than the minimum support count are frequent by denition, and therefore belong to Lk). Ck, however, can be huge, and so this could involve heavy computation. To reduce the size ofCk, the Apriori property is used as follows. Any(k-1)-itemset that is not frequent cannot be a subset of a frequent k-itemset. Hence, if any (k-1)-subset of a candidate k-itemset is not inLk,1, then the candidate cannot be frequent either and so can be removed fromCk. This subset testing can be done quickly by maintaining a hash tree of all frequent itemsets.
AllElectronicsdatabase TID List of item ID's T100 I1, I2, I5 T200 I2, I3, I4 T300 I3, I4 T400 I1, I2, I3, I4
Figure 6.2: Transactional data for anAllElectronicsbranch.
Example 6.1 Let's look at a concrete example of Apriori, based on the AllElectronicstransaction database,D, of Figure 6.2. There are four transactions in this database, i.e.,jDj= 4. Apriori assumes that items within a transaction are sorted in lexicographic order. We use Figure 6.3 to illustrate the APriori algorithm for nding frequent itemsets inD.
In the rst iteration of the algorithm, each item is a member of the set of candidate 1-itemsets, C1. The algorithm simply scans all of the transactions in order to count the number of occurrences of each item.
Suppose that the minimum transaction support count required is 2 (i.e.,min sup= 50%). The set of frequent 1-itemsets,L1, can then be determined. It consists of the candidate 1-itemsets having minimum support.
To discover the set of frequent 2-itemsets, L2, the algorithm uses L1 1 L1 to generate a candidate set of 2-itemsets,C2 3. C2 consists of,jL21j2-itemsets.
Next, the transactions inDare scanned and the support count of each candidate itemset inC2is accumulated, as shown in the middle table of the second row in Figure 6.3.
The set of frequent 2-itemsets, L2, is then determined, consisting of those candidate 2-itemsets inC2 having minimum support.
The generation of the set of candidate 3-itemsets, C3, is detailed in Figure 6.4. First, let C3 =L2 1L2 =
ffI1;I2;I3g;fI1;I2;I4g;fI2;I3;I4gg. Based on the Apriori property that all subsets of a frequent itemset must also be frequent, we can determine that the candidates fI1,I2,I3g and fI1,I2,I4g cannot possibly be frequent. We therefore remove them fromC3, thereby saving the eort of unnecessarily obtaining their counts during the subsequent scan ofDto determineL3. Note that since the Apriori algorithm uses a level-wise search strategy, then given a k-itemset, we only need to check if its(k-1)-subsets are frequent.
The transactions in D are scanned in order to determine L3, consisting of those candidate 3-itemsets in C3 having minimum support (Figure 6.3).
No more frequent itemsets can be found (since here, C4=), and so the algorithm terminates, having found all of the frequent itemsets.
2
3L11L1is equivalent toL1L1since the denition ofLk1Lk requires the two joining itemsets to sharek,1 = 0 items.
www.elsolucionario.net
ScanDfor count of each
candidate
,!
C1 Itemset Sup.
fI1g 2
fI2g 3
fI3g 3
fI4g 3
fI5g 1
Compare candidate support with minimum support
count
,!
L1 Itemset Sup.
fI1g 2
fI2g 3
fI3g 3
fI4g 3 GenerateC2
candidates from L1
,!
C2 Itemset
fI1,I2g
fI1,I3g
fI1,I4g
fI2,I3g
fI2,I4g
fI3,I4g
Scan Dfor count of each candidate
,!
C2
Itemset Sup.
fI1,I2g 2
fI1,I3g 1
fI1,I4g 1
fI2,I3g 2
fI2,I4g 2
fI3,I4g 3
Compare candidate support with minimum support
count
,!
L2 Itemset Sup.
fI1,I2g 2
fI2,I3g 2
fI2,I4g 2
fI3,I4g 3
GenerateC3 candidates from
L2
,!
C3 Itemset
fI2,I3,I4g ScanDfor count of each
candidate
,!
C3 Itemset Sup.
fI2,I3,I4g 2 Compare candidate support with minimum support
count
,!
L3 Itemset Sup.
fI2,I3,I4g 2
Figure 6.3: Generation of candidate itemsets and frequent itemsets, where the minimum support count is 2.
1. C3 = L2 1 L2 = ffI1,I2g, fI2,I3g, fI2,I4g, fI3,I4gg 1 ffI1,I2g, fI2,I3g, fI2,I4g, fI3,I4gg =
ffI1;I2;I3g;fI1;I2;I4g;fI2;I3;I4gg.
2. Apriori property: All subsets of a frequent itemset must also be frequent. Do any of the candidates have a subset that is not frequent?
{ The 2-item subsets offI1,I2,I3garefI1,I2g,fI1,I3g, andfI2,I3g. fI1,I3gis not a member ofL2, and so it is not frequent. Therefore, removefI1,I2,I3gfromC3.
{ The 2-item subsets offI1,I2,I4garefI1,I2g,fI1,I4g, andfI2,I4g. fI1,I4gis not a member ofL2, and so it is not frequent. Therefore, removefI1,I2,I4gfromC3.
{ The 2-item subsets of fI2,I3,I4garefI2,I3g,fI2,I4g, andfI3,I4g. All 2-item subsets of fI2,I3,I4gare members ofL2. Therefore, keepfI2,I3,I4ginC3.
3. Therefore, C3=ffI2;I3;I4gg.
Figure 6.4: Generation of candidate 3-itemsets,C3, fromL2 using the Apriori property.
www.elsolucionario.net
Algorithm 6.2.1 (Apriori) Find frequent itemsets using an iterative level-wise approach.
Input: Database,D, of transactions; minimum support threshold,min sup.
Output: L, frequent itemsets in D.
Method:
1) L1 = nd frequent 1-itemsets(D);
2) for(k= 2;Lk,16=;k++)f 3) Ck = apriori gen(Lk,1,min sup);
4) for eachtransaction t2Df// scanDfor counts
5) Ct= subset(Ck;t); // get the subsets oftthat are candidates 6) for eachcandidatec2Ct
7) c.count++;
8) g
9) Lk=fc2Ckjc:countmin supg 10) g
11) returnL=[kLk;
pro cedureapriorigen(Lk,1:frequent(k-1)-itemsets;min sup: minimum support) 1) for eachitemsetl12Lk,1
2) for eachitemsetl22Lk,1
3) if(l1[1] =l2[1])^(l1[2] =l2[2])^:::^(l1[k,2] =l2[k,2])^(l1[k,1]< l2[k,1])thenf
4) c=l11l2; // join step: generate candidates 5) ifhasinfrequentsubset(c;Lk,1)then
6) deletec; // prune step: remove unfruitful candidate 7) else addctoCk;
8) g
9) returnCk;
pro cedurehasinfrequentsubset(c: candidatek-itemset;Lk,1: frequent (k,1)-itemsets); // use prior knowledge 1) for each(k,1)-subsetsofc
2) ifs62Lk,1 then
3) returnTRUE;
4) returnFALSE;
Figure 6.5: The Apriori algorithm for discovering frequent itemsets for mining Boolean association rules.
Figure 6.5 shows pseudo-code for the Apriori algorithm and its related procedures. Step 1 of Apriori nds the frequent 1-itemsets,L1. In steps 2-10,Lk,1is used to generate candidatesCk in order to ndLk. Theapriori gen procedure generates the candidates and then uses the Apriori property to eliminate those having a subset that is not frequent (step 3). This procedure is described below. Once all the candidates have been generated, the database is scanned (step 4). For each transaction, a subset function is used to nd all subsets of the transaction that are candidates (step 5), and the count for each of these candidates is accumulated (steps 6-7). Finally, all those candidates satisfying minimum support form the set of frequent itemsets, L. A procedure can then be called to generate association rules from the frequent itemsets. Such as procedure is described in Section 6.2.2.
The apriori gen procedure performs two kinds of actions, namelyjoinandprune, as described above. In the join component,Lk,1is joined withLk,1 to generate potential candidates (steps 1-4). The conditionl1[k,1]< l2[k,1]
simply ensures that no duplicates are generated (step 3). The prune component (steps 5-7) employs the Apriori property to remove candidates that have a subset that is not frequent. The test for infrequent subsets is shown in procedurehas infrequent subset.