Skip to main content

My Brief Adventures in Neural Networks: Merely an interpolation system which cannot reliably extrapolate?

I used to think neural networks were a reasonably good technology, until I decided to try setting up a neural network myself. After some experimentation with neural networks, I dramatically reversed my stance. I now believe neural networks should not be in charge of any decisions such that could have life-or-death impact. Find out why below.

Disclosure: These are my personal thoughts about neural networks based on my limited experience with them. I do not claim to be an expert in neural networks.

First I'm going to propose a definition for a neural network:

An interpolation system whose behavior becomes undefined when extrapolating beyond its training data.

In simple language, "undefined" may be thought of as "random by human standards". OK, how did this definition come about? It all started when I desired to make a system for classifying fonts a year or two ago.

Even Google Fonts had at the time very few parameters for manually finding suitable fonts. For picking a font for a website, for example, the current font categories that most font sites use (serif, sans-serif, handwriting, display) were to me almost useless in finding a suitable font quickly. While Google Fonts at the time included a few additional parameters such as the width/narrowness of the font, even they had very little more to offer than that. This resulted in a lot of man-hours spent in selecting a suitable font. I desired to be able to ask a neural network for the types of qualitative features I was seeking in a font, and have it name a suitable font for me.

To this end, my first and pilot goal was to set up a neural network that could successfully distinguish between the simplest of cases: serif and sans-serif fonts. Then I'd move on to other font parameters.

But I'd never worked with neural networks before! So before setting up a network that could handle font images, I wanted to make sure I could set up a simple neural network in general. For my experiments, I used the excellent open-source Fast Artificial Neural Network Library, also known as FANN and designed for ease of use, installed on my local Linux computer. I purposely set up to be a simple experiment: I wasn't setting up the type of neural network which adapts itself in an ongoing manner after its training; I set up a network that learns from a training set of data and then does not change itself further after the training.

First, I set up training data where the input was a number x, and the desired output was x/2 + 1. I trained this on many (but not all) numbers from 1 to 100. Most humans would be able to spot this formula pretty easily.

When querying my neural network for a number that was not in the training data, but was within the 1 to 100 range, it gave me a number that was not exact but somewhat reasonable. It wasn't too far away from the expected number. However, when I queried what the answer would be when I put an input of 50,000 the answer shocked and scared me. It was not even close to the correct answer. 

So with the simple formula given, the neural network was able to interpolate reasonably well within the parameters of the training data. However, when outside the limits of the training data, the behavior seemed random.

You may be pointing out right now that this was a small training set, the experiment was tiny, and so on. All of that is true. But my point is, a human would have been able to spot the relationship of inputs and outputs and extrapolated more accurately when asked to give an answer for 50,000.

For those who are wondering what happened with the rest of the project, I went on to serif and sans-serif font images and the network was able to tell the difference. I started on some of the other parameters, however, beyond serif/sans-serif it became much more time-consuming (of my own time, not just of processor time) than I had anticipated. I therefore decided to abandon the project. But this experience left me alarmed at what sorts of decisions we as humans are entrusting to neural networks. 

This experience also made me think more deeply about neural networks in general, and how they "think" completely differently to humans.

Let's take an example where a neural network has been tested to be 99% accurate. That sounds pretty good, doesn't it? Would you be comfortable with a 99% accurate car driving you? Let's take a quick look at that other 1%. As humans, we like to think that the 1% was wrong because it was "a little bit off the target", which is in reality what we as humans are likely to arrive at ourselves when we get it wrong. That's not the case with neural networks. The 1% error from a machine may be very, very far from correct. It can be so far incorrect as to appear almost random by human standards. 

This magnitude of error might not be a problem if you're asking the neural network to tag people in your photos. If it gets some of the people wildly wrong, so what? But it will be a problem if you're asking it to make self-driving car decisions.

Let's look at a more concrete example: a stop sign covered in snow.

  • Example human reactions: A stop sign, a yield sign, a road sign of some sort
  • Example neural network reactions: A red and white blob, a fire truck.

These are theoretical examples. But they're not far away from reality - an article from Ars Technica in 2017 shows that hacking street signs with camouflaged stickers could confuse self-driving cars.

So you could see how by human standards, a human looking at a stop sign covered in snow or in camouflaged stickers might get it wrong by a tiny bit, but a neural network could get it wrong by a long way.

Do you want to use a neural network for anything that could have a life-or-death impact now? You might point out that the solution is simple: just expand the training sets to include more edge cases, such as stop signs covered with snow. This way, the neural network will actually recognize a stop sign covered with snow as a stop sign. In other words, you're expanding out the training parameters to ensure that a particular case is now going to be interpolated instead of extrapolated. But this merely is a "quick fix" that deals with a particular symptom (stop signs being classified wrongly) and not the cause (neural network giving undefined results when extrapolating).

The other bigger issue at hand is, even if you feel that trying to use massive training sets to get the error rate down, is that the user doesn't know when they are experiencing an occasion where the neural network is extrapolating outside of the training sets. It would be really nice if a neural network could tell you "I'm not sure what that funny-looking blob is. It's outside of my training data." If it could tell you that, it would be a step in the right direction. No, the bigger problem is that even the neural network is not aware that it's being posed with something that's outside of its training data.

Where to from here? Should we shun neural networks altogether? Not necessarily. I think we as humans need to do 2 things:

  1. Be aware of the limitations of neural networks - for example, not use them in situations with life-or-death consequences.
  2. Continue to look at and develop the technology to overcome its problems. For example, try to build in a system where the neural network can tell you where it's experiencing uncertainty due to being outside the training data in at least one parameter. And then have it refuse to output a result or decision for those cases, instead forcing it to request a human decision.

Just because some neural networks are currently being used in life-or-death situations, does this mean they should be? These are ethical questions we should be posing ourselves. 

Non-learning neural networks and learning ones both suffer from these problems. 

The neural network I had made was non-learning: it couldn't adapt or change itself after the training phase.

By contrast, the learning neural networks are able to add data from feedback to themselves and thereby improve their accuracy. One example would be a neural network which makes a prediction about oil prices, then checks it against an actual new updated oil price, and feeds the new data back into the training set. This type of neural network is going to have a better accuracy than the non-learning type. But even a learning network can still suffer from all of the same underlying problems as the non-learning ones - the only difference is that is has a bigger and ongoing training set. We as humans still need to understand that it's still possible to ask for a result from input is outside of its training data, and that this will still pose a big problem. Even in a neural network which learns and adapts itself, we should still aim to build in the ability to refuse to give a decision and to instead demand a human decision when it's experiencing uncertainty.

Thus, I think my definition of a neural network still holds:

A neural network is an interpolation system whose behavior becomes undefined when extrapolating beyond its training data. 

I won't be putting myself in a self-driving car anytime soon.

Popular posts from this blog

How to center images horizontally using Grav

I've been playing around a bit with Grav. I was posing the question to myself: for the relatively simple use-cases I'm dealing with, could it possibly work for my purposes as an alternative to ProcessWire?  The problem I was initially dismayed to find that Grav uses Markdown as its editor, which does not offer native support for horizontal centering of anything (text or images). However, Grav offers some tweaks that help make it easier to do specific things you might commonly want to do. I tried writing a sample article, and I found that one of the hardest things to do was to center an image horizontally. And horizontal centering of images is something I would typically do in most of the articles I would write. So the lack of easy horizontal centering is a highly significant drawback IMHO (most people do want to center images in an article!) However, this issue is made up for by other things in Grav: the relative speed, ease and flexibility of custom theming and built-in suppor...

Life using the Linux operating system exclusively for the last few years

Above: my Linux desktop layout. Back in 2017, I switched my operating system entirely to Linux. In case anyone is wondering, here is what I experienced over the last few years. Others I interact with have no idea I'm on Linux. For example, if someone emails me an MS Word document that I need to complete, I simply open it with LibreOffice (an open-source word processing program that is pre-installed on most Linux systems), edit the document as needed - which is very easy since the same sorts of functionalities are available in LibreOffice - and then I can save it in MS Word format and email it back. Likewise, if I'm on a Zoom call, everything works just the way it does on PC and Mac. Zoom makes their application available for Linux too, I downloaded it and let it self-install, and it works exactly the same way as it does on other operating systems. I can point-and-click my way to whatever I need to do on Linux; no special knowledge required. If you want to dig deeper into script...

Correct usage of unwind-protect and with-open-file in Lisp

Learning to use unwind-protect in Lisp typically crops up very early on when you're first learning the language. In fact, anything to do with I/O is going to be something you'll need to know early on. Yet unfortunately, I find that unwind-protect is not explained sufficiently well for a beginner to understand not just how to use it correctly, but why and when . Grappling with this myself, I found that hands-down the best explanation came from this YouTube video from Baggers: Luckily, in the case of file handlers, LISP already assumes you'll want to open a file with unwind-protect, so it provides the with-open-file macro for this exact purpose. It closes the file handler for you with a built-in unwind-protect. This is an advantage over manually opening and closing your file handlers, because if your program opens the file but never gets to the part with the close command (for example due to a run-time error in between those stages), the built-in unwind-protect make...

About Me

My photo
Vera
I'm a wife and mother. I don't have any formal computer science qualifications, or any religious qualifications. I have a PhD in biochemistry. This photo is of me, but is confusing for AI.