24.07.2016 Views

www.allitebooks.com

Learning%20Data%20Mining%20with%20Python

Learning%20Data%20Mining%20with%20Python

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

Getting Started with Data Mining<br />

A simple classification example<br />

In the affinity analysis example, we looked for correlations between different<br />

variables in our dataset. In classification, we instead have a single variable that we<br />

are interested in and that we call the class (also called the target). If, in the previous<br />

example, we were interested in how to make people buy more apples, we could set<br />

that variable to be the class and look for classification rules that obtain that goal.<br />

We would then look only for rules that relate to that goal.<br />

What is classification?<br />

Classification is one of the largest uses of data mining, both in practical use and in<br />

research. As before, we have a set of samples that represents objects or things we<br />

are interested in classifying. We also have a new array, the class values. These class<br />

values give us a categorization of the samples. Some examples are as follows:<br />

• Determining the species of a plant by looking at its measurements. The class<br />

value here would be Which species is this?.<br />

• Determining if an image contains a dog. The class would be Is there a dog in<br />

this image?.<br />

• Determining if a patient has cancer based on the test results. The class would<br />

be Does this patient have cancer?.<br />

While many of the examples above are binary (yes/no) questions, they do not have<br />

to be, as in the case of plant species classification in this section.<br />

The goal of classification applications is to train a model on a set of samples with<br />

known classes, and then apply that model to new unseen samples with unknown<br />

classes. For example, we want to train a spam classifier on my past e-mails, which<br />

I have labeled as spam or not spam. I then want to use that classifier to determine<br />

whether my next email is spam, without me needing to classify it myself.<br />

Loading and preparing the dataset<br />

The dataset we are going to use for this example is the famous Iris database of plant<br />

classification. In this dataset, we have 150 plant samples and four measurements of<br />

each: sepal length, sepal width, petal length, and petal width (all in centimeters).<br />

This classic dataset (first used in 1936!) is one of the classic datasets for data mining.<br />

There are three classes: Iris Setosa, Iris Versicolour, and Iris Virginica. The aim is to<br />

determine which type of plant a sample is, by examining its measurements.<br />

[ 16 ]

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!