Algorithms for NLP. Classifica(on III. Taylor Berg- Kirkpatrick CMU Slides: Dan Klein UC Berkeley

Similar documents
Algorithms for NLP. Classifica(on III. Taylor Berg- Kirkpatrick CMU Slides: Dan Klein UC Berkeley

Algorithms for NLP. Classification II. Taylor Berg-Kirkpatrick CMU Slides: Dan Klein UC Berkeley

Natural Language Processing. Classification. Margin. Linear Models: Perceptron. Issues with Perceptrons. Problems with Perceptrons.

Natural Language Processing. Classification. Features. Some Definitions. Classification. Feature Vectors. Classification I. Dan Klein UC Berkeley

Classification. Statistical NLP Spring Example: Text Classification. Some Definitions. Block Feature Vectors.

Statistical NLP Spring A Discriminative Approach

CSE546: SVMs, Dual Formula5on, and Kernels Winter 2012

CS 188: Artificial Intelligence Spring Announcements

CS 188: Artificial Intelligence Spring Announcements

Announcements. CS 188: Artificial Intelligence Spring Classification. Today. Classification overview. Case-Based Reasoning

COMP 562: Introduction to Machine Learning

CS6375: Machine Learning Gautam Kunapuli. Support Vector Machines

Structured Prediction: A Large Margin Approach. Ben Taskar University of Pennsylvania

CS 6140: Machine Learning Spring What We Learned Last Week 2/26/16

Support Vector Machines: Maximum Margin Classifiers

Support vector machines Lecture 4

Announcements - Homework

CSC 411 Lecture 17: Support Vector Machine

Probabilistic Graphical Models

Support Vector Machine (SVM) and Kernel Methods

Support Vector Machine (SVM) and Kernel Methods

Support Vector Machine (SVM) & Kernel CE-717: Machine Learning Sharif University of Technology. M. Soleymani Fall 2012

Introduction to Logistic Regression and Support Vector Machine

Discrimina)ve Latent Variable Models. SPFLODD November 15, 2011

Max Margin-Classifier

Lecture Support Vector Machine (SVM) Classifiers

Support Vector Machines

Linear & nonlinear classifiers

Jeff Howbert Introduction to Machine Learning Winter

SVM optimization and Kernel methods

Machine Learning for Structured Prediction

18.9 SUPPORT VECTOR MACHINES

Least Mean Squares Regression. Machine Learning Fall 2017

MIRA, SVM, k-nn. Lirong Xia

Lecture 9: Large Margin Classifiers. Linear Support Vector Machines

Support Vector Machine (SVM) and Kernel Methods

Support Vector Machines

Kernelized Perceptron Support Vector Machines

Support Vector Machine (continued)

L5 Support Vector Classification

Founda'ons of Large- Scale Mul'media Informa'on Management and Retrieval. Lecture #3 Machine Learning. Edward Chang

Support Vector Machines.

Statistical Machine Learning from Data

Kernel Machines. Pradeep Ravikumar Co-instructor: Manuela Veloso. Machine Learning

Bellman s Curse of Dimensionality

Machine Learning for NLP

Machine Learning for NLP

COMP 652: Machine Learning. Lecture 12. COMP Lecture 12 1 / 37

Kernel Methods and Support Vector Machines

Linear classifiers selecting hyperplane maximizing separation margin between classes (large margin classifiers)

Methodological Foundations of Biomedical Informatics (BMSC-GA 4449) Optimization

Algorithms for NLP. Language Modeling III. Taylor Berg-Kirkpatrick CMU Slides: Dan Klein UC Berkeley

Support Vector Machine

Linear smoother. ŷ = S y. where s ij = s ij (x) e.g. s ij = diag(l i (x))

Dan Roth 461C, 3401 Walnut

EE613 Machine Learning for Engineers. Kernel methods Support Vector Machines. jean-marc odobez 2015

Natural Language Processing with Deep Learning. CS224N/Ling284

Support Vector Machines and Kernel Methods

Discriminative Models

Support Vector Machines

Support Vector Machines

Introduction to Support Vector Machines

Mark your answers ON THE EXAM ITSELF. If you are not sure of your answer you may wish to provide a brief explanation.

Introduction to SVM and RVM

UNIVERSITY of PENNSYLVANIA CIS 520: Machine Learning Final, Fall 2013

Statistical Pattern Recognition

Learning Theory. Piyush Rai. CS5350/6350: Machine Learning. September 27, (CS5350/6350) Learning Theory September 27, / 14

COMP 875 Announcements

PAC-learning, VC Dimension and Margin-based Bounds

Machine Learning Practice Page 2 of 2 10/28/13

Linear & nonlinear classifiers

Machine Learning 4771

Machine Learning and Data Mining. Support Vector Machines. Kalev Kask

UNIVERSITY of PENNSYLVANIA CIS 520: Machine Learning Final, Fall 2014

CS 6140: Machine Learning Spring What We Learned Last Week. Survey 2/26/16. VS. Model

Machine Learning A Geometric Approach

CS 6140: Machine Learning Spring 2016

Discriminative Models

Support Vector Machines. CSE 6363 Machine Learning Vassilis Athitsos Computer Science and Engineering Department University of Texas at Arlington

Machine Learning Support Vector Machines. Prof. Matteo Matteucci

Topics we covered. Machine Learning. Statistics. Optimization. Systems! Basics of probability Tail bounds Density Estimation Exponential Families

Structured Prediction

CSE 473: Ar+ficial Intelligence. Hidden Markov Models. Bayes Nets. Two random variable at each +me step Hidden state, X i Observa+on, E i

Nonlinear Classification

SVMs, Duality and the Kernel Trick

Kernel Methods. Barnabás Póczos

Support Vector Machines. Machine Learning Fall 2017

Kernels. Machine Learning CSE446 Carlos Guestrin University of Washington. October 28, Carlos Guestrin

Probability and Structure in Natural Language Processing

Lecture 10: A brief introduction to Support Vector Machine

CS 188: Artificial Intelligence Fall 2008

General Naïve Bayes. CS 188: Artificial Intelligence Fall Example: Overfitting. Example: OCR. Example: Spam Filtering. Example: Spam Filtering

CS 188: Artificial Intelligence. Outline

(Kernels +) Support Vector Machines

Boos$ng Can we make dumb learners smart?

Warm up: risk prediction with logistic regression

Day 3: Classification, logistic regression

CSE 473: Ar+ficial Intelligence

Indirect Rule Learning: Support Vector Machines. Donglin Zeng, Department of Biostatistics, University of North Carolina

Optimization and Gradient Descent

Transcription:

Algorithms for NLP Classifica(on III Taylor Berg- Kirkpatrick CMU Slides: Dan Klein UC Berkeley

Objec(ve Func(ons What do we want from our weights? Depends! So far: minimize (training) errors: This is the zero- one loss Discon(nuous, minimizing is NP- complete Not really what we want anyway Maximum entropy and SVMs have other objec(ves related to zero- one loss

Linear Separators Which of these linear separators is op(mal? 3

Classifica(on Margin (Binary) Distance of x i to separator is its margin, m i Examples closest to the hyperplane are support vectors Margin γ of the separator is the minimum m γ m

Classifica(on Margin For each example x i and possible mistaken candidate y, we avoid that mistake by a margin m i (y) (with zero- one loss) Margin γ of the en(re separator is the minimum m It is also the largest γ for which the following constraints hold

Maximum Margin Separable SVMs: find the max- margin w Can s(ck this into Matlab and (slowly) get an SVM Won t work (well) if non- separable

Why Max Margin? Why do this? Various arguments: Solu(on depends only on the boundary cases, or support vectors (but remember how this diagram is broken!) Solu(on robust to movement of support vectors Sparse solu(ons (features not in support vectors get zero weight) Generaliza(on bound arguments Works well in prac(ce for many problems Support vectors

Max Margin / Small Norm Reformula(on: find the smallest w which separates data Remember this condition? γ scales linearly in w, so if w isn t constrained, we can take any separa(ng w and scale up our margin Instead of fixing the scale of w, we can fix γ = 1

So` Margin Classifica(on What if the training set is not linearly separable? Slack variables ξ i can be added to allow misclassifica(on of difficult or noisy examples, resul(ng in a so1 margin classifier ξ i ξ i

Maximum Margin Note: exist other choices of how to penalize slacks! Non- separable SVMs Add slack to the constraints Make objec(ve pay (linearly) for slack: C is called the capacity of the SVM the smoothing knob Learning: Can s(ll s(ck this into Matlab if you want Constrained op(miza(on is hard; becer methods! We ll come back to this later

Maximum Margin

Likelihood

Linear Models: Maximum Entropy Maximum entropy (logis(c regression) Use the scores as probabili(es: Maximize the (log) condi(onal likelihood of training data Make positive Normalize

Maximum Entropy II Mo(va(on for maximum entropy: Connec(on to maximum entropy principle (sort of) Might want to do a good job of being uncertain on noisy cases in prac(ce, though, posteriors are precy peaked Regulariza(on (smoothing)

Maximum Entropy

Loss Comparison

Log- Loss If we view maxent as a minimiza(on problem: This minimizes the log loss on each example One view: log loss is an upper bound on zero- one loss

Remember SVMs We had a constrained minimiza(on but we can solve for ξ i Giving

Hinge Loss Plot really only right in binary case Consider the per-instance objective: This is called the hinge loss Unlike maxent / log loss, you stop gaining objec(ve once the true label wins by enough You can start from here and derive the SVM objec(ve Can solve directly with sub- gradient decent (e.g. Pegasos: Shalev- Shwartz et al 07)

Max vs So`- Max Margin SVMs: Maxent: You can make this zero but not this one Very similar! Both try to make the true score becer than a func(on of the other scores The SVM tries to beat the augmented runner- up The Maxent classifier tries to beat the so`- max

Loss Func(ons: Comparison Zero- One Loss Hinge Log

Separators: Comparison

Condi(onal vs Joint Likelihood

Example: Sensors Reality Raining Sunny P(+,+,r) = 3/8 P(-,-,r) = 1/8 P(+,+,s) = 1/8 P(-,-,s) = 3/8 NB Model Raining? M1 M2 NB FACTORS: P(s) = 1/2 P(+ s) = 1/4 P(+ r) = 3/4 PREDICTIONS: n n P(r,+,+) = (½)(¾)(¾) P(s,+,+) = (½)(¼)(¼) n P(r +,+) = 9/10 n P(s +,+) = 1/10

Example: Stoplights Reality Lights Working Lights Broken P(g,r,w) = 3/7 P(r,g,w) = 3/7 P(r,r,b) = 1/7 NB Model Working? NS EW NB FACTORS: P(w) = 6/7 P(r w) = 1/2 P(g w) = 1/2 n P(b) = 1/7 n P(r b) = 1 n P(g b) = 0

Example: Stoplights What does the model say when both lights are red? P(b,r,r) = (1/7)(1)(1) = 1/7 = 4/28 P(w,r,r) = (6/7)(1/2)(1/2) = 6/28 = 6/28 P(w r,r) = 6/10! We ll guess that (r,r) indicates lights are working! Imagine if P(b) were boosted higher, to 1/2: P(b,r,r) = (1/2)(1)(1) = 1/2 = 4/8 P(w,r,r) = (1/2)(1/2)(1/2) = 1/8 = 1/8 P(w r,r) = 1/5! Changing the parameters bought accuracy at the expense of data likelihood

Duals and Kernels

Nearest- Neighbor Classifica(on Nearest neighbor, e.g. for digits: Take new example Compare to all training examples Assign based on closest example Encoding: image is vector of intensi(es: Similarity func(on: E.g. dot product of two images vectors

Non- Parametric Classifica(on Non- parametric: more examples means (poten(ally) more complex classifiers How about K- Nearest Neighbor? We can be a licle more sophis(cated, averaging several neighbors But, it s s(ll not really error- driven learning The magic is in the distance func(on Overall: we can exploit rich similarity func(ons, but not objec(ve- driven learning

A Tale of Two Approaches Nearest neighbor- like approaches Work with data through similarity func(ons No explicit learning Linear approaches Explicit training to reduce empirical error Represent data through features Kernelized linear models Explicit training, but driven by similarity! Flexible, powerful, very very slow

The Perceptron, Again Start with zero weights Visit training instances one by one Try to classify If correct, no change! If wrong: adjust weights mistake vectors

Perceptron Weights What is the final value of w? Can it be an arbitrary real vector? No! It s built by adding up feature vectors (mistake vectors). mistake counts Can reconstruct weight vectors (the primal representa(on) from update counts (the dual representa(on) for each i

Dual Perceptron Track mistake counts rather than weights Start with zero counts (α) For each instance x Try to classify If correct, no change! If wrong: raise the mistake count for this example and predic(on

Dual / Kernelized Perceptron How to classify an example x? If someone tells us the value of K for each pair of candidates, never need to build the weight vectors

Issues with Dual Perceptron Problem: to score each candidate, we may have to compare to all training candidates Very, very slow compared to primal dot product! One bright spot: for perceptron, only need to consider candidates we made mistakes on during training Slightly becer for SVMs where the alphas are (in theory) sparse This problem is serious: fully dual methods (including kernel methods) tend to be extraordinarily slow Of course, we can (so far) also accumulate our weights as we go...

Kernels: Who Cares? So far: a very strange way of doing a very simple calcula(on Kernel trick : we can subs(tute any* similarity func(on in place of the dot product Lets us learn new kinds of hypotheses * Fine print: if your kernel doesn t satisfy certain technical requirements, lots of proofs break. E.g. convergence, mistake bounds. In practice, illegal kernels sometimes work (but not always).

Some Kernels Kernels implicitly map original vectors to higher dimensional spaces, take the dot product there, and hand the result back Linear kernel: Quadra(c kernel: RBF: infinite dimensional representa(on Discrete kernels: e.g. string kernels, tree kernels

Tree Kernels [Collins and Duffy 01] Want to compute number of common subtrees between T, T Add up counts of all pairs of nodes n, n Base: if n, n have different root produc(ons, or are depth 0: Base: if n, n are share the same root produc(on:

Dual Formula(on for SVMs We want to op(mize: (separable case for now) This is hard because of the constraints Solu(on: method of Lagrange mul(pliers The Lagrangian representa(on of this problem is: All we ve done is express the constraints as an adversary which leaves our objec(ve alone if we obey the constraints but ruins our objec(ve if we violate any of them

Lagrange Duality We start out with a constrained op(miza(on problem: We form the Lagrangian: This is useful because the constrained solu(on is a saddle point of Λ (this is a general property): Primal problem in w Dual problem in α

Dual Formula(on II Duality tells us that has the same value as This is useful because if we think of the α s as constants, we have an unconstrained min in w that we can solve analy(cally. Then we end up with an op(miza(on over α instead of w (easier).

Dual Formula(on III Minimize the Lagrangian for fixed α s: So we have the Lagrangian as a func(on of only α s:

Back to Learning SVMs We want to find α which minimize This is a quadra(c program: Can be solved with general QP or convex op(mizers But they don t scale well to large problems Cf. maxent models work fine with general op(mizers (e.g. CG, L- BFGS) How would a special purpose op(mizer work?

Coordinate Descent I Despite all the mess, Z is just a quadra(c in each α i (y) Coordinate descent: op(mize one variable at a (me 0 0 If the unconstrained argmin on a coordinate is nega(ve, just clip to zero

Coordinate Descent II Ordinarily, trea(ng coordinates independently is a bad idea, but here the update is very fast and simple So we visit each axis many (mes, but each visit is quick This approach works fine for the separable case For the non- separable case, we just gain a simplex constraint and so we need slightly more complex methods (SMO, exponen(ated gradient)

What are the Alphas? Each candidate corresponds to a primal constraint In the solu(on, an α i (y) will be: Zero if that constraint is inac(ve Posi(ve if that constrain is ac(ve i.e. posi(ve on the support vectors Support vectors Support vectors contribute to weights:

Structure

Handwri(ng recogni(on x y brace Sequential structure [Slides: Taskar and Klein 05]

CFG Parsing x y The screen was a sea of red Recursive structure

Bilingual Word Alignment x What is the anticipated cost of collecting fees under the new proposal? En vertu de nouvelle propositions, quel est le côut prévu de perception de les droits? What is the anticipated cost of collecting fees under the new proposal? Combinatorial structure y En vertu de les nouvelle propositions, quel est le côut prévu de perception de le droits?

Structured Models space of feasible outputs Assump(on: Score is a sum of local part scores Parts = nodes, edges, produc(ons

CFG Parsing #(NP DT NN) #(PP IN NP) #(NN sea )

Bilingual word alignment What is the anticipated cost of collecting fees under the new proposal? j k En vertu de les nouvelle propositions, quel est le côut prévu de perception de le droits? associa(on posi(on orthography

Input Op(on 0: Reranking N-Best List (e.g. n=100) [e.g. Charniak and Johnson 05] Output x = The screen was a sea of red. Baseline Parser Non-Structured Classification

Reranking Advantages: Directly reduce to non- structured case No locality restric(on on features Disadvantages: Stuck with errors of baseline parser Baseline system must produce n- best lists But, feedback is possible [McCloskey, Charniak, Johnson 2006]

Efficient Primal Decoding Common case: you have a black box which computes at least approximately, and you want to learn w Many learning methods require more (expecta(ons, dual representa(ons, k- best lists), but the most commonly used op(ons do not Easiest op(on is the structured perceptron [Collins 01] Structure enters here in that the search for the best y is typically a combinatorial algorithm (dynamic programming, matchings, ILPs, A* ) Predic(on is structured, learning update is not

Structured Margin Remember the margin objec(ve: This is s(ll defined, but lots of constraints

Full Margin: OCR We want: brace Equivalently: brace aaaaa brace aaaab a lot! brace zzzzz

Parsing example We want: It was red S A B C D Equivalently: It was red S A B C D It was red S A B D F It was red S A B C D It was red S A B C D a lot! It was red S A B C D It was red S E F G H

Alignment example We want: What is the Quel est le 1 2 3 1 2 3 Equivalently: What is the Quel est le 1 2 3 1 2 3 What is the Quel est le 1 2 3 1 2 3 What is the Quel est le 1 2 3 1 2 3 What is the Quel est le 1 2 3 1 2 3 a lot! What is the Quel est le 1 2 3 1 2 3 What is the Quel est le 1 2 3 1 2 3

Cuyng Plane A constraint induc(on method [Joachims et al 09] Exploits that the number of constraints you actually need per instance is typically very small Requires (loss- augmented) primal- decode only Repeat: Find the most violated constraint for an instance: Add this constraint and resolve the (non- structured) QP (e.g. with SMO or other QP solver)

Cuyng Plane Some issues: Can easily spend too much (me solving QPs Doesn t exploit shared constraint structure In prac(ce, works precy well; fast like perceptron/mira, more stable, no averaging

M3Ns Another op(on: express all constraints in a packed form Maximum margin Markov networks [Taskar et al 03] Integrates solu(on structure deeply into the problem structure Steps Express inference over constraints as an LP Use duality to transform minimax formula(on into min- min Constraints factor in the dual along the same structure as the primal; alphas essen(ally act as a dual distribu(on Various op(miza(on possibili(es in the dual

Likelihood, Structured Structure needed to compute: Log- normalizer Expected feature counts E.g. if a feature is an indicator of DT- NN then we need to compute posterior marginals P(DT- NN sentence) for each posi(on and sum Also works with latent variables (more later)