Why are neural networks so powerful?

栏目: IT技术 · 发布时间: 4年前

内容简介:It is common knowledge that neural networks are very powerful and they can be used for almost any statistical learning problem with great results. But have you thought about why is this the case? Why is this method more powerful in most scenarios than many

The universal approximation theorem

It is common knowledge that neural networks are very powerful and they can be used for almost any statistical learning problem with great results. But have you thought about why is this the case? Why is this method more powerful in most scenarios than many other algorithms?

As always with machine learning, there is a precise mathematical reason for this. Simply saying, the set of functions described by a neural network model is very large. But what does describing a set of functions mean? How can a set of functions be large? These concepts seem difficult to grasp at a first glance, however they can be properly defined, shedding a light on why certain algorithms are better than others.

Machine learning as function approximation

Let’s take an abstract viewpoint and formulate what a machine learning problem is. Suppose we have our dataset

where x ⁽ᵏ⁾ is a data point and y ⁽ᵏ⁾ is the observation related to the data point. The observation y ⁽ᵏ⁾ can be a real number or even a probability distribution (in the case of classification). The task is simply to find a function f(x) for which f(x ⁽ᵏ⁾ ) is approximately y ⁽ᵏ⁾ .

For this, we fix a parametrized family of functions in advance, and select a parameter configuration which has the best fit. For instance, linear regression uses the function family

as a parametric family of functions, with a and b as parameters.

If we suppose that there is a true underlying function g(x) which describes the relationship between x ⁽ᵏ⁾ and y ⁽ᵏ⁾, the problem can be phrased as a function approximation problem. This leads us into the beautiful albeit very technical field of approximation theory.

A primer on approximation theory

Probably you have encountered the exponential function throughout your life several times. It is defined by

Why are neural networks so powerful?

where e is the famous Euler number. This is a transcendental function , which basically means that you cannot calculate its value with finitely many additions and multiplications. However, when you punch this into a calculator, you’ll still get a value. This value is an approximation only, although it is often sufficient for our purposes. In fact, we have

Why are neural networks so powerful?

which is a polynomial, so its value can be calculated explicitly. The larger n is, the closer the approximation to the true value.

The central problem of approximation theory is to provide a mathematical framework for these problems. If you have any function g(x) and a family of functions which are easier to handle from computational aspects, your goal is to find a “simple” function which is close enough to g . In essence, approximation theory searches answers to three core questions.

  • What is “close enough”?
  • Which family of functions can (or should) I use to approximate?
  • From a given approximating function family, which exact function is the one which will fit the best?

Don’t worry if these sound a little bit abstract, because next we are going to look into the special case of neural networks.

Neural networks as function approximators

So, let’s reiterate the problem. We have a function g(x) which describes the relation between data and the observation. This is not known exactly, only for some values

where g(x ⁽ᵏ⁾ ) = y ⁽ᵏ⁾. Our job is to find an f(x) which

  • generalizes the knowledge from the data,
  • and computationally feasible.

If we assume that all of our data points are in the subset X , that is

holds, we would like a function where the quantity supremum norm

is as small as possible. You can imagine this quantity by plotting the these functions, coloring the area enclosed by the graph and calculating the maximum spread said area along the y axis.

Why are neural networks so powerful?

Even though we cannot evaluate g(x) for arbitrary values, we should always aim to approximate it in this broader sense, instead of requiring f(x) to fit only at the known data points xₖ .

So, the problem is given. The question is, which set of functions should we use to approximate with?

Neural networks with a single hidden layer

Mathematically speaking, a neural network with a single hidden layer is defined by

Why are neural networks so powerful?

where φ is a nonlinear function (called activation function) such as the sigmoid function

Why are neural networks so powerful?

and

The value x corresponds to the data, while wᵢ , bᵢ and vᵢ are the parameters. Is the function family

enough to approximate any reasonable function? The answer is a resounding yes!

The universal approximation theorem

Why are neural networks so powerful?
The universal approximation theorem in its full glory :) Source: Cybenko, G. (1989) “Approximations by superpositions of sigmoidal functions” , Mathematics of Control, Signals, and Systems , 2(4), 303–314.

A famous result from 1989, called universal approximation theorem , states that as long as the activation function is sigmoid-like and the function to be approximated is continuous, a neural network with a single hidden layer can approximate it as precisely as you want. (Or learn it in machine learning terminology.)

Don’t worry if the exact theorem seems difficult, I will explain the whole process in detail. (In fact, I deliberately skipped concepts like dense to make the explanation clearer, albeit less precise.)

Step one.Suppose that the function to learn is g(x), which is continuous. Let’s fix a small number ε and draw an ε wide stripe around the function. The smaller ε is, the better the result will be.

Why are neural networks so powerful?

Step two.(The hard part.) Find a function of the form

Why are neural networks so powerful?

which is completely inside the stripe. The theorem guarantees the existence of such F(x), hence this family of functions are called universal approximators . This is the awesome thing about neural networks, giving them their real power.

Why are neural networks so powerful?

There are several caveats however. For instance, the theorem doesn’t say anything about N, which is the number of neurons in the hidden layer. For small ε , this can be very large, which is bad from a computational perspective. We want to calculate predictions as fast as possible, and calculating the sum of ten billion terms is definitely not fun.

The second issue is that even though the theorem guarantees the existence of a good approximating function, it doesn’t tell us how to find it. Although this might be surprising, this is very typical in mathematics. We have extremely powerful tools to reason about the existence of certain objects, without being able to explicitly construct them. (There is a mathematical school called constructivism , which rejects purely existence proofs such as the original proof of the universal approximation theorem. However, the problem is very deep-rooted. Without accepting nonconstructive proofs, we wouldn’t even be able to talk about functions on infinite sets.)

However, the biggest issue is that in practice, we never know the underlying function completely, we only know what we have observed:

There is an infinite number of possible configurations which could fit our data arbitrarily well. Most of them generalizes horribly to new data. You surely know this phenomenon: it is the dreaded overfitting.

With great power comes great responsibility

So, here is the thing. If you have N observations, then you can find a polynomial of degree N-1 which perfectly fits your observations. This is not a big deal, you can even write down this polynomial explicitly by using Lagrange interpolation . However, it won’t generalize to any new data, in fact it will be awful. The figure below demonstrates what happens when we try to fit a polynomial of large degree to a small dataset.

Why are neural networks so powerful?

The very same phenomenon holds for neural networks. This is a huge problem, and the universal approximation theorem gives us absolutely zero hints on how to overcome this.

In general, the more expressive a function family is, the more it is prone to overfitting. With great power comes great responsibility. This is called the bias-variance tradeoff . For neural networks, there are lots of approaches to mitigate this, from L1 regularization of weights to dropoff layers. However, since neural networks are so expressive, this problem is always looming in the background and requires constant attention.

Beyond the universal approximation theorem

As I have mentioned, the theorem gives no tools to find a parameter configuration for our neural network. From a practical standpoint, this is almost as important as the universal approximating property. For decades, neural networks were out of favor because the lack of a computationally effective method to fit them to the data. There were two essential advances, which made their use feasible: backpropagation and general purpose GPU-s. With these two under your belt, training huge neural networks is a breeze. You can train state of the art models using your notebook without even breaking a sweat. We have come so far since the universal approximation theorem!

Usually, this is the starting point of a standard deep learning course. Due to its mathematical complexity, the theoretical foundations of neural network are not covered. However, the universal approximation theorem (and the tools used in its proof) give a very deep insight into why neural networks are so powerful, and it even lays the groundwork for engineering novel architectures. After all, who said that we are only allowed to combine sigmoids and linear functions?


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

妙趣横生的算法

妙趣横生的算法

杨峰 / 清华大学出版社 / 2010-4 / 49.00元

《妙趣横生的算法(C语言实现)》理论与实践相结合,旨在帮助读者理解算法,并提高C语言编程能力,培养读者的编程兴趣,并巩固已有的C语言知识。全书分为2个部分共10章,内容涵盖了编程必备的基础知识(如数据结构、常用算法等),编程实例介绍,常见算法和数据结构面试题等。《妙趣横生的算法(C语言实现)》最大的特色在于实例丰富,题材新颖有趣,实用性强,理论寓于实践之中。通过《妙趣横生的算法(C语言实现)》的学......一起来看看 《妙趣横生的算法》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具