2020-04-15 21:01:26 +02:00

145 lines
6.1 KiB
TeX
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

\documentclass[../main.tex]{subfiles}
\begin{document}
\chapter{Lecture 1 - 09-03-2020}
\section{Introduction of the course}
In this course we look at the principle behind design of Machine learning.
Not just coding but have an idea of algorithm that can work with the data.\\\\
We have to fix a mathematical framework: some statistic and mathematics.\\
\textbf{Work on ML on a higher level}\\
ML is data inference: make prediction about the future using data about the
past\\
\begin{itemize}
\item Clustering $\rightarrow$ grouping according to similarity
\item Planning $\rightarrow$ (robot to learn to interact in a certain environment)
\item Classification $\rightarrow$ (assign meaning to data) example: Spam filtering\\
I want to predict the outcome of this individual or i want to predict whether a
person click or not in a certain advertisement.
\end{itemize}
\section{Examples}
Classify data into categories:\\
\begin{itemize}
\item Medical diagnosis: data are medical records and categories are diseases
\item Document analysis: data are texts and categories are topics
\item Image analysts: data are digital images and for categories name of objects
in the image (but could be different).
\item Spam filtering: data are emails, categories are spam vs non spam.
\item Advertising prediction: data are features of web site visitors and categories
could be click/non click on banners.
\end{itemize}
Classification : \textbf{ Different from clustering }since we do not have semantically
classification (spam or not spam) $\rightarrow$ like meaning of the image.\\
I have a semantic label.
\\\\
Clustering: i want to group data with similarity function. \\\\
Planning: Learning what to do next \\\\
Clustering: Learn similarity function \\\\
Classification: Learn semantic labels meaning of data\\\\
Planning: Learn actions given state\\\\
In classification is an easier than planning task since Im able to make
prediction telling what is the semantic label that goes with data points.\\
If i can do classification i can clustering.\\
If you do planning you probably classify (since you understanding meaning in
your position) and then you can also do clustering probably.\\
We will focus on classification because many tasks are about classification.\\\\
Classify data in categories we can image a set of categories.\\
For instance the tasks:\\
predict income of a person\\
Predict tomorrow price for a stock\\
The label is a number and not an abstract thing.\\\\
We can distinguish two cases:
\begin{itemize}
\item The label set $\rightarrow$ set of possible categories for each data point. For each of
this could be finite set of abstract symbols (case of document classification,
medical diagnosis). So the task is classification.
\item Real number (no bound on how many of them). My prediction will be a real
number and is not a category. In this case we talk about a task of
regression.
\end{itemize}
Classification: task we want to give a label predefined point in abstract
categories (like YES or NO)
\\
Regression: task we want to give label to data points but this label are
numbers.\\\\
When we say prediction task: used both for classification and regression
tasks.\\
Supervised learning: Label attached to data (classification, regression)\\
Unsupervised learning: No labels attached to data (clustering)\\
In unsupervised the mathematical modelling and way algorithm are score and
can learn from mistakes is a little bit harder. Problem of clustering is harder to
model mathematically.\\
You can cast planning as supervised learning: i can show the robot which is
the right action to do in that state. But that depends on planning task is
formalised.\\
Planning is higher level of learning since include task of supervised and
unsupervised learning.\\\\
Why is this important ?\\
Algorithm has to know how to given the label.\\
In ML we want to teach the algorithm to perform prediction correctly. Initially
algorithm will make mistakes in classifying data. We want to tell algorithm that
classification was wrong and just want to perform a score. Like giving a grade
to the algorithm to understand if it did bad or really bad.
So we have mistakes!\\\\
Algorithm predicts and something makes a mistake $\rightarrow$ we can correct it.\\
Then algorithm can be more precisely.
We have to define this mistake.\\
Mistakes in case of classification:\\
\begin{itemize}
\item If category is the wrong one (in the simple case). We have a binary signal
where we know that category is wrong.
\end{itemize}
How to communicate it?\\
We can use the loss function: we can tell the algorithm whether is wrong or
not.\\\\
\bred{Loss function}: measure discrepancy between true label and predicted
label.\\
So we may assume that every datapoint has a true label.
If we have a set of topic this is the true topic that document is talking about.
It is typical in supervised learning.
\\\\
How good the algorithm did?
\\
\[\ell(y,\hat{y})\leq0 \]
were $y $ is true label and $\hat{y}$ is predicted label
\\\\
We want to build a spam filter were $0$ is not spam and $1$ is spam and that's a
Classification task:
\\\\
$
\ell(y,\hat{y} = \begin{cases} 0, & \mbox{if } \hat{y} = y
\\ 1, &
\mbox{if }\hat{y} \neq y
\end{cases}
$
\\\\
\textbf{The loss function is the “interface” between algorithm and data.}\\
So algorithm know about the data through the loss function.\\
If we give a useless loss function the algorithm will not perform good: is
important to have a good loss function.
\subsection{Spam filtering}
$Y = \{ spam, no \, spam\}$
\\
Binary classification $|Y| = 2$ \\
We have two main mistake:
\begin{itemize}
\item False positive: $y = $non spam, $\hat{y} = $ spam
\item False negative: $y = $spam, $\hat{y} = $ no spam
\end{itemize}
It is the same mistake? No if i have important email and you classify as spam
thats bad and if you show me a spam than its ok.\\
So we have to assign a different weight.\\
$$
\ell\left(y,\hat{y}\right) = \begin{cases}
2 \quad \textit{if FP}\\
1 \quad \textit{if FN}\\
0 \quad otherwise
\end{cases}
$$
\bred{We have to take more attention on positive mistake}\\
Even in binary classification, mistakes are not equal.
\end{document}