Presentation is loading. Please wait.

Presentation is loading. Please wait.

Machine learning Image source: https://www.coursera.org/course/mlhttps://www.coursera.org/course/ml.

Similar presentations


Presentation on theme: "Machine learning Image source: https://www.coursera.org/course/mlhttps://www.coursera.org/course/ml."— Presentation transcript:

1 Machine learning Image source: https://www.coursera.org/course/mlhttps://www.coursera.org/course/ml

2 Machine learning Definition –Getting a computer to do well on a task without explicitly programming it –Improving performance on a task based on experience

3 Learning for episodic tasks We have just looked at learning in sequential environments Now let’s consider the “easier” problem of episodic environments –The agent gets a series of unrelated problem instances and has to make some decision or inference about each of them –In this case, “experience” comes in the form of training data

4 Example: Image classification apple pear tomato cow dog horse inputdesired output

5 Training data apple pear tomato cow dog horse

6 Example 2: Seismic data classification Body wave magnitude Surface wave magnitude Nuclear explosions Earthquakes

7 Example 3: Spam filter

8 Example 4: Sentiment analysis http://gigaom.com/2013/10/03/stanford-researchers-to-open-source-model-they-say-has-nailed-sentiment-analysis/ http://nlp.stanford.edu:8080/sentiment/rntnDemo.html

9 The basic machine learning framework y = f(x) Learning: given a training set of labeled examples {(x 1,y 1 ), …, (x N,y N )}, estimate the parameters of the prediction function f Inference: apply f to a never before seen test example x and output the predicted value y = f(x) The key challenge is generalization outputclassification function input

10 Prediction Learning and inference pipeline Training Labels Training Samples Training Learning Features Inference Test Sample Learned model

11 Naïve Bayes classifier A single dimension or attribute of x

12 Decision tree classifier Example problem: decide whether to wait for a table at a restaurant, based on the following attributes: 1.Alternate: is there an alternative restaurant nearby? 2.Bar: is there a comfortable bar area to wait in? 3.Fri/Sat: is today Friday or Saturday? 4.Hungry: are we hungry? 5.Patrons: number of people in the restaurant (None, Some, Full) 6.Price: price range ($, $$, $$$) 7.Raining: is it raining outside? 8.Reservation: have we made a reservation? 9.Type: kind of restaurant (French, Italian, Thai, Burger) 10.WaitEstimate: estimated waiting time (0-10, 10-30, 30-60, >60)

13 Decision tree classifier

14

15 Nearest neighbor classifier f(x) = label of the training example nearest to x All we need is a distance function for our inputs No training required! Test example Training examples from class 1 Training examples from class 2

16 K-nearest neighbor classifier For a new point, find the k closest points from training data Vote for class label with labels of the k points k = 5

17 Linear classifier Find a linear function to separate the classes f(x) = sgn(w 1 x 1 + w 2 x 2 + … + w D x D ) = sgn(w  x)

18 NN vs. linear classifiers NN pros: +Simple to implement +Decision boundaries not necessarily linear +Works for any number of classes +Nonparametric method NN cons: –Need good distance function –Slow at test time Linear pros: +Low-dimensional parametric representation +Very fast at test time Linear cons: –Works for two classes –How to train the linear function? –What if data is not linearly separable?

19 Perceptron x1x1 x2x2 xDxD w1w1 w2w2 w3w3 x3x3 wDwD Input Weights...... Output: sgn(w  x + b) Can incorporate bias as component of the weight vector by always including a feature with value set to 1

20 Loose inspiration: Human neurons

21

22 Linear separability

23 Perceptron training algorithm Initialize weights Cycle through training examples in multiple passes (epochs) For each training example: –If classified correctly, do nothing –If classified incorrectly, update weights

24 Perceptron update rule For each training instance x with label y: –Classify with current weights: y’ = sgn(w  x) –Update weights: w  w + α(y-y’)x –α is a learning rate that should decay as a function of epoch t, e.g., 1000/(1000+t) –What happens if y’ is correct? –Otherwise, consider what happens to individual weights w i  w i + α(y-y’)x i If y = 1 and y’ = -1, w i will be increased if x i is positive or decreased if x i is negative  w  x will get bigger If y = -1 and y’ = 1, w i will be decreased if x i is positive or increased if x i is negative  w  x will get smaller

25 Convergence of perceptron update rule Linearly separable data: converges to a perfect solution Non-separable data: converges to a minimum-error solution assuming learning rate decays as O(1/t) and examples are presented in random sequence

26 Implementation details Bias (add feature dimension with value fixed to 1) vs. no bias Initialization of weights: all zeros vs. random Learning rate decay function Number of epochs (passes through the training data) Order of cycling through training examples

27 Multi-class perceptrons Need to keep a weight vector w c for each class c Decision rule: c = argmax c w c  x Update rule: suppose example from class c gets misclassified as c’ –Update for c: w c  w c + α x –Update for c’: w c’  w c’ – α x

28 Differentiable perceptron x1x1 x2x2 xdxd w1w1 w2w2 w3w3 x3x3 wdwd Sigmoid function: Input Weights...... Output:  (w  x + b)

29 Update rule for differentiable perceptron Define total classification error or loss on the training set: Update weights by gradient descent: w1w1 w2w2

30 Update rule for differentiable perceptron Define total classification error or loss on the training set: Update weights by gradient descent: For a single training point, the update is:

31 Update rule for differentiable perceptron For a single training point, the update is: Compare with update rule with non-differentiable perceptron:

32 Multi-Layer Neural Network Can learn nonlinear functions Training: find network weights to minimize the error between true and estimated labels of training examples: Minimization can be done by gradient descent provided f is differentiable –This training method is called back-propagation

33 Deep convolutional neural networks Zeiler, M., and Fergus, R. Visualizing and Understanding Convolutional Neural Networks, tech report, 2013. Krizhevsky, A., Sutskever, I., and Hinton, G.E. ImageNet classication with deep convolutional neural networks. NIPS, 2012.


Download ppt "Machine learning Image source: https://www.coursera.org/course/mlhttps://www.coursera.org/course/ml."

Similar presentations


Ads by Google