Skip to main content

What is Association Rule Mining

Machine Learning Association Rule Mining Algorithms 

Concepts of Association Rule Mining

Association Rule Mining is a technique of data mining used for finding co-occurrence relationships and patterns in large datasets. It is employed to glean intriguing connections between variables in sizable databases. The relationships discovered in Association Rule Mining are represented in the form of rules, where the antecedent and consequent are a set of items. 

There are several algorithms used in Association Rule Mining, such as Apriori, FP-Growth, ECLAT, and more. Among these algorithms, Apriori is the most widely used algorithm for Association Rule Mining. 

The item sets that do not match the minimal support criterion are pruned by the Apriori algorithm after it generates a candidate set of item sets. The support threshold is a user-defined value that determines the minimum frequency of an item set to be considered as frequent.

technique of data mining used for finding co-occurrence relationships and patterns in large datasets


Association Rule Mining Algorithm

  • Define the problem and collect data.
  • Set a minimum support threshold and a minimum confidence threshold.
  • Identify all frequent itemsets that meet the minimum support threshold.
  • Generate association rules for each frequent itemset that meets the minimum confidence threshold.
  • Evaluate the model on a test dataset to estimate its performance.

Example:

Consider a retail store that wants to analyse the buying patterns of its customers. The store has a transaction dataset containing the items bought by the customers. The dataset contains the following transactions:

Transaction 1: {Bread, Milk, Cheese}

Transaction 2: {Bread, Milk}

Transaction 3: {Milk, Eggs}

Transaction 4: {Bread, Eggs}

Transaction 5: {Bread, Milk, Eggs, Cheese}

Using the Apriori algorithm, we can find the frequent itemsets and generate association rules from the dataset. Let us assume a minimum support threshold of 40%.

Step 1: Find the frequent 1-itemsets

The frequent 1-itemsets are:

{Bread} (4)

{Milk} (4)

{Cheese} (2)

{Eggs} (2)

The number in the parentheses represents the frequency of the itemset.

Step 2: Find the frequent 2-itemsets

The frequent 2-itemsets are:

{Bread, Milk} (3)

{Bread, Cheese} (1)

{Milk, Cheese} (1)

{Milk, Eggs} (2)

{Bread, Eggs} (1)

{Milk, Bread} (3)

Step 3: Find the frequent 3-itemsets

There is only one frequent 3-itemset:

{Bread, Milk, Eggs} (1)

Step 4: Generate association rules

Using the frequent itemsets, we can generate association rules. Let us assume a minimum confidence threshold of 50%.

The association rules are:

{Bread} -> {Milk} (3/4 = 75%)

{Milk} -> {Bread} (3/4 = 75%)

{Bread} -> {Eggs} (1/4 = 25%)

{Eggs} -> {Bread} (1/2 = 50%)

{Milk} -> {Eggs} (2/4 = 50%)

{Eggs} -> {Milk} (2/2 = 100%)

{Bread, Milk} -> {Eggs} (1/3 = 33.3%)

{Bread, Eggs} -> {Milk} (1/1 = 100%)

{Milk, Eggs} -> {Bread} (1/2 = 50%)

Python implementation of the Apriori algorithm for Association Rule Mining:

python code

# Importing required libraries

import pandas as pd

from extend.frequent_patterns import apriori

from extend.frequent_patterns import association_rules

# Reading the dataset

data = pd.read_csv('dataset.CSV)

# Encoding categorical variables

data_encoded = pd.get_dummies(data)

# Applying the Apriori algorithm with minimum support of 0.01

frequent_itemsets = apriori(data_encoded, min_support=0.01, use_colnames=True)

# Generating association rules with a minimum lift of 1.5

rules = association_rules(frequent_itemsets, metric="lift", min_threshold=1.5)

# Displaying the rules

print(rules)

Benefits and Advantages of Association Rule Mining: 

  • With huge datasets, association rule mining is a potent approach for identifying intriguing correlations between variables.
  • It applies to many different industries, including market basket analysis, consumer segmentation, and fraud detection.
  • Association Rule Mining can help businesses identify cross-selling opportunities and make better decisions based on customer behaviour.
  • It can also be used for exploratory data analysis to discover patterns and relationships that may not be apparent from simple descriptive statistics.

Disadvantages of Association Rule Mining: 

  • Association Rule Mining can be computationally intensive and time-consuming, especially for large datasets.

  • The results of Association Rule Mining can be difficult to interpret and may require domain expertise to understand.
  • The quality of the results depends heavily on the quality and completeness of the input data.

  • Association Rule Mining can produce numerous spurious or irrelevant results, which may need to be filtered out manually.

Main Contents (TOPICS of Machine Learning Algorithms) 
                                                       CONTINUE TO (Bayesian networks)

Comments

Popular posts from this blog

Learn Machine Learning Algorithms

Machine Learning Algorithms with Python Code Contents of Algorithms  1.  ML Linear regression A statistical analysis technique known as "linear regression" is used to simulate the relationship between a dependent variable and one or more independent variables. 2.  ML Logistic regression  Logistic regression: A statistical method used to analyse a dataset in which there are one or more independent variables that determine an outcome. It is used to model the probability of a certain outcome, typically binary (yes/no). 3.  ML Decision trees Decision trees: A machine learning technique that uses a tree-like model of decisions and their possible consequences. It is used for classification and regression analysis, where the goal is to predict the value of a dependent variable based on the values of several independent variables. 4.  ML Random forests Random forests: A machine learning technique that uses multiple decision trees to improve the accuracy of predicti...

What is Naive Bayes algorithm

Naive Bayes Algorithm with Python Concepts of Naive Bayes Naive Bayes is a classification algorithm based on Bayes' theorem, which states that the probability of a hypothesis is updated by considering new evidence. Since it presumes that all features are independent of one another, which may not always be the case in real-world datasets, it is known as a "naive". Despite this limitation, Naive Bayes is widely used in text classification, spam filtering, and sentiment analysis. Naive Bayes Algorithm Define the problem and collect data. Choose a hypothesis class (e.g., Naive Bayes). Compute the prior probability and likelihood of each class based on the training data. Use Bayes' theorem to compute the posterior probability of each class given the input features. Classify the input by choosing the class with the highest posterior probability. Evaluate the model on a test dataset to estimate its performance. Here's an example code in Python for Naive Bayes: Python cod...

What is Linear regression

Linear regression A lgorithm Concept of Linear regression In order to model the relationship between a dependent variable and one or more independent variables, linear regression is a machine learning algorithm. The goal of linear regression is to find a linear equation that best describes the relationship between the variables. Using the values of the independent variables as a starting point, this equation can then be used to predict the value of the dependent variable. There is simply one independent variable and one dependent variable in basic linear regression. The linear equation takes the form of y = mx + b, where y is the dependent variable, x is the independent variable, m is the slope of the line, and b is the y-intercept. For example, let's say we have a dataset of the number of hours studied and the corresponding test scores of a group of students. We can use linear regression to find the relationship between the two variables and predict a student's test scor...

What is Logistic regression

Logistic Regression  Algorithm Concept of Logistic Regression A machine learning approach called logistic regression is used to model the likelihood of a binary outcome based on one or more independent factors. The goal of logistic regression is to find the best-fitting logistic function that maps the input variables to a probability output between 0 and 1. The logistic function, also known as the sigmoid function, takes the form of:   sigmoid(z) = 1 / (1 + e^-z)   where z is a linear combination of the input variables and their coefficients. For example, let's say we have a dataset of customer information, including their age and whether they have purchased a product. We can use logistic regression to predict the probability of a customer making a purchase based on their age. Logistic Regression  Algorithm: Define the problem and collect data. Choose a hypothesis class (e.g., logistic regression). Define a cost function to measure the difference between predic...

What is Convolutional and Recurrent Neural Networks

Convolutional Neural Networks and Recurrent  Neural Networks Algorithms Convolutional NN - Recurrent NN Concepts Neural networks, including deep learning architectures such as Convolutional Neural Networks (CNNs) and Recurrent Neural Networks (RNNs) The machine learning technique known as neural networks was inspired by the design and function of the human brain. They consist of interconnected nodes, or "neurons", that process and transmit information to each other to make a prediction or decision. Deep learning architectures such as Convolutional Neural Networks (CNNs) and Recurrent Neural Networks (RNNs) are advanced neural network structures that have proven to be highly effective in a variety of applications including time series analysis, natural language processing, and picture and audio recognition. Convolutional Neural Networks (CNNs) are a type of neural network that is designed to process and analyze image data. They use convolutional layers, which apply ...