I expect the NIPS 2006 workshops to be quite interesting, and recommend going for anyone interested in machine learning research. (Most or all of the workshops webpages can be found two links deep.)
Exemplar programming
There are many different abstractions for problem definition and solution. Here are a few examples:
- Functional programming: a set of functions are defined. The composed execution of these functions yields the solution.
- Linear programming: a set of constraints and a linear objective function are defined. An LP solver finds the constrained optimum.
- Quadratic programming: Like linear programming, but the language is a little more flexible (and the solution slower).
- Convex programming: like quadratic programming, but the language is more flexible (and the solutions even slower).
- Dynamic programming: a recursive definition of the problem is defined and then solved efficiently via caching tricks.
- SAT programming: A problem is specified as a satisfiability involving a conjunction of a disjunction of boolean variables. A general engine attempts to find a good satisfying assignment. For example Kautz’s blackbox planner.
These abstractions have different tradeoffs between ease of use, generality, and the effectiveness of existing solutions.
Machine learning can be thought of as exemplar programming. Exemplar programming is creating examples of a (input,output) pairs which are used by an algorithm to predict a function from input to output. Basic questions about this abstraction are:
- How easy to use is it? An honest answer here is “not very”. There are several subtle issues related to overfitting, independence, and representativeness of the samples which take significant effort to describe to an unfamiliar person. Making this abstraction easier to use via careful language design is an area where effort may pay off.
- How effectve are the exemplar programming solvers (aka learning algorithms)? There is huge variance with respect to the problem under consideration. For some problems, some learning algorithm is very effective while for others you might as well have not tried.
- How general is exemplar programming? Very general. A great many problems can be phrased as “given this, I want that”.
- How effective has examplar programming been? Increasingly effective.
Exemplar programming is a viewpoint of machine learning which (mostly) ignores statistics, prior information, and the possibility of overfitting. That’s a great deal to ignore, but there are gains as well.
- Exemplar programming creates a split between problem solution and problem formation. This is important because the problem solver can heavily optimized (for speed, scalibility, effectiveness on common problems, etc…) making the process of apply machine learning simply a matter of specifying the exemplars.
- The formation/solution split helps us focus on problem formation independent of solution. The big gains in machine learning in the last decade seem to be discovering how to apply to new areas. A significant step in any application to a new area is discovering the right way to formulate the problem.
Exemplar programming seems to be a useful viewpoint for machine learning in “big data” problems with many examples where significant prior information is lacking. When either of these conditions are not met, other viewpoints/approaches to machine learning may be more succesful.
David Pennock starts Oddhead
Incompatibilities between classical confidence intervals and learning.
Classical confidence intervals satisfy a theorem of the form: For some data sources D,
where f is some function of the distribution (such as the mean) and g is some function of the observed sample S. The constraints on D can vary between “Independent and identically distributed (IID) samples from a gaussian with an unknown mean” to “IID samples from an arbitrary distribution D“. There are even some confidence intervals which do not require IID samples.
Classical confidence intervals often confuse people. They do not say “with high probability, for my observed sample, the bounds holds”. Instead, they tell you that if you reason according to the confidence interval in the future (and the constraints on D are satisfied), then you are not often wrong. Restated, they tell you something about what a safe procedure is in a stochastic world where d is the safety parameter.
There are a number of results in theoretical machine learning which use confidence intervals. For example,
- The E3 algorithm uses confidence intervals to learn a near optimal policy for any MDP with high probability.
- Set Covering Machines minimize a confidence interval upper bound on the true error rate of a learned classifier.
- The A2 uses confidence intervals to safely deal with arbitrary noise while taking advantage of active learning.
Suppose that we want to generalize thse algorithms in a reductive style. The goal would be to train a regressor to predict the output of g(S) for new situations. For example, a good regression prediction of g(S) might allow E3 to be applied to much larger state spaces. Unfortunately, this approach seems to fail badly due to a mismatch between the semantics of learning and the semantics of a classical confidence interval.
- It’s difficult to imagine a constructive sampling mechanism. In a large state space, we may never encounter the same state twice, so we can not form meaningful examples of the form “for this state-action, the correct confidence interval is y“.
- When we think of succesful learning, we typically think of it in an l1 sense—the expected error rate over the data generating distribution is small. Confidence intervals have a much stronger meaning as we would like to apply them: with high probability, in all applications, the confidence interval holds. This mismatch appears unaddressable.
It is tempting to start plugging in other notions such as Bayesian confidence intervals or quantile regression systems. Making these approaches work at a theoretical level on even simple systems is an open problem, but there is plenty of motivation to do so.
Health of Conferences Wiki
Aaron Hertzmann points out the health of conferences wiki, which has a great deal of information about how many different conferences function.