{ "metadata": { "name": "", "signature": "sha256:ed27079cf7cc6b818d3cd0af27d1a7dafbe17aa5469f61f0a49355a3d1a14ae1" }, "nbformat": 3, "nbformat_minor": 0, "worksheets": [ { "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "[Table of Contents](http://nbviewer.ipython.org/github/rlabbe/Kalman-and-Bayesian-Filters-in-Python/blob/master/table_of_contents.ipynb)" ] }, { "cell_type": "heading", "level": 1, "metadata": {}, "source": [ "Discrete Bayes Filter" ] }, { "cell_type": "code", "collapsed": false, "input": [ "#format the book\n", "%matplotlib inline\n", "from __future__ import division, print_function\n", "import matplotlib.pyplot as plt\n", "import book_format\n", "book_format.load_style()" ], "language": "python", "metadata": {}, "outputs": [ { "html": [ "\n", "\n" ], "metadata": {}, "output_type": "pyout", "prompt_number": 1, "text": [ "" ] } ], "prompt_number": 1 }, { "cell_type": "markdown", "metadata": {}, "source": [ "The Kalman filter belongs to a family of filters called *bayesian filters*. Most textbook treatments of the Kalman filter present the Bayesian formula, perhaps shows how it factors into the Kalman filter equations, but mostly keeps the discussion at a very abstract level. \n", "\n", "That approach requires a fairly sophisticated understanding of several fields of mathematics, and it still leaves much of the work of understanding and forming an intuitive grasp of the situation in the hands of the reader.\n", "\n", "I will use a different way to develop the topic, to which I owe the work of Dieter Fox and Sebastian Thrun a great debt. It depends on building an intuition on how Bayesian statistics work by tracking an object through a hallway - they use a robot, I use a dog (I like dogs). The first published example of this that I can find seems to be Fox 1999 [1], with a fuller example in Fox [2] 2003. Sebastian Thrun also uses this formulation in his excellent Coursera course Artificial Intelligence for Robotics [3] In fact, if you like watching videos, I highly recommend pausing reading this book in favor of first few lessons of that course, and then come back to this book for a deeper dive into the topic.\n", "\n", "Let's now use a simple thought experiment, much like we did with the g-h filter, to see how we might reason about the use of probabilities for filtering and tracking." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Tracking a Dog" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Let us begin with a simple problem. We have a dog friendly workspace, and so people bring their dogs to work. However, occasionally the dogs wander out of your office and down the halls. We want to be able to track them. So during a hackathon somebody created a little sonar sensor to attach to the dog's collar. It emits a signal, listens for the echo, and based on how quickly an echo comes back we can tell whether the dog is in front of an open doorway or not. It also senses when the dog walks, and reports in which direction the dog has moved. It connects to our network via wifi and sends an update once a second.\n", "\n", "I want to track my dog Simon, so I attach the device to his collar and then fire up Python, ready to try to write code to track him through the building. At first blush this may appear impossible. If I start listening to the sensor of Simon's collar I might read 'door', 'hall', 'hall', and so on. How can I use that information to determine where Simon is?\n", "\n", "To keep the problem small, we will assume that there are only 10 positions in a single hallway to consider, which we will number 0 to 9, where 1 is to the right of 0, 2 is to the right of 1, and so on. For reasons that will be clear later, we will also assume that the hallway is circular or rectangular. If you move right from position 9, you will be at position 0. \n", "\n", "When I begin listening to the sensor I have no reason to believe that Simon is at any particular position in the hallway. He is equally likely to be in any position. The probability that he is in each position is therefore 1/10. \n", "\n", "Let us represent our belief of his position at any time in a numpy array." ] }, { "cell_type": "code", "collapsed": false, "input": [ "import numpy as np\n", "\n", "pos_belief = np.array([.1, .1, .1, .1, .1, .1, .1, .1, .1, .1])" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 2 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Now let's create a map of the hallway in another list. Suppose there are first two doors close together, and then another door quite a bit further down the hallway. We will use 1 to denote a door, and 0 to denote a wall:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "hallway = np.array([1, 1, 0, 0, 0, 0, 0, 0, 1, 0])" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 3 }, { "cell_type": "markdown", "metadata": {}, "source": [ "So I start listening to Simon's transmissions on the network, and the first data I get from the sensor is \"door\". From this I conclude that he is in front of a door, but which one? I have no idea. I have no reason to believe is in front of the first, second, or third door. But what I can do is assign a probability to each door. All doors are equally likely, so I assign a probability of 1/3 to each door. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "from __future__ import print_function, division\n", "import matplotlib.pyplot as plt\n", "import book_plots as bp\n", "import numpy as np\n", "\n", "pos_belief = np.array([1./3, 1./3, 0, 0, 0, 0, 0, 0, 1./3, 0])\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\nqqqqoqqqqtNja9euPW3t1ltvjVtvvTVtMgAAoNfo8XeFAgAAzj7CAgAASCYsAACAZMICAABIJiwA\nAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGRZhUVtbW2MGjUqiouLo7y8POrr67u95m//9m9j7Nix\n0b9//xg2bFjU1NQkDwsAAOSnPt2dsHHjxliwYEGsWbMmpkyZEqtXr45p06bFT3/60xgxYkSn11RX\nV8dzzz0Xf/3Xfx3jx4+PY8eOxZEjR3p8eAAAID90GxbLly+POXPmxNy5cyMiYuXKlfH888/HmjVr\n4pFHHjnt/Ndeey2+/e1vx549e2LMmDHt6xMmTOjBsQEAgHzS5VOhTp06Fbt27YrKysoO65WVlbF9\n+/ZOr/mnf/qnKCsri02bNkVZWVmMGjUqZs+eHf/1X//Vc1MDAAB5pSCTyWTOdPDw4cMxfPjw2LZt\nW0yZMqV9/aGHHooNGzbE/v37T7tm3rx5sX79+vjsZz8by5Yti4iI+++/PyIiduzYEQUFBe3nHjt2\nrP3rAwcOpN8bAADgIzF69Oj2rwcOHHja8W6fCvVBtbW1xcmTJ+Opp56KT3/60xER8dRTT8WYMWOi\noaEhrr766p6+SQAAIMe6DIvBgwdHUVFRtLS0dFhvaWmJ0tLSTq8pLS2NPn36tEdFRMSnP/3pKCoq\nijfeeOOMYVFeXv5BZ//QGhoaPvbb7K3sVfbsVfbsVfbs1Qdjv7Jnr7Jnr7Jnr7LXG/fq/z/bqDNd\nvsaib9++MXHixNi8eXOH9bq6uqioqOj0milTpsS7774bTU1N7WtNTU3R2toal1xySbZzAwAAvUi3\n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\n0dDwsw93bf8hPTxNfkvZq1xqaGjI9Qi9hr3Knr36YOxX9uxV9nrbXvm5oXfoTf+uRo8e3eXxj/xd\nof7lX/4l/vAP/zBWrVoV5eXlH/XNAQAAOdDtIxaDBw+OoqKiaGlp6bDe0tISpaWlXV5bX18fn//8\n52Px4sXxJ3/yJ2mTfkIMGDAgyi+/+ENdW3/wrYg42bMD5bGUvcqF93/jIKC7Z6+yZ68+GPuVPXuV\nvd66V35uyG+98d/VsWPHujze7SMWffv2jYkTJ8bmzZs7rNfV1UVFRcUZr9u2bVvcdNNN8eCDD8bX\nvva1LMcFAAB6o6zeFaq6ujruvPPOmDRpUlRUVMRjjz0Wzc3NMW/evIh4712gdu7cGS+88EJEvPc5\nFp///Ofjq1/9asyaNav9tRhFRUVxwQUXfER3BQAAyJWswmLmzJlx9OjRWLJkSRw5ciTGjx8fmzZt\nihEjRkRERHNzczQ1NbWfv379+jhx4kQsW7Ysli1b1r4+cuTIDucBAACfDFmFRUREVVVVVFVVdXrs\nNz9Ve+3atT5pGwAAziIf+btCAQAAn3zCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\nwgIAAEgmLAAAgGRZhUVtbW2MGjUqiouLo7y8POrr67s8f8+ePXH99ddHSUlJDB8+PBYvXtwjwwIA\nAPmp27DYuHFjLFiwIBYtWhSNjY1RUVER06ZNi0OHDnV6/vHjx+PGG2+M0tLSaGhoiBUrVsSyZcti\n+fLlPT48AACQH7oNi+XLl8ecOXNi7ty5MWbMmFi5cmWUlpbGmjVrOj3/H/7hH+LEiROxfv36uOyy\n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\nQmCC\n", "text": [ "" ] } ], "prompt_number": 4 }, { "cell_type": "markdown", "metadata": {}, "source": [ "We call this a multimodal distribution because we have multiple beliefs about the position of our dog. Of course we are not saying that we think he is simultaneously in three different locations, merely that so far we have narrowed down our knowledge in his position to these locations. \n", "\n", "I hand coded the `pos_belief` array in the code above. How would we implement this in code? Well, hallway represents each door as a 1, and wall as 0, so we will multiply the hallway variable by the percentage, like so;" ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = hallway * (1/3)\n", "np.set_printoptions(precision=3)\n", "print(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.333 0.333 0. 0. 0. 0. 0. 0. 0.333 0. ]\n" ] } ], "prompt_number": 5 }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Extracting Information from Multiple Sensor Readings" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Let's put Python aside and think about the problem a bit. Suppose we were to read the following from Simon's sensor:\n", "\n", " * door\n", " * move right\n", " * door\n", " \n", "\n", "Can we deduce where Simon is at the end of that sequence? Of course! Given the hallway's layout there is only one place where you can be in front of a door, move once to the right, and be in front of another door, and that is at the left end. Therefore we can confidently state that Simon is in front of the second doorway. If this is not clear, suppose Simon had started at the second or third door. After moving to the right, his sensor would have returned 'wall'. Therefore the only possibility is that he is now in front of the second door. We denote this in Python with:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = np.array([0., 1., 0., 0., 0., 0., 0., 0., 0., 0.])\n", "print(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0. 1. 0. 0. 0. 0. 0. 0. 0. 0.]\n" ] } ], "prompt_number": 6 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Obviously I carefully constructed the hallway layout and sensor readings to give us an exact answer quickly. Real problems will not be so clear cut. But this should trigger your intuition - the first sensor reading only gave us very low probabilities (0.333) for Simon's location, but after a position update and another sensor reading we knew much more about where he is. You might suspect, correctly, that if you had a very long hallway with a large number of doors that after several sensor readings and positions updates we would either be able to know where Simon was, or have the possibilities narrowed down to a small number of possibilities. For example, suppose we had a long sequence of \"door, right, door, right, wall, right, wall, right, door, right, door, right, wall, right, wall, right, wall, right, wall, right, door\". Simon could only be located where we had a sequence of [1,1,0,0,1,1,0,0,0,0,1] in the hallway. There might be only one match for that, or at most a few. Either way we will be far more certain about his position then when we started.\n", "\n", "We could work through the code to implement this solution, but instead let us consider a real world complication to the problem." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Noisy Sensors" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Unfortunately I have yet to come across a perfect sensor. Perhaps the sensor would not detect a door if Simon sat in front of it while scratching himself, or it might report there is a door if he is facing towards the wall, not down the hallway. So in practice when I get a report 'door' I cannot assign 1/3 as the probability for each door. I have to assign something less than 1/3 to each door, and then assign a small probability to each blank wall position. At this point it doesn't matter exactly what numbers we assign; let us say that the probably of 'door' being correct is 0.6, and the probability of being incorrect is 0.2, which is another way of saying it is about 3 times more likely to be right than wrong. How would we do this?\n", "\n", "At first this may seem like an insurmountable problem. If the sensor is noisy it casts doubt on every piece of data. How can we conclude anything if we are always unsure?\n", "\n", "The key, as with the problem above, is probabilities. We are already comfortable with assigning a probabilistic belief about the location of the dog; now we just have to incorporate the additional uncertainty caused by the sensor noise. Say we think there is a 50% chance that our dog is in front of a specific door and we get a reading of 'door'. Well, we think that is only likely to be true 0.6 of the time, so we multiply: $0.5 * 0.6= 0.3$. Likewise, if we think the chances that our dog is in front of a wall is 0.1, and the reading is 'door', we would multiply the probability by the chances of a miss: $0.1 * 0.2 = 0.02$.\n", "\n", "However, we more or less chose 0.6 and 0.2 at random; if we multiply the `pos_belief` array by these values the end result will no longer represent a true probability distribution. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "def update(pos_belief, measure, p_hit, p_miss):\n", " for i in range(len(hallway)):\n", " if hallway[i] == measure:\n", " pos_belief[i] *= p_hit\n", " else:\n", " pos_belief[i] *= p_miss\n", "\n", "pos_belief = np.array([0.2]*10)\n", "reading = 1 # 1 is 'door'\n", "update(pos_belief, 1, .6, .2)\n", "\n", "print(pos_belief)\n", "print('sum =', sum(pos_belief))\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.12 0.12 0.04 0.04 0.04 0.04 0.04 0.04 0.12 0.04]\n", "sum = 0.64\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAGNCAYAAACMgOcOAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAIABJREFUeJzt3XFw1/V9+PFXEgQTi5wMwSAoxDKoiFSJTCJVb4e5YR1l\nU1G62YJ0jsxaMHPH0rJzCkotOzagBJ31gNnR4q4911PmEU+UMuiNCHFIweGyIb2QdDILlhU4ku/v\nj17za0pIvvqOfL+Rx+OOu/D+fj75vr7vC3d58v1+P9+CTCaTCQAAgASFuR4AAADo/YQFAACQTFgA\nAADJhAUAAJBMWAAAAMmEBQAAkExYAAAAyboNiy1btsS0adNi2LBhUVhYGOvWrev2m+7evTtuuumm\nKCkpiWHDhsWiRYt6ZFgAACA/dRsWx44di6uvvjqWL18excXFUVBQ0OXxR48ejVtuuSVKS0ujvr4+\nli9fHkuXLo1ly5b12NAAAEB+Kfggn7zdv3//WLVqVXzhC1844zGrV6+OmpqaaGlpiX79+kVExGOP\nPRarV6+On/zkJ+kTAwAAeafH32Oxffv2+MxnPtMeFRERlZWV0dTUFAcOHOjpuwMAAPJAn57+hs3N\nzXHZZZd1WBsyZEj7bZdffnn7+pEjR3r67gEAgI/YgAEDTlvr8WcsunsPBgAA8PHT42FxySWXRHNz\nc4e1lpaW9tsAAICPnx5/KdSkSZNiwYIFceLEifb3WdTV1cWll17a4WVQv6mzp1M+KvX19RERUV5e\nftbus7eyV9mzV9mzV9mzVx+M/cqevcqevcqevcpeb9yr7t7GkNXlZhsaGqKhoSHa2triwIED0dDQ\nEAcPHoyIiJqampgyZUr78Z///OejpKQkZs2aFXv27Invf//78cQTT0R1dXXiQwEAAPJVt2GxY8eO\nuPbaa+Paa6+N48ePx8MPPxzXXnttPPzwwxHxyzdkNzY2th9/4YUXRl1dXTQ1NUV5eXk88MAD8dBD\nD8WDDz740T0KAAAgp7p9KdTNN98cbW1tZ7x9zZo1p61dddVV8dprr6VNBgAA9Bo9/uZtAADg3CMs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\n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\n", "text": [ "" ] } ], "prompt_number": 7 }, { "cell_type": "markdown", "metadata": {}, "source": [ "We can see that this is not a probability distribution because it does not sum to 1.0. But we can see that the code is doing mostly the right thing - the doors are assigned a number (0.12) that is 3 times higher than the walls (0.04). So we can write a bit of code to normalize the result so that the probabilities correctly sum to 1.0." ] }, { "cell_type": "code", "collapsed": false, "input": [ "def update(pos_belief, measure, p_hit, p_miss):\n", " for i in range(len(hallway)):\n", " if hallway[i] == measure:\n", " pos_belief[i] *= p_hit\n", " else:\n", " pos_belief[i] *= p_miss\n", " \n", " pos_belief /= sum(pos_belief)\n", "\n", "pos_belief = np.array([0.2]*10)\n", "reading = 1 # 1 is 'door'\n", "update(pos_belief, 1, .6, .2)\n", "\n", "print('sum =', sum(pos_belief))\n", "print('probability of door =', pos_belief[0])\n", "print('probability of wall =', pos_belief[2])\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "sum = 1.0\n", "probability of door = 0.1875\n", "probability of wall = 0.0625\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nAOhBuvwci5qamli1alU899xzsXv37pg9e3Y0NzfHrFmzIiKitrY2Jk6c2Hb8xIkT4/rrr4/7778/\nGhoaYseOHXH//ffHjTfe2KOKDAAAyF6X77GYOnVqHDx4MBYsWBAHDhyI0aNHx7p169o+w6K5ubnd\nsxMFBQXx0ksvxVe+8pW4+eabo7i4OKqqqmLx4sVn71EAAAA5ldWbt6urq6O6urrD21auXHnK2mWX\nXRYvvPBC2mQAAECP0eVLoQAAALoiLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\nwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMIC\nAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAA\nSCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgm\nLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwA\nAIBkWYVFXV1dDBs2LIqLi6OioiI2bdqU1Tffu3dv9O3bN/r27Zs0JAAAkN+6DIu1a9fGnDlzYt68\nedHQ0BCVlZUxadKk2L9/f6fnHT9+PO6999645ZZboqCgoNsGBgAA8k+XYbF48eKYMWNGzJw5M0aM\nGBFLly6N0tLSWLFiRafnzZ07Nz796U/H3XffHZlMptsGBgAA8k+nYXH8+PHYvn17VFVVtVuvqqqK\nzZs3n/a8l19+OV5++eVYtmyZqAAAgPNAr85ufP/996O1tTUGDRrUbn3gwIHR3Nzc4TlNTU3xwAMP\nxIsvvhglJSVZD7Jt27asj+0uubjPnspeZc9eZc9eZc9enRn7lT17lT17lT17lb2etFfDhw/v9PZu\nvyrUfffdF9XV1XHDDTd097cGAADyVKfPWAwYMCCKioqipaWl3XpLS0uUlpZ2eM6GDRti48aN8dhj\nj0VERCaTiZMnT8YFF1wQK1asiC996UsdnldRUfFR5v9IflWG5/I+eyp7lT17lT17lT17dWbsV/bs\n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\nGDp0aNx///25Hi/vPP/883H//fdHWVlZFBUVxdixY2PatGnx5ptv5nq0JOdNWAwYMCCKioqipaWl\n3XpLS0uUlpbmaCo+Th5++OF44YUXYsOGDTF06NBcj5O3LrjggigvL4+IiOuuuy62bt0ay5cvj5Ur\nV+Z4svyyZcuWeP/992PUqFFta62trfHDH/4wnnnmmThy5EhccMEFOZwwf5WUlMSoUaPi3XffzfUo\neWfw4MFx9dVXt1sbOXJkvPfeezmaqGf46U9/Gj/4wQ+irq4u16PkrSeeeCLmzZsXU6dOjYiIUaNG\nxb59+2LhwoXCogPl5eXx+uuvxy9+8Ys4fPhwDBo0KO6555646qqrcj1akvPmPRa9e/eOsWPHxvr1\n69ut19fXR2VlZY6m4uNi9uzZsXbt2njttdfit3/7t3M9To/S2toaJ0+ezPUYeecP/uAP4u233463\n3nor3nrrrWhoaIiKioqYNm1aNDQ0iIpOHD16NHbv3u0/jTpw0003xZ49e9qt/cd//If/DOnCqlWr\n4sILL4xp06blepS8lclkorCw/a+VhYWFnmXtQnFxcQwaNCg++OCDWL9+fXzuc5/L9UhJzptnLCJ+\n+TKV++67L8aNGxeVlZXx9NNPR3Nzs9f/deDIkSOxd+/eiPjlU+f79u2LhoaG+K3f+q22T13nlx58\n8MH49re/HS+++GL069ev7T07ffv2jYsuuijH0+WXv/zLv4w77rgjysrK4sMPP4w1a9bEG2+8Ea+8\n8kquR8s7v/qsj19XUlISl1xyySn/43y+e+SRR2Ly5MkxZMiQ+OlPfxrz58+PX/ziF/HFL34x16Pl\nnYcffjgqKyvjySefjKlTp8aOHTti2bJlLgnaiUwmE9/61rfi3nvvjZKSklyPk7emTJkSX//612PY\nsGFx9dVXx44dO+Jv//Zv/Ts8jfXr10dra2uMHDky3n333fiLv/iL+NSnPhUzZszI9WhpcnhFqpyo\nq6vLDB06NNOnT59MRUVF5oc//GGuR8pLGzZsyBQUFGQKCgoyhYWFbV/PmDEj16Plnd/co1/9eeyx\nx3I9Wt6ZPn165sorr8z06dMnM3DgwMxtt92WWb9+fa7H6jFcbrZj9957b2bw4MGZ3r17Zy6//PLM\nXXfdldm9e3eux8pbL7/8cmbMmDGZCy+8MDNixIjMsmXLcj1SXnvttdcyhYWFma1bt+Z6lLz285//\nPPPnf/7nmaFDh2aKi4sz5eXlma997WuZY8eO5Xq0vPTCCy9krrrqqkyfPn0ypaWlmYceeihz+PDh\nXI+VrCAJkNGwAAAAPUlEQVST8RwVAACQ5rx5jwUAAHD2CAsAACCZsAAAAJIJCwAAIJmwAAAAkgkL\nAAAgmbAAAACSCQsAACDZ/wPWkdIM5K/8lgAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 8 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Normalization is done by dividing each element by the sum of all elements in the list. If this is not clear you should spend a few minutes proving it to yourself algebraically. We can see from the output that the sum is now 1.0, and that the probability of a door vs wall is still three times larger. The result also fits our intuitiion that the probability of a door must be less than 0.333, and that the probability of a wall must be greater than 0.0. Finally, it should fit our intuition that we have not yet been given any information that would allow us to distinguish between any given door or wall position, so all door positions should have the same value, and the same should be true for wall positions. " ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Incorporating Movement Data" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Recall how quickly we were able to find an exact solution to our dog's position when we incorporated a series of measurements and movement updates. However, that occured in a fictional world of perfect sensors. Might we be able to find an exact solution even in the presence of noisy sensors?\n", "\n", "Unfortunately, the answer is no. Even if the sensor readings perfectly match an extremely complicated hallway map we could not say that we are 100% sure that the dog is in a specific position - there is, after all, the possibility that every sensor reading was wrong! Naturally, in a more typical situation most sensor readings will be correct, and we might be close to 100% sure of our answer, but never 100% sure. This may seem head-spinningly complicated, but lets just go ahead and program the math, which as we have seen is quite simple.\n", "\n", "First let's deal with the simple case - assume the movement sensor is perfect, and it reports that the dog has moved one space to the right. How would we alter our `pos_belief` array?\n", "\n", "I hope after a moment's thought it is clear that we should just shift all the values one space to the right. If we previously thought there was a 50% chance of Simon being at position 3, then after the move to the right we should believe that there is a 50% chance he is at position 4. So let's implement that. Recall that the hallway is circular, so we will use modulo arithmetic to perform the shift correctly" ] }, { "cell_type": "code", "collapsed": false, "input": [ "import numpy\n", "def perfect_predict(pos_belief, move):\n", " \"\"\" move the position by 'move' spaces, where positive is to the right, \n", " and negative is to the left\n", " \"\"\"\n", " n = len(pos_belief)\n", " result = np.zeros(n)\n", " for i in range(n):\n", " result[i] = pos_belief[(i-move) % n]\n", " pos_belief[:] = result\n", " \n", "pos_belief = np.array([.4, .1, .2, .3])\n", "print('belief before predict =', pos_belief)\n", "bp.bar_plot(pos_belief, title='Before prediction')\n", "\n", "perfect_predict(pos_belief, 1)\n", "print('belief after predict =', pos_belief)\n", "bp.bar_plot(pos_belief, title='After prediction')" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "belief before predict = [ 0.4 0.1 0.2 0.3]\n", "belief after predict =" ] }, { "output_type": "stream", "stream": "stdout", "text": [ " [ 0.3 0.4 0.1 0.2]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAGaCAYAAACSU9UtAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAIABJREFUeJzt3Xt0lPWd+PHPhIsE5aIiFxW5rIq6DQhEK1ERWJpdypZ6\nvHCsrhTEdWG9gKirdF3FSr128baC1wJVq7DV6jmKLKiARVChmOoq1gsu0oVkC2pALBfJ/P7wkF/T\nhCT4DR0ir9c5nlO+8zwzn5k8h+bNPM9MJpvNZgMAACBBXq4HAAAAGj9hAQAAJBMWAABAMmEBAAAk\nExYAAEAyYQEAACQTFgB72D333BN//dd/HS1btoy8vLy44YYbcj1SozNgwIDIy6v6f1kLFy7c469n\n165do1u3bnvs/gG+SYQFwNdw1113RV5eXuTl5cXrr7++y+2eeOKJGDduXOzYsSPGjRsXkyZNigED\nBsSkSZMiLy8vZs6c+RecunHLZDK7tV4fXbt2rRYsf37fKfcPsC9pmusBABqjBx54oMr/PvHEE2vc\n7tlnn42IiJ///OdVtlmwYEFEpP1SvK/79re/He+++260a9cu6X5q+xm89NJLSfcNsC/xjgXAbvr1\nr38dK1eujHPOOScOP/zwmDVrVmzatKnGbdeuXRsRER06dKjx9mw2u8fm/KbLz8+Po48+Og466KA9\n9hjdunVzKhRAPQkLgN20892KCy+8MEaMGBGbN2+Oxx57rMo2O091WrhwYUR89QvqzlOnBg4cGD/+\n8Y8jImLUqFGV63l5efHxxx9X3kdFRUU89NBDcfLJJ0ebNm0iPz8/CgoK4pZbbont27dXmysvLy+6\ndesWGzdujPHjx0eXLl2iWbNmcdddd9X6fHZeqzBq1Kh45513YtiwYXHQQQfFAQccEP37948XX3yx\n2j4zZsyovL7h1VdfjSFDhsSBBx4YeXl5sXHjxq81f8RXp4717ds3WrZsGR06dIgRI0ZUxtmu5q7p\nGotPP/00/u3f/i0KCgrigAMOiDZt2kRBQUFcddVV8dlnn8X//M//VL7e2Wy2ys9g4MCBlfezq2ss\ntm3bFrfffnscf/zxsf/++0fr1q2jX79+MX369Bpn3fmz+eKLL+Kqq66KI444Ilq0aBFHHXVU3Hbb\nbTXuA9DYOBUKYDd88skn8ctf/jK6dOkSgwYNii5dusRNN90UDz74YIwZM6Zyu4EDB0Ymk4kZM2bE\n6tWrY/z48dG2bduIiOjSpUtERCxatChOP/30OP744yv3a9OmTUREfPnll3HGGWfEs88+Gz169Ijz\nzjsvWrRoEQsXLowf/ehH8eKLL8bcuXOjSZMmVebbunVrDBw4MDZu3BhDhw6Nli1bRufOnev13D76\n6KM4+eST4/jjj4+xY8fG73//+5g9e3b87d/+bcyePTvOOOOMavssWbIkbrrpphgwYEBcdNFFsW7d\numjSpMnXmv+OO+6IK664Itq2bRsjRoyIAw88MP7rv/6rMkx25c9PZfroo49i4MCB8fHHH0efPn0q\nfy7vvfdeTJ06Nc4///zo0qVLXH/99XHnnXdGeXl5TJo0qXL/rl271nr/27dvjyFDhsSCBQuiR48e\n8c///M+xdevWeOqpp2L06NGxePHiePjhh6vNuX379iguLo5169bF0KFDo2nTpvGrX/0qrrnmmtiy\nZUtcd911u3yOAI1CFoB6u+OOO7KZTCZ7/fXXV671798/m8lkssuWLau2/WmnnZbNZDLZ1atXV1m/\n/vrrs5lMJjtz5swaH+fGG2/MZjKZ7KWXXpqtqKioXK+oqMhedNFF2Uwmk73nnnuq7JPJZLKZTCZb\nXFyc/eMf/1jv57RgwYLKff/lX/6lym2vvfZatmnTptmDDz44+/nnn1euT58+vXKfBx98MHn+jz76\nKNusWbPsgQcemP3oo4+qbD98+PBsJpPJ5uXl1Tj3DTfcUGW9X79+2Uwmk508eXK1ucrLy6s8jy5d\nulS73z/VpUuXbLdu3aqs3XLLLdlMJpP9u7/7u+z27dur3Pe3vvWtbCaTyf7yl7+sss/O12ro0KHZ\nLVu2VK7/3//9X7Zt27bZtm3bVrkvgMbIqVAAu+GBBx6IvLy8GDlyZOXaBRdcUHlbQ6ioqIi77ror\nOnToEHfeeWeVfzHPZDJx6623RiaTiUcffbTavplMJn76059GixYtdvtx27ZtW+1fzU888cQYPnx4\nfPLJJ/HMM89U26d3795x4YUXfq35H3nkkcr1xx57LL788su4+OKLq7xjsHP72j656U/95je/iVdf\nfTV69uwZ//qv/1rt9tatW8f+++9fr/valYceeigymUxMmTIlmjb9/2/8t27dOm6++eaIiHjwwQer\n7ZfJZOLuu++O/fbbr3LtkEMOiWHDhkV5eXm89957SXMB5JpToQDq6de//nW8++67MWDAgCq//J59\n9tlx6aWXxhNPPBFTpkyJAw44IOlx3nvvvdiwYUP81V/9VeW1GH+uRYsW8c4779S4XlBQ8LUet0+f\nPjX+0t2/f/94/PHHo6SkJM4999wqt9X0aVj1nX/lypWVf16xYkVERJx22mnVtu3atWt07ty5yvUn\nu/Lqq69GRERxcXGd234dmzZtig8//DA6duwYxx57bLXbBw0aFBERb7zxRrXb2rRpE927d6+2vvNU\ntU8//bSBpwX4yxIWAPV0//33R0TED3/4wyrrLVu2jLPPPjumT58ev/jFL+Kiiy5KepwNGzZERMSH\nH364y1/MI2r+mNT27dt/7cfd1SdX7VwvLy+vdlvHjh2rrX2d+Xfed20z1CcsPvvss4iIOOyww+rc\n9uvYOWdNzzviq2OhdevWlXP8qZ3X2Py5ne967Nixo4GmBMgNp0IB1MPOi7Yjqn+SU15eXuWnATXE\n6VA7L1QeNmxYVFRU7PK/mn4RTflejLKyslrXa7qAuqbH+zrz79ynrhnqsvOX99///vf12n537Zyz\ntLS0xtu/+OKL2LhxY60XmwN8U3nHAqAeZs6cGdu2bYvevXtH3759a9zm+eefjxUrVsSKFSuiT58+\ntd7fzk9DqikOjj322Gjbtm289tprsX379mjWrFn6E6iHFStWxOeff17tVK5FixZFxFfXU9TH15m/\nb9++8atf/SoWLlwYgwcPrnLbRx99FGvWrKnXY/fr1y8iIubNmxe33XZbnaG18+eQzWbrFWWtWrWK\nI488Mj744INYuXJltdOhdn6h3q6OEYBvMu9YANTDAw88UHnx7QMPPFDjf5dffnnltn+qpl9YDz74\n4IiIWL16dbXbmjRpEuPGjYuysrK4+OKL449//GO1bdavXx+//e1vG+KpVfrss8+qnbr02muvxezZ\ns+Oggw6K73//+/W6n68z/3nnnRfNmjWLe++9Nz766KPK9YqKirjmmmuioqKiXo/dp0+fKCoqirfe\neit+8pOfVLu9vLw8Nm/eXPnngw8+OLLZbI0/h10ZPXp0RERcccUV8eWXX1aub9y4MX70ox9FRFS7\noB1gX+AdC4A6vPzyy/G73/0ujj322Dj55JN3ud2IESNi4sSJ8fjjj8e///u/V14Ina3h27X/5m/+\nJvLy8uLOO++MDRs2VF5bcNlll0Xr1q3j2muvjbfeeiseeuiheO6552LQoEFx+OGHxx/+8If48MMP\n45VXXolLLrkkpkyZ0mDP89RTT40HH3wwXn/99SgqKor//d//jVmzZkUmk4kHHnggWrZsWe/72t35\nu3TpErfccktcccUV0adPnxg+fHjl91iUl5dHz549480336zXYz/66KMxYMCAuO666+Lpp5+OAQMG\nRMRX13zMmzcvli5dGj179oyIry7yXr58eZxxxhkxZMiQyM/Pj65du8Y//MM/7PL+J0yYEHPnzo25\nc+dGQUFBDB06NLZv3x5PPvlkrF27Nn74wx/GmWeeWe/XCuAbo67Po120aFH2e9/7Xvawww7LZjKZ\n7IwZM+r8DNs333wz279//2x+fn72sMMOy/74xz9O/2BcgBw599xzs3l5edk77rijzm2HDx+ezcvL\nyz700EPZbDabHTBgQDYvL6/a91hks9ns448/nu3bt2+2ZcuWld/T8OfbPf7449ni4uLswQcfnG3e\nvHn20EMPzfbr1y87adKk7AcffFBl20wmU+07F+pj5/dBjBo1Krty5crssGHDsgceeGB2//33z/bv\n3z/74osvVttnxowZ2by8vGrfIVHTc6zv/Du379OnT7ZFixbZ9u3bZ88///zsunXrKl/HmuauaYYN\nGzZkJ06cmD3mmGOyLVq0yLZt2zbbs2fP7NVXX5397LPPKrf74osvspdeemn2iCOOyDZr1iybyWSy\nAwcOrLy9a9euNb6mW7duzd56663Znj17ZvPz87MHHHBA9qSTTso+/PDDNb4Otf1sJk2alM3Ly8su\nWrSo5hcRoJHIZLM1/FPan3j++efjlVdeid69e8eIESNi2rRpMWLEiF1uv3Hjxjj66KMr/7Vo5cqV\nMWrUqJg0aVJMmDChwcMIgDQLFy6MQYMGxciRI+NnP/tZrscBoJGq81SoIUOGxJAhQyIiqnwh1K48\n9thjsWXLlpg5c2bst99+cdxxx8W7774bU6ZMERYAAPAN1eAXby9dujROPfXUKt8sWlxcHGvXrt2t\ni+MAAIDGo8Ev3i4tLY0jjjiiytrOixJLS0ujS5cules1fdkSAH9Zn3/+eUREbNu2zd/LANRLTd/X\n0+BhkfLlTAD85Z166qnx6aef5noMABq5Bj8VqmPHjtW+kXTnN6Z27NixoR8OAADYCzT4Oxb9+vWL\nq6++OrZu3Vp5ncX8+fPjsMMOq3Ia1J+r6e0U/r/ly5dHRERhYWGOJ4E9z/HOvsTxzr7E8d641XW6\nbJ3vWGzevDlKSkqipKQkKioqYvXq1VFSUhJr1qyJiIiJEyfG4MGDK7c/99xzo2XLljFy5Mh4++23\n46mnnopbb73VJ0IBAMA3WJ1hsWzZsujTp0/06dMntmzZEtdff3306dMnrr/++oj46oLsVatWVW7f\nunXrmD9/fqxduzYKCwvj0ksvjSuvvDIuv/zyPfcsAACAnKrzVKgBAwZERUXFLm+fPn16tbVvfetb\nsWjRorTJAACARqPBL94GAAD2PcICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\nwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMIC\nAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAA\nSCYsAACAZPUKi6lTp0a3bt0iPz8/CgsLY/HixbVuP2fOnDjppJOidevWccghh8Tpp58e77//foMM\nDAAA7H3qDItZs2bF+PHj49prr42SkpIoKiqKIUOGxJo1a2rc/oMPPojTTz89BgwYECUlJfHCCy/E\nli1b4rvf/W6DDw8AAOwd6gyLKVOmxKhRo2L06NHRo0ePuPvuu6NTp04xbdq0GrcvKSmJioqKuPnm\nm6N79+7Rq1evuPrqq+PDDz+MTz75pMGfAAAAkHu1hsW2bdtixYoVUVxcXGW9uLg4lixZUuM+J598\nchxwwAHx4IMPxo4dO2LTpk0xY8aMOPHEE+Oggw5quMkBAIC9RtPably/fn3s2LEjOnToUGW9ffv2\nUVpaWuM+nTp1ijlz5sTpp58eF198cVRUVETv3r3j+eefr3WQ5cuX7+bo+yavE/sSxzv7Esc7+xLH\ne+N01FFH1Xp7g38q1KpVq+L000+PUaNGxfLly2PhwoXRqlWrGD58eGSz2YZ+OAAAYC9Q6zsW7dq1\niyZNmkRZWVmV9bKysujUqVON+9x///3RuXPnuPXWWyvXHn300ejcuXMsXbo0ioqKatyvsLBwd2ff\np+wse68T+wLHO/sSxzv7Esd741ZeXl7r7bW+Y9G8efPo27dvzJs3r8r6/PnzdxkI2Ww28vKq3u3O\nP1dUVNQ5MAAA0PjUeSrUhAkTYsaMGfHwww/HypUrY9y4cVFaWhpjxoyJiIiJEyfG4MGDK7cfNmxY\nrFixIm688cZ4//33Y8WKFTFq1Kg44ogjom/fvnvumQAAADlT66lQERHDhw+PDRs2xOTJk2PdunVR\nUFAQc+bMic6dO0dERGlpaaxatapy+1NOOSVmzZoVt9xyS9x2223RsmXL6NevX8ydOzfy8/P33DMB\nAAByps6wiIgYO3ZsjB07tsbbpk+fXm3trLPOirPOOittMgAAoNFo8E+FAgAA9j3CAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGT1CoupU6dGt27dIj8/PwoLC2Px4sV1\n7nPnnXfGMcccEy1atIhDDz00Jk6cmDwsAACwd2pa1wazZs2K8ePHx7Rp0+KUU06Je++9N4YMGRLv\nvPNOdO7cucZ9JkyYEM8991z89Kc/jYKCgigvL49169Y1+PAAAMDeoc6wmDJlSowaNSpGjx4dERF3\n3313zJ07N6ZNmxY33XRTte1/97vfxX/8x3/EW2+9FT169Khc79WrVwOODQAA7E1qPRVq27ZtsWLF\niiguLq6yXlxcHEuWLKlxn2eeeSa6d+8ec+bMie7du0e3bt1i5MiR8Yc//KHhpgYAAPYqtb5jsX79\n+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\nLCyMxYsX73LbhQsXxve///049NBDY//9949evXrF9OnTG2RgAABg71OvsJg1a1aMHz8+rr322igp\nKYmioqIYMmRIrFmzpsbtly5dGr169Yonn3wy3n777Rg7dmxcdNFF8fjjjzfo8AAAwN6haX02mjJl\nSowaNSpGjx4dERF33313zJ07N6ZNmxY33XRTte0nTpxY5c9jxoyJBQsWxJNPPhk/+MEPGmBsAABg\nb1LnOxbbtm2LFStWRHFxcZX14uLiWLJkSb0fqLy8PA466KDdnxAAANjr1fmOxfr162PHjh3RoUOH\nKuvt27eP0tLSej3Is88+Gy+99NJuhQik2LRpUyxf/mGux6hmU4v2uR6Bb6C99Xhn9yxfvjzXI8Bf\njOO9cTrqqKNqvb1ep0KleOWVV+K8886Le+65JwoLC/f0wwEA/EVlW7WL9dt90CYNr12zishsWp/r\nMeqtzrBo165dNGnSJMrKyqqsl5WVRadOnWrdd/HixTF06NC48cYb45/+6Z/SJoXd0KpVqyj81hG5\nHqOaxas/jYituR6Db5i99Xinfnb+y61/fGu8Fq/+NH70euP55Y/G457+7eKUHl1zPUal8vLyWm+v\nM6+bN28effv2jXnz5lVZnz9/fhQVFe1yv5dffjm++93vxg033BCXXXZZPccFAAAao3qdCjVhwoQ4\n//zz48QTT4yioqK47777orS0NMaMGRMRX30K1LJly+KFF16IiK++x2Lo0KFxySWXxA9+8IPKazGa\nNGkShxxyyB56KgAAQK7UKyyGDx8eGzZsiMmTJ8e6deuioKAg5syZE507d46IiNLS0li1alXl9jNn\nzowtW7bE7bffHrfffnvleteuXatsBwAAfDPU++LtsWPHxtixY2u87c+/VXv69Om+aRsAAPYhPsIA\nAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAA\nSCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgm\nLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZE1zPQAA30yr\n1m+KtZu/zPUYe71NLdpHRMTi1Z/meJLG4dD9m0b3dq1yPQZQA2EBwB6xdvOXcenL63M9RiOyNdcD\n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\nYII=\n", "text": [ "" ] } ], "prompt_number": 9 }, { "cell_type": "markdown", "metadata": {}, "source": [ "We can see that we correctly shifted all values one position to the right, wrapping from the end of the array back to the beginning." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Adding Noise to the Prediction" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "We want to solve real world problems, and we have already stated that all sensors have noise. Therefore the code above must be wrong. What if the sensor reported that our dog moved one space, but he actually moved two spaces, or zero? Once again this may initially sound like an insurmountable problem, but let's just model it in math. Since this is just an example, we will create a pretty simple noise model for the sensor - later in the book we will handle far more sophisticated errors.\n", "\n", "We will say that when the sensor sends a movement update, it is 80% likely to be right, and it is 10% likely to overshoot one position to the right, and 10% likely to undershoot to the left. That is, if we say the movement was 4 (meaning 4 spaces to the right), the dog is 80% likely to have moved 4 spaces to the right, 10% to have moved 3 spaces, and 10% to have moved 5 spaces.\n", "\n", "This is slightly harder than the math we have done so far, but it is still tractable. Each result in the array now needs to incorporate probabilities for 3 different situations. For example, consider position 9 for the case where the reported movement is 2. It should be clear that after the move we need to incorporate the probability that was at position 7 (9-2). However, there is a small chance that our dog actually moved from either 1 or 3 spaces away due to the sensor noise, so we also need to use positions 6 and 8. How much? Well, we have the probabilities, so we can just multiply and add. It would be 80% of position 7 plus 10% of position 6 and 10% of position 8! Let's try coding that:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "def predict(pos_belief, move, p_correct, p_under, p_over):\n", " n = len(pos_belief)\n", " result = np.zeros(n)\n", " for i in range(n):\n", " result[i] = (\n", " pos_belief[(i-move) % n] * p_correct +\n", " pos_belief[(i-move-1) % n] * p_over +\n", " pos_belief[(i-move+1) % n] * p_under) \n", " pos_belief[:] = result\n", "\n", "pos_belief = np.array([0, 0, 0, 1, 0, 0, 0, 0], dtype=float)\n", "predict(pos_belief, 2, .8, .1, .1)\n", "print(pos_belief)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0. 0. 0. 0. 0.1 0.8 0.1 0. ]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nlJRER0dHr/WOjo6oqKjo85ydO3fGrl274rHHHouIiHw+H93d3XHeeedFQ0ND/NEf/VGf51VVVf0m\n8w+69wpzuMwzUtj3bNj3bNj3bIyUfW8++HZEvJv1GOeEsWPHRtW1l2U9xpAYKY/34abQ972zs7Pf\n2/sNi9GjR8fMmTNj+/btcdddd/WsNzU1xT333NPnOT/84Q97/f3FF1+Mxx9/PPbu3RsTJ04807kB\nAIBzSL9hERFRV1cX999/f8yaNSuqq6vj2WefjVwuF0uXLo2IiJUrV8bevXvjlVdeiYiIq6++utf5\n3//+96O4uPi0dQAAoHAMGBYLFiyIY8eOxZo1a+LIkSMxffr0aGxsjMrKyoiIyOVy0d7e3u/38DkW\nAABQ2AYMi4iI2traqK2t7fO2zZs393vuokWLYtGiRR94MAAA4Nwx6O8KBQAAjDzCAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGRnHBb19fUxefLkKC0tjaqqqmhubn7f\nY7/3ve/F7/3e78XEiRPjggsuiBkzZsTmzZsHZWAAAGD4OaOw2LZtWyxfvjxWrVoVbW1tUV1dHXPn\nzo1Dhw71efyePXtixowZ8cILL8Sbb74ZtbW18cADD8Tf/u3fDurwAADA8DDqTA5au3ZtLF68OJYs\nWRIREevWrYuXX345Ghoa4oknnjjt+JUrV/b6+9KlS2Pnzp3xwgsvxMKFCwdhbAAAYDgZ8BmLU6dO\nRWtra9TU1PRar6mpid27d5/xD+rs7IyLLrrog08IAAAMewM+Y3H06NHo6uqKCRMm9FovLy+PXC53\nRj/ku9/9buzYsaPfEGlpaTmj73W2DLd5Rgr7ng37ng37no1C3/fjY8qzHuGccfz48Whp+UnWYwyp\nQn+8D1eFuu9Tp07t9/Yhf1eof/7nf44/+IM/iPXr10dVVdVQ/zgAACADAz5jMX78+CgpKYmOjo5e\n6x0dHVFRUdHvuc3NzXHnnXfG6tWr40/+5E/6PXa4RMd7hTlc5hkp7Hs27Hs27Hs2Rsq+Nx98OyLe\nzXqMc8LYsWOj6trLsh5jSIyUx/twU+j73tnZ2e/tAz5jMXr06Jg5c2Zs376913pTU1NUV1e/73m7\ndu2KT3ziE/HYY4/FF77whTMcFwAAOBed0btC1dXVxf333x+zZs2K6urqePbZZyOXy8XSpUsj4pfv\nArV379545ZVXIuKXn2Nx5513xuc///lYuHBhz7UYJSUlcfHFFw/RXQEAALJyRmGxYMGCOHbsWKxZ\nsyaOHDkS06dPj8bGxqisrIyIiFwuF+3t7T3Hb926NU6ePBlPP/10PP300z3rV1xxRa/jAACAwnBG\nYRERUVtbG7W1tX3e9n8/VXvz5s0+aRsAAEaQIX9XKAAAoPAJCwAAIJmwAAAAkgkLAAAgmbAAAACS\nCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkL\nAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAA\nIJmwAAAAkgkLAAAgmbAAAACSCQsAACDZqKwHAKAwtR89HodP/CLrMXocH1MeERHNB9/OeJLTTbxg\nVEwZPzbrMfgNDbfHeoTHO9kQFgAMicMnfhEP7Tqa9Rh9eDfrAU6z/tbxMWV81lPwmxq+j/UIj3fO\nJi+FAgAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZ\nsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAA\nAACSCQsAACCZsAAAAJIJCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJKdUVjU19fH5MmT\no7S0NKqqqqK5ubnf4/ft2xe33XZblJWVxaRJk2L16tWDMiwAADA8DRgW27Zti+XLl8eqVauira0t\nqqurY+7cuXHo0KE+j3/nnXfijjvuiIqKimhpaYlnnnkmnn766Vi7du2gDw8AAAwPA4bF2rVrY/Hi\nxbFkyZKYNm1arFu3LioqKqKhoaHP4//mb/4mTp48GVu3bo2rr7467rrrrlixYoWwAACAAtZvWJw6\ndSpaW1ujpqam13pNTU3s3r27z3P27NkTH//4x+P888/vdfzhw4fj4MGDgzAyAAAw3Izq78ajR49G\nV1dXTJgwodd6eXl55HK5Ps/J5XJx2WWX9Vp77/xcLheXX355n+d1dnae8dBDaerUqRExfOYZKex7\nNux7NkbKvk//reL43rzyrMc4ZwzW48G+fzCDse/2/IMr1H//Rsq/7+9n0N8VqqioaLC/JQAAMMz1\nGxbjx4+PkpKS6Ojo6LXe0dERFRUVfZ5zySWXnPZsxnvnX3LJJSmzAgAAw1S/L4UaPXp0zJw5M7Zv\n3x533XVXz3pTU1Pcc889fZ4ze/bsWLFiRbz77rs911k0NTXFpZdeetrLoMaNG5c6PwAAMAwM+FKo\nurq62LJlS2zatCn2798fy5Yti1wuF0uXLo2IiJUrV8acOXN6jr/vvvuirKwsFi1aFG+++WZ8+9vf\njqeeeirq6uqG7l4AAACZ6vcZi4iIBQsWxLFjx2LNmjVx5MiRmD59ejQ2NkZlZWVE/PKC7Pb29p7j\nL7zwwmhqaooHH3wwqqqq4qKLLopHHnkkHn744aG7FwAAQKaK8vl8PushAACAc9ugvyvUua6+vj4m\nT54cpaWlUVVVFc3NzVmPVNB27doV8+bNi0mTJkVxcXFs3bo165FGhCeffDJuvPHGGDduXJSXl8e8\nefPizTffzHqsgrdhw4aYMWNGjBs3LsaNGxfV1dXR2NiY9VgjypNPPhnFxcXx0EMPZT1KwXv00Uej\nuLi415+JEydmPdaIcOTIkfjsZz8b5eXlUVpaGtdcc03s2rUr67EK2hVXXHHa4724uDg++clPZj3a\nWSUsfs22bdti+fLlsWrVqmhra4vq6uqYO3duHDp0KOvRCtaJEyfiuuuui2eeeSZKS0u9XfFZ8uqr\nr8bnP//52LNnT+zYsSNGjRoVc+bMibfffjvr0QpaZWVlfPWrX43XX389fvCDH8Tv/M7vxPz58+ON\nN97IerQR4V/+5V9i48aNcd111/m35iy56qqrIpfL9fzZt29f1iMVvP/5n/+Jm2++OYqKiqKxsTHe\neuut+NrXvhbl5T5nYyj94Ac/6PVYb21tjaKiovj0pz+d9WhnlZdC/Zrf/u3fjo997GPx3HPP9ax9\n9KMfjbvvvjueeOKJDCcbGcaOHRsbNmyIz3zmM1mPMuKcOHEixo0bF9/5znfizjvvzHqcEeUjH/lI\nfOUrX4k//uM/znqUgtbZ2RkzZ86MTZs2xaOPPhrTp0+PdevWZT1WQXv00UfjhRdeEBNn2Ze+9KV4\n7bXX4rXXXst6lBHt8ccfj7/8y7+MI0eO9LxL6kjgGYtfOXXqVLS2tkZNTU2v9Zqamti9e3dGU8HZ\n8c4770R3d3d8+MMfznqUEaOrqyv+7u/+Lk6ePBm33npr1uMUvAceeCDuueeeuO2228Lv086e9vb2\nuPTSS2PKlCmxcOHC+I//+I+sRyp4L774YsyaNSs+/elPx4QJE+L666+PDRs2ZD3WiJLP52PTpk3x\nh3/4hyMqKiKERY+jR49GV1dXTJgwodd6eXn5aR/4B4Vm2bJlcf3118fs2bOzHqXg7du3Lz70oQ/F\nmDFj4oEHHojnn38+pk2blvVYBW3jxo3R3t4ea9asiYjwMqiz5KabboqtW7fGP/3TP8XGjRsjl8tF\ndXV1/PznP896tILW3t4e9fX1ceWVV8b27dtj2bJl8cUvflFcnEVNTU3xn//5nyPymegB324WKGx1\ndXWxe/fuaG5u9h+us+Cqq66Kf/3Xf43Ozs74+7//+7j33ntj586dUVVVlfVoBelHP/pR/Omf/mk0\nNzdHSUlJRPzyt4metRh6v/u7v9vz9bXXXhuzZ8+OyZMnx9atW70F/RDq7u6OWbNmxeOPPx4RETNm\nzIgDBw7Ehg0b4sEHH8x4upFh48aNMWvWrJg+fXrWo5x1wuJXxo8fHyUlJdHR0dFrvaOjIyoqKjKa\nCobWww8/HM8//3zs3LkzrrjiiqzHGRHOO++8mDJlSkREXH/99bF3797YsGFDbN68OePJCtOePXvi\n6NGjcc011/SsdXV1xWuvvRbPPfdcnDhxIs4777wMJxw5ysrK4pprrokf//jHWY9S0CZOnBhXX311\nr7WrrroqfvrTn2Y00cjys5/9LP7hH/4h6uvrsx4lE14K9SujR4+OmTNnxvbt23utNzU1RXV1dUZT\nwdBZtmxZbNu2LXbs2BEf/ehHsx5nxOrq6oru7u6sxyhYv//7vx8//OEP44033og33ngj2traoqqq\nKhYuXBhtbW2i4iw6efJk7N+/3y/rhtjNN98cb731Vq+1f//3f/fLo7Nky5YtMWbMmFi4cGHWo2TC\nMxa/pq6uLu6///6YNWtWVFdXx7PPPhu5XC6WLl2a9WgF68SJE3HgwIGI+OXTtwcPHoy2trb4yEc+\n0vPp7gy+Bx98ML75zW/Giy++GOPGjeu5jmjs2LFxwQUXZDxd4friF78Yn/zkJ2PSpElx/Pjx+Na3\nvhWvvvpqvPzyy1mPVrDe+8yQX1dWVhYf/vCHT/utLoPrkUceiXnz5kVlZWX87Gc/i9WrV8f//u//\nxmc/+9msRytoDz/8cFRXV8cTTzwRCxYsiNdffz3Wr18fTz75ZNajFbx8Ph9//dd/Hffee2+UlZVl\nPU428vRSX1+fv+KKK/Lnn39+vqqqKv/aa69lPVJB27lzZ76oqChfVFSULy4u7vl68eLFWY9W0P7v\nfr/357HHHst6tIK2aNGi/OWXX54///zz8+Xl5fk77rgjv3379qzHGnFuv/32/EMPPZT1GAXv3nvv\nzU+cODE/evTo/KWXXpq/++678/v37896rBHhpZdeys+YMSM/ZsyY/LRp0/Lr16/PeqQRYceOHfni\n4uL83r17sx4lMz7HAgAASOYaCwAAIJmwAAAAkgkLAAAgmbAAAACSCQsAACCZsAAAAJIJCwAAIJmw\nAAAAkv1/1CENiaUhvCAAAAAASUVORK5CYII=\n", "text": [ "" ] } ], "prompt_number": 10 }, { "cell_type": "markdown", "metadata": {}, "source": [ "The simple test case that we ran appears to work correctly. We initially believed that the dog was in position 3 with 100% certainty; after the movement update we now give an 80% probability to the dog being in position 5, and a 10% chance to undershooting to position 4, and a 10% chance of overshooting to position 6. Let us look at a case where we have multiple beliefs:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = np.array([0, 0, .4, .6, 0, 0, 0, 0])\n", "predict(pos_belief, 2, .8, .1, .1)\n", "print(pos_belief)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0. 0. 0. 0.04 0.38 0.52 0.06 0. ]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nfRkuh9z3sAAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 11 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Here the results are more complicated, but you should still be able to work it out in your head. The 0.04 is due to the possibility that the 0.4 belief undershot by 1. The 0.38 is due to the following: the 80% chance that we moved 2 positions $(.4 * .8)$ and the 10% chance that we undershot $(.6*.1)$. Overshooting plays no role here because if we overshot both .4 and .6 would be past this position. **I strongly suggest working some examples until all of this is very clear, as so much of what follows depends on understanding this step.**\n", "\n", "If you look at the probabilities after performing the update you probably feel dismay. In the example above we started with probabilities of .4 and .6 in two fields; after performing the update the probabilities are not only lowered, but they are strewn out across the map." ] }, { "cell_type": "code", "collapsed": false, "input": [ "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\nfRkuh9z3sAAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 12 }, { "cell_type": "markdown", "metadata": {}, "source": [ "This is not a coincidence, or the result of a carefully chosen example - it is always true of the update step. This is inevitable; if our sensor is noisy we will lose a bit of information on every update. Suppose we were to perform the update an infinite number of times - what would the result be? If we lose information on every step, we must eventually end up with no information at all, and our probabilities will be equally distributed across the `pos_belief` array. Let's try this with say 500 iterations.\n" ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = np.array([1.0, 0, 0, 0, 0, 0, 0, 0, 0, 0])\n", "for i in range (500):\n", " predict(pos_belief, 1, .8, .1, .1)\n", "print(pos_belief)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1 0.1]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nKIjbbrst16PlnYcffjgee+yxWL16dbz22muxcuXKqK+vj2XLluV6tLz0pS99KRoaGuIf/uEf4tVX\nX43q6uqYNm1aHDlyJNejpcl8hEyePDlz1113dVkbM2ZMpq6uLkcT9Q8f//jHMxs2bMj1GP3Gz3/+\n80xRUVHmmWeeyfUo/cKQIUMyf//3f5/rMfLWz372s8yll16aefHFFzPXX3995p577sn1SHnn/vvv\nz1x++eW5HqNfqKury0ydOjXXY/RbS5cuzZx//vmZEydO5HqUvHPTTTdl5syZ02XtC1/4Qub3f//3\nczRR/vq///u/zIABAzI/+MEPuqxPmjQps3jx4hxN1Tc+Ms9YnDp1Knbv3h3V1dVd1qurq2PHjh05\nmooPo+PHj0dHR0ecf/75uR4lr7W3t8d3v/vdOHHiRHzmM5/J9Th566677opbb701rrvuush4S9wZ\nNTc3x0UXXRQVFRUxe/bs+K//+q9cj5SXnn766Zg8eXLcdtttMXz48LjyyitjzZo1uR6rX8hkMvHE\nE0/EH//xH3d+nD7/3/Tp0+OFF16I1157LSIifvzjH8fWrVvjxhtvzPFk+efdd9+N9vb20/4cnXvu\nuf3+Jfq9firUh8Wbb74Z7e3tMXz48C7rw4YNO+0L/SDFggUL4sorr4wpU6bkepS8tHfv3pgyZUqc\nPHkyiouL46mnnoqxY8fmeqy89Pjjj0dzc3Ns3LgxIsLLoM7gmmuuiQ0bNsS4ceOitbU1li5dGlVV\nVbFv374YMmRIrsfLK83NzVFfXx+1tbXx1a9+Nfbs2dP5vp277747x9Plt4aGhvjv//7v+JM/+ZNc\nj5KX/uzP/ix+8pOfxCc/+ckYMGBAvPvuu7F48eLOryfg/xs8eHBMmTIlli5dGpdffnkMHz48vvOd\n78SPfvSjGDNmTK7HS/KRCQv4INTW1saOHTti+/bt/hF4BuPGjYt///d/j7a2tvinf/qnuP3222Pr\n1q1RWVmZ69HyymuvvRZf+9rXYvv27VFUVBQRv/wfU89anO73fu/3Om9ffvnlMWXKlBg9enRs2LDB\nR53/ho6Ojpg8eXI89NBDERExceLEOHjwYKxZs0ZY9OLxxx+PyZMnx4QJE3I9Sl5atWpVrFu3Lr77\n3e/G+PHjY8+ePbFgwYIYNWpU3HnnnbkeL+88+eSTceedd0Z5eXkUFRXFpEmTYvbs2fHyyy/nerQk\nH5mwGDp0aBQVFUVra2uX9dbW1igrK8vRVHyY3HvvvfHUU0/F1q1bY9SoUbkeJ2+dc845UVFRERER\nV155ZezatSvWrFkT69aty/Fk+WXnzp3x5ptvxvjx4zvX2tvb44c//GE89thj8c4778Q555yTwwnz\nV0lJSYwfPz5ef/31XI+Sd0aMGBGXXXZZl7Vx48bFG2+8kaOJ+oef/vSn8YMf/CDq6+tzPUreeuih\nh2Lx4sUxa9asiIgYP358HDp0KJYtWyYsulFRUREvvvhi/OIXv4jjx4/H8OHD47bbbotLL70016Ml\n+ci8x2LgwIExadKk2LJlS5f1hoaGqKqqytFUfFgsWLAgNm3aFC+88EL89m//dq7H6Vfa29ujo6Mj\n12PknT/4gz+IV199NV555ZV45ZVXoqmpKSorK2P27NnR1NQkKnpw4sSJ2L9/v/806sa1114bBw4c\n6LL2H//xH/4zpBfr16+Pc889N2bPnp3rUfJWJpOJwsKu/6wsLCz0LGsviouLY/jw4fHWW2/Fli1b\n4nOf+1yuR0rykXnGIuKXL1O54447YvLkyVFVVRWPPvpotLS0eP1fN9555504ePBgRPzyqfNDhw5F\nU1NT/NZv/Vbnt67zS3fffXd8+9vfjqeffjpKS0s737MzePDg+NjHPpbj6fLLX/7lX8ZNN90U5eXl\n8fbbb8fGjRvjpZdeiueeey7Xo+WdX33Xx68rKSmJ888//7T/cf6ou++++2LGjBkxcuTI+OlPfxpL\nliyJX/ziF/HFL34x16PlnXvvvTeqqqri4YcfjlmzZsWePXti9erVPhK0B5lMJr71rW/F7bffHiUl\nJbkeJ2/NnDkzvv71r8fo0aPjsssuiz179sTf/u3f+nt4Blu2bIn29vYYN25cvP766/EXf/EX8clP\nfjLmzp2b69HS5PATqXKivr4+M2rUqMygQYMylZWVmR/+8Ie5Hikvbd26NVNQUJApKCjIFBYWdt6e\nO3durkfLO7+5R7/69cADD+R6tLwzZ86czCWXXJIZNGhQZtiwYZkbbrghs2XLllyP1W/4uNnu3X77\n7ZkRI0ZkBg4cmLnooosyt9xyS2b//v25HitvPfvss5mJEydmzj333MzYsWMzq1evzvVIee2FF17I\nFBYWZnbt2pXrUfLaz3/+88yf//mfZ0aNGpUpLi7OVFRUZL72ta9lTp48mevR8tJTTz2VufTSSzOD\nBg3KlJWVZe65557M8ePHcz1WsoJMxnNUAABAmo/MeywAAID3j7AAAACSCQsAACCZsAAAAJIJCwAA\nIJmwAACMdhJLAAAAE0lEQVQAkgkLAAAgmbAAAACS/T/nedWRsLADlgAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 13 }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n", "After 500 iterations we have lost all information, even though we were 100% sure that we started in position 1. Feel free to play with the numbers to see the effect of differing number of updates. For example, after 100 updates we have a small amount of information left.\n" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "And, if you are viewing this on the web or in IPython Notebook, here is an animation of that output.\n", "" ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Integrating Measurements and Movement Updates" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The problem of losing information during an update may make it seem as if our system would quickly devolve into no knowledge. However, recall that our process is not an endless series of updates, but of *measure->update->measure->update->measure->update...* The output of the measure step is fed into the update. The update step, with a degraded certainty, is then fed into the measure step. \n", "\n", "Let's think about this intuitively. After the first measure->update round we have degraded the knowledge we gained by the measurement by a small amount. But now we take another measurement. When we try to incorporate that new measurement into our belief, do we become more certain, less certain, or equally certain. Consider a simple case - you are sitting in your office. A co-worker asks another co-worker where you are, and they report \"in his office\". You keep sitting there while they ask and answer \"has he moved\"? \"No\" \"Where is he\" \"In his office\". Eventually you get up and move, and lets say the person didn't see you move. At that time the questions will go \"Has he moved\" \"no\" (but you have!) \"Where is he\" \"In the kitchen\". Wow! At that moment the statement that you haven't moved conflicts strongly with the next measurement that you are in the kitchen. If we were modelling these with probabilities the probability that you are in your office would lowever, and the probability that you are in the kitchen would go up a little bit. But now imagine the subsequent conversation: \"has he moved\" \"no\" \"where is he\" \"in the kitchen\". Pretty quickly the belief that you are in your office would fade away, and the belief that you are in the kitchen would increase to near certainty. The belief that you are in the office will never go to zero, nor will the belief that you are in the kitchen ever go to 1.0 because of the chances of error, but in practice your co-workers would be correct to be quite confident in their system.\n", "\n", "That is what intuition tells us. What does the math tell us?\n", "\n", "Well, we have already programmed the measure step, and we have programmed the update step. All we need to do is feed the result of one into the other, and we will have programmed our dog tracker!!! Let's see how it performs. We will input data as if the dog started at position 0 and moved right at each update. However, as in a real world application, we will start with no knowledge and assign equal probability to all positions. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = np.array([.1]*10)\n", "update(pos_belief, 1, .6, .2)\n", "print(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.187 0.187 0.062 0.062 0.062 0.062 0.062 0.062 0.187 0.062]\n" ] } ], "prompt_number": 14 }, { "cell_type": "code", "collapsed": false, "input": [ "predict(pos_belief, 1, .8, .1, .1)\n", "print(pos_belief)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.087 0.175 0.175 0.075 0.062 0.062 0.062 0.062 0.075 0.162]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nFk9j9OjR0dLS0v5r586duR4pL/3sZz+LG264IQoKCmL9+vWxZ8+e+OY3vxmDBw/O9Wh56Y033ujw\n52r79u1RUFAQd911V65HyztPPPFEPP3007F8+fJ4++23Y+nSpVFXVxeLFi3K9Wh56Utf+lLU19fH\nP/zDP8Rbb70VVVVVMXny5Ghubs71aGky55AJEyZk7rvvvg5rI0eOzNTW1uZoot7hE5/4RGbNmjW5\nHqPX+PnPf54pKirKvPjii7kepVcYOHBg5u///u9zPUbe+tnPfpa54oorMq+99lrm5ptvzjzwwAO5\nHinvPPzww5mrrroq12P0CrW1tZlJkybleoxea+HChZmLLrooc/To0VyPknduu+22zMyZMzusfeEL\nX8j8/u//fo4myl//93//l+nTp0/mBz/4QYf18ePHZxYsWJCjqXrGOfOKxfHjx2P79u1RVVXVYb2q\nqiq2bNmSo6n4ODp8+HCcPHkyLrroolyPktfa2triu9/9bhw9ejRuvPHGXI+Tt+677764884746ab\nboqMt8SdVlNTU1x66aVRXl4eM2bMiP/6r//K9Uh56YUXXogJEybEXXfdFUOGDIlrrrkmVqxYkeux\neoVMJhPPPvts/PEf/3H77fT5/6ZMmRKvvvpqvP322xER8eMf/zg2btwYt956a44nyz8nTpyItra2\nU/4cnX/++b3+Ev1u7wr1cfHee+9FW1tbDBkypMP64MGDT/lAP0gxd+7cuOaaa2LixIm5HiUv7dy5\nMyZOnBjHjh2L4uLieP7552PUqFG5HisvPfPMM9HU1BRr166NiHAZ1Glcf/31sWbNmhg9enS0trbG\nwoULo7KyMnbt2hUDBw7M9Xh5pampKerq6qKmpia++tWvxo4dO9rft3P//ffneLr8Vl9fH//93/8d\nf/Inf5LrUfLSn/3Zn8VPfvKT+NSnPhV9+vSJEydOxIIFC9o/noD/r3///jFx4sRYuHBhXHXVVTFk\nyJD4zne+Ez/60Y9i5MiRuR4vyTkTFnA21NTUxJYtW2Lz5s3+J/A0Ro8eHf/+7/8ehw4din/6p3+K\nu+++OzZu3BgVFRW5Hi2vvP322/G1r30tNm/eHEVFRRHxy38x9arFqX7v936v/eurrroqJk6cGCNG\njIg1a9a41flvOHnyZEyYMCEef/zxiIgYN25c7N27N1asWCEsuvHMM8/EhAkTYuzYsbkeJS8tW7Ys\nVq1aFd/97ndjzJgxsWPHjpg7d24MHz487r333lyPl3eee+65uPfee6OsrCyKiopi/PjxMWPGjHjj\njTdyPVqScyYsBg0aFEVFRdHa2tphvbW1NUpLS3M0FR8nDz74YDz//POxcePGGD58eK7HyVvnnXde\nlJeXR0TENddcE9u2bYsVK1bEqlWrcjxZftm6dWu89957MWbMmPa1tra2+OEPfxhPP/10HDlyJM47\n77wcTpi/SkpKYsyYMfHOO+/kepS8M3To0Ljyyis7rI0ePTrefffdHE3UO/z0pz+NH/zgB1FXV5fr\nUfLW448/HgsWLIjp06dHRMSYMWNi3759sWjRImHRifLy8njttdfiF7/4RRw+fDiGDBkSd911V1xx\nxRW5Hi3JOfMei759+8b48eNjw4YNHdbr6+ujsrIyR1PxcTF37txYt25dvPrqq/Hbv/3buR6nV2lr\na4uTJ0/meoy88wd/8Afx1ltvxZtvvhlvvvlmNDY2RkVFRcyYMSMaGxtFRReOHj0au3fv9o9Gnbjh\nhhtiz549Hdb+4z/+wz+GdGP16tVx/vnnx4wZM3I9St7KZDJRWNjxfysLCwu9ytqN4uLiGDJkSLz/\n/vuxYcOG+NznPpfrkZKcM69YRPzyMpV77rknJkyYEJWVlfHUU09FS0uL6/86ceTIkdi7d29E/PKl\n83379kVjY2P81m/9VvunrvNL999/f3z729+OF154IQYMGND+np3+/fvHBRdckOPp8stf/uVfxm23\n3RZlZWXxwQcfxNq1a+P111+Pl19+Odej5Z1ffdbHryspKYmLLrrolH9xPtc99NBDMXXq1Bg2bFj8\n9Kc/jcceeyx+8YtfxBe/+MVcj5Z3HnzwwaisrIwnnngipk+fHjt27Ijly5e7JWgXMplMfOtb34q7\n7747SkpKcj1O3po2bVp8/etfjxEjRsSVV14ZO3bsiL/927/13+FpbNiwIdra2mL06NHxzjvvxF/8\nxV/Epz71qZg1a1auR0uTwztS5URdXV1m+PDhmX79+mUqKioyP/zhD3M9Ul7auHFjpqCgIFNQUJAp\nLCxs/3rWrFm5Hi3v/OYe/erXI488kuvR8s7MmTMzl19+eaZfv36ZwYMHZ2655ZbMhg0bcj1Wr+F2\ns527++67M0OHDs307ds3c+mll2buuOOOzO7du3M9Vt566aWXMuPGjcucf/75mVGjRmWWL1+e65Hy\n2quvvpopLCzMbNu2Ldej5LWf//znmT//8z/PDB8+PFNcXJwpLy/PfO1rX8scO3Ys16Plpeeffz5z\nxRVXZPpNLH2HAAAAUUlEQVT165cpLS3NPPDAA5nDhw/neqxkBZmM16gAAIA058x7LAAAgDNHWAAA\nAMmEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMn+HxOW0hpY7CSLAAAAAElFTkSuQmCC\n", "text": [ "" ] } ], "prompt_number": 15 }, { "cell_type": "markdown", "metadata": {}, "source": [ "So after the first update we have assigned a high probability to each door position, and a low probability to each wall position. The update step shifted these probabilities to the right, smearing them about a bit. Now let's look at what happens at the next sense." ] }, { "cell_type": "code", "collapsed": false, "input": [ "update(pos_belief, 1, .6, .2)\n", "print(pos_belief)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.157 0.313 0.104 0.045 0.037 0.037 0.037 0.037 0.134 0.097]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "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\nFhERlZWVUVlZ2epjK1euPGPt/vvvj/vvvz9tMgAAoNPo8HeFAgAALj3CAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\nwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMIC\nAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAA\nSCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGRZhUVVVVUMHjw4iouLo6ysLGpqato952//9m9j\n2LBh0b179+jfv3/MnTs3eVgAACA/dWnvgLVr18asWbNixYoVMXbs2Fi+fHmMHz8+fvzjH8fAgQNb\nPWf27Nnx+uuvx1//9V/HiBEj4vDhw3HgwIEOHx4AAMgP7YbF4sWLY+rUqTFt2rSIiFi6dGm88cYb\nsWLFinj22WfPOP7999+Pb37zm7Fjx44YOnRo8/rIkSM7cGwAACCftPlUqJMnT8a2bduioqKixXpF\nRUVs3ry51XP+6Z/+KUpLS2PdunVRWloagwcPjilTpsR//dd/ddzUAABAXinIZDKZsz24f//+GDBg\nQGzatCnGjh3bvP7000/HmjVrYvfu3WecM3369Fi9enV8+tOfjkWLFkVExBNPPBEREVu2bImCgoLm\nYw8fPtz89Z49e9J/GgAA4LwYMmRI89e9evU64/F2nwp1rk6fPh0nTpyIl19+OT75yU9GRMTLL78c\nQ4cOjdra2rj11ls7+pIAAECOtRkWffr0iaKiomhsbGyx3tjYGCUlJa2eU1JSEl26dGmOioiIT37y\nk1FUVBQffvjhWcOirKzsXGf/jdXW1l7wa3ZW9ip79ip79ip79urc2K/s2avs2avs2avsdca9+v/P\nNmpNm6+x6Nq1a4waNSrWr1/fYr26ujrKy8tbPWfs2LFx6tSpqK+vb16rr6+PpqamuO6667KdGwAA\n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\nnWPHjsVNN90US5YsieLiYm8j3Ia33347vvzlL8eWLVtiw4YN0aVLlxg3blx89NFHuR4t7wwcODC+\n8Y1vxPbt2+Odd96J3/3d342JEyfGu+++m+vR8tqPfvSjePHFF+Omm27y3+JZDBs2LBoaGpr/7Nix\nI9cj5aWf//zncfvtt0dBQUGsW7cudu/eHd/85jejb9++uR4tL73zzjstfq+2bdsWBQUF8eCDD+Z6\ntLzz7LPPxgsvvBDLli2L999/P5YsWRJVVVWxcOHCXI+Wl770pS9FdXV1/P3f/3289957UVFREePG\njYv9+/fnerQ0mUvI6NGjM48++miLtSFDhmTmzp2bo4k6h0984hOZ1atX53qMTuMXv/hFpqioKPPa\na6/lepROoXfv3pm/+7u/y/UYeevnP/955vrrr8+89dZbmbvuuiszY8aMXI+Ud5588snMjTfemOsx\nOoW5c+dmxo4dm+sxOq0FCxZkrrzyyszx48dzPUreuffeezNTpkxpsfaFL3wh8/u///s5mih//c//\n/E+mS5cumR/84Act1keNGpWZN29ejqbqGJfMHYuTJ0/Gtm3boqKiosV6RUVFbN68OUdTcTE6cuRI\nnD59Oq688spcj5LXmpqa4rvf/W4cP3487rjjjlyPk7ceffTReOCBB+LOO++MjJfEnVV9fX1cc801\nUVpaGpMnT47/+I//yPVIeenVV1+N0aNHx4MPPhj9+vWLm2++OZYvX57rsTqFTCYTL730UvzRH/1R\n89vp83/Gjx8fGzZsiPfffz8iIn784x/Hxo0b45577snxZPnn1KlT0dTUdMbvUffu3Tv9U/TbfVeo\ni8XBgwejqakp+vXr12K9b9++Z3ygH6SYOXNm3HzzzTFmzJhcj5KXduzYEWPGjIkTJ05EcXFxvPLK\nKzF06NBcj5WXXnzxxaivr481a9ZERHga1FncdtttsXr16hg2bFg0NjbGggULory8PHbu3Bm9e/fO\n9Xh5pb6+PqqqqmL27Nnx1a9+NbZv3978up3HHnssx9Plt+rq6vjP//zP+OM//uNcj5KX/vRP/zR+\n+tOfxqc+9ano0qVLnDp1KubNm9f88QT8n549e8aYMWNiwYIFceONN0a/fv3iO9/5TvzoRz+KIUOG\n5Hq8JJdMWMCFMHv27Ni8eXPU1NT4n8CzGDZsWPzbv/1bHD58OP7xH/8xHnroodi4cWOUlZXlerS8\n8v7778fXvva1qKmpiaKiooj41b+Yumtxpt/7vd9r/vrGG2+MMWPGxODBg2P16tXe6vzXnD59OkaP\nHh3PPPNMRESMHDky9uzZE8uXLxcW7XjxxRdj9OjRMWLEiFyPkpeWLl0aK1eujO9+97sxfPjw2L59\ne8ycOTMGDRoUjzzySK7Hyzsvv/xyPPLIIzFgwIAoKiqKUaNGxeTJk+Odd97J9WhJLpmw6NOnTxQV\nFUVjY2OL9cbGxigpKcnRVFxMHn/88XjllVdi48aNMWjQoFyPk7cuu+yyKC0tjYiIm2++ObZu3RrL\nly+PlStX5niy/LJly5Y4ePBgDB8+vHmtqakpfvjDH8YLL7wQx44di8suuyyHE+avHj16xPDhw+OD\nDz7I9Sh5p3///nHDDTe0WBs2bFh8+OGHOZqoc/jZz34WP/jBD6KqqirXo+StZ555JubNmxeTJk2K\niIjhw4fH3r17Y+HChcKiFaWlpfHWW2/FL3/5yzhy5Ej069cvHnzwwbj++utzPVqSS+Y1Fl27do1R\no0bF+vXrW6xXV1dHeXl5jqbiYjFz5sxYu3ZtbNiwIX77t3871+N0Kk1NTXH69Olcj5F3/uAP/iDe\ne++9ePfdd+Pdd9+Nurq6KCsri8mTJ0ddXZ2oaMPx48dj165d/tGoFbfffnvs3r27xdq///u/+8eQ\ndqxatSq6d+8ekydPzvUoeSuTyURhYcv/rSwsLHSXtR3FxcXRr1+/+Oijj2L9+vXxuc99LtcjJblk\n7lhE/OppKg8//HCMHj06ysvL4/nnn4+GhgbP/2vFsWPHYs+ePRHxq1vne/fujbq6uvit3/qt5k9d\n51cee+yx+Pa3vx2vvvpq9OrVq/k1Oz179ozLL788x9Pll7/4i7+Ie++9NwYMGBBHjx6NNWvWxNtv\nvx1vvPFGrkfLOx9/1sf/16NHj7jyyivP+BfnS90TTzwREyZMiIEDB8bPfvazmD9/fvzyl7+ML37x\ni7keLe88/vjjUV5eHs8++2xMmjQptm/fHsuWLfOWoG3IZDLxrW99Kx566KHo0aNHrsfJWxMnToyv\nf/3rMXjw4Ljhhhti+/bt8Td/8zf+OzyL9evXR1NTUwwbNiw++OCD+PM///P41Kc+FVOnTs31aGly\n+I5UOVFVVZUZNGhQplu3bpmysrLMD3/4w1yPlJc2btyYKSgoyBQUFGQKCwubv546dWquR8s7v75H\nH/956qmncj1a3pkyZUrmuuuuy3Tr1i3Tt2/fzN13351Zv359rsfqNLzdbOseeuihTP/+/TNdu3bN\nXHPNNZk5UhZhAAAAs0lEQVT7778/s2vXrlyPlbdef/31zMiRIzPdu3fPDB06NLNs2bJcj5TXNmzY\nkCksLMxs3bo116PktV/84heZP/uzP8sMGjQoU1xcnCktLc187Wtfy5w4cSLXo+WlV155JXP99ddn\nunXrlikpKcnMmDEjc+TIkVyPlawgk3GPCgAASHPJvMYCAAA4f4QFAACQTFgAAADJhAUAAJBMWAAA\nAMmEBQAAkExYAAAAyYQFAACQ7H8BKbjls59fh/EAAAAASUVORK5CYII=\n", "text": [ "" ] } ], "prompt_number": 16 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Notice the tall bar at position 1. This corresponds with the (correct) case of starting at position 0, sensing a door, shifting 1 to the right, and sensing another door. No other positions make this set of observations as likely. Now lets add an update and then sense the wall." ] }, { "cell_type": "code", "collapsed": false, "input": [ "predict(pos_belief, 1, .8, .1, .1)\n", "update(pos_belief, 0, .6, .2)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\nerS8c/z48bjppptiyZIlUVxc7G2E2/H222/Hl7/85di6dWts3LgxunXrFuPHj4+PPvoo16PlnUGD\nBsU3vvGN2LFjR7zzzjvxu7/7uzFp0qR49913cz1aXvvRj34UL774Ytx0003+LJ7D8OHDo7GxseXH\nzp07cz1SXvr5z38et99+exQUFMT69etjz5498c1vfjP69euX69Hy0jvvvNPq99X27dujoKAgHnzw\nwVyPlneeffbZeOGFF2LZsmXx/vvvx5IlS2LFihWxcOHCXI+Wl770pS9FTU1N/P3f/3289957UVlZ\nGePHj48DBw7kerQ0mUvImDFjMo8++mirtaFDh2bmzp2bo4m6hk984hOZNWvW5HqMLuMXv/hFpqio\nKPPaa6/lepQuoU+fPpm/+7u/y/UYeevnP/955vrrr8+89dZbmbvuuiszc+bMXI+Ud5588snMjTfe\nmOsxuoS5c+dmxo0bl+sxuqwFCxZkrrzyysyJEydyPUreuffeezNTp05ttfaFL3wh8/u///s5mih/\n/c///E+mW7dumR/84Aet1kePHp2ZN29ejqbqHJfMMxanTp2K7du3R2VlZav1ysrK2LJlS46m4uPo\n6NGjcebMmbjyyitzPUpea25uju9+97tx4sSJuOOOO3I9Tt569NFH44EHHog777wzMm6JO6eGhoa4\n5pproqysLKZMmRL/8R//keuR8tKrr74aY8aMiQcffDD69+8fN998cyxfvjzXY3UJmUwmXnrppfij\nP/qjlrfT5/+bMGFCbNy4Md5///2IiPjxj38cmzZtinvuuSfHk+Wf06dPR3Nz81m/j3r27NnlX6Lf\n4btCfVwcOnQompubo3///q3W+/Xrd9YH+kGKWbNmxc033xxjx47N9Sh5aefOnTF27Ng4efJkFBcX\nxyuvvBLDhg3L9Vh56cUXX4yGhoZYu3ZtRISXQZ3DbbfdFmvWrInhw4dHU1NTLFiwICoqKmLXrl3R\np0+fXI+XVxoaGmLFihVRXV0dX/3qV2PHjh0t9+089thjOZ4uv9XU1MR//ud/xh//8R/nepS89Kd/\n+qfx05/+ND71qU9Ft27d4vTp0zFv3ryWjyfg/+vVq1eMHTs2FixYEDfeeGP0798/vvOd78SPfvSj\nGDp0aK7HS3LJhAVcDNXV1bFly5aora31P4HnMHz48Pi3f/u3OHLkSPzjP/5jPPTQQ7Fp06YoLy/P\n9Wh55f3334+vfe1rUVtbG0VFRRHxq38x9azF2X7v936v5ec33nhjjB07NoYMGRJr1qzxVuf/x5kz\nZ2LMmDHxzDPPRETEqFGjYu/evbF8+XJh0YEXX3wxxowZEyNHjsz1KHlp6dKlsWrVqvjud78bI0aM\niB07dsSsWbNi8ODB8cgjj+R6vLzz8ssvxyOPPBIDBw6MoqKiGD16dEyZMiXeeeedXI+W5JIJi759\n+0ZRUVE0NTW1Wm9qaorS0tIcTcXHyeOPPx6vvPJKbNq0KQYPHpzrcfLWZZddFmVlZRERcfPNN8e2\nbdti+fLlsWrVqhxPll+2bt0ahw4dihEjRrSsNTc3xw9/+MN44YUX4vjx43HZZZflcML8VVJSEiNG\njIgPPvgg16PknQEDBsQNN9zQam348OHx4Ycf5miiruFnP/tZ/OAHP4gVK1bkepS89cwzz8S8efNi\n8uTJERExYsSI2LdvXyxcuFBYtKGsrCzeeuut+OUvfxlHjx6N/v37x4MPPhjXX399rkdLcsncY9G9\ne/cYPXp0bNiwodV6TU1NVFRU5GgqPi5mzZoV69ati40bN8Zv//Zv53qcLqW5uTnOnDmT6zHyzh/8\nwR/Ee++9F++++268++67UV9fH+Xl5TFlypSor68XFe04ceJE7N692z8ateH222+PPXv2tFr793//\nd/8Y0oHVq1dHz549Y8qUKbkeJW9lMpkoLGz9v5WFhYWeZe1AcXFx9O/fPz766KPYsGFDfO5zn8v1\nSEkumWcsIn71MpWHH344xowZExUVFfH8889HY2Oj1/+14fjx47F3796I+NVT5/v27Yv6+vr4rd/6\nrZZPXedXHnvssfj2t78dr776avTu3bvlnp1evXrF5ZdfnuPp8stf/MVfxL333hsDBw6MY8eOxdq1\na+Ptt9+ON954I9ej5Z1ff9bH/1ZSUhJXXnnlWf/ifKl74oknYuLEiTFo0KD42c9+FvPnz49f/vKX\n8cUvfjHXo+Wdxx9/PCoqKuLZZ5+NyZMnx44dO2LZsmXeErQdmUwmvvWtb8VDDz0UJSUluR4nb02a\nNCm+/vWvx5AhQ+KGG26IHTt2xN/8zd/4c3gOGzZsiObm5hg+fHh88MEH8ed//ufxqU99KqZNm5br\n0dLk8B2pcmLFihWZwYMHZ3r06JEpLy/P/PCHP8z1SHlp06ZNmYKCgkxBQUGmsLCw5efTpk3L9Wh5\n5//u0a9/PPXUU7keLe9MnTo1c91112V69OiR6devX+buu+/ObNiwIddjdRnebrZtDz30UGbAgAGZ\n7t27Z65pm/GqAAAAt0lEQVS55prM/fffn9m9e3eux8pbr7/+embUqFGZnj17ZoYNG5ZZtmxZrkfK\naxs3bswUFhZmtm3blutR8tovfvGLzJ/92Z9lBg8enCkuLs6UlZVlvva1r2VOnjyZ69Hy0iuvvJK5\n/vrrMz169MiUlpZmZs6cmTl69Giux0pWkMl4jgoAAEhzydxjAQAAXDjCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASPb/AN7Y5bPgh6s9AAAAAElFTkSuQmCC\n", "text": [ "" ] } ], "prompt_number": 17 }, { "cell_type": "markdown", "metadata": {}, "source": [ "This is exciting! We have a very prominent bar at position 2 with a value of around 35%. It is over twice the value of any other bar in the plot, and is about 4% larger than our last plot, where the tallest bar was around 31%. Let's see one more sense->update cycle." ] }, { "cell_type": "code", "collapsed": false, "input": [ "predict(pos_belief, 1, .8, .1, .1)\n", "update(pos_belief, 0, .6, .2)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\nRETMmjUrZs2a1eZtq1evPmPt3nvvjXvvvTdtMgAAoMvo9HeFAgAALj7CAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAA\ngGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk\nwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMIC\nAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAA\nSCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGRZhcXKlStj6NChUVxcHGVlZVFdXd3hOX/7t38b\nI0aMiJ49e8bAgQNj/vz5ycMCAAD5qVtHB6xfvz7mzp0bq1ativHjx8eKFSti4sSJ8dOf/jQGDx7c\n5jmVlZXx2muvxV//9V/HqFGj4siRI3Hw4MFOHx4AAMgPHYbFkiVLYvr06TFjxoyIiFi2bFm8/vrr\nsWrVqnjmmWfOOP69996Lb3/727Fr164YPnx4y/ro0aM7cWwAACCftPtUqFOnTsWOHTuioqKi1XpF\nRUVs3bq1zXP+6Z/+KUpLS2PDhg1RWloaQ4cOjWnTpsV//dd/dd7UAABAXinIZDKZs91YX18fgwYN\nii1btsT48eNb1p988slYt25d7N2794xzZs6cGWvXro3PfvazsXjx4oiIeOyxxyIiYtu2bVFQUNBy\n7JEjR1q+3rdvX/q9AQAAzolhw4a1fN2nT58zbu/wqVCfVHNzc5w8eTJeeuml+PSnPx0RES+99FIM\nHz48ampq4uabb+7sSwIAADnWblj069cvioqKorGxsdV6Y2NjlJSUtHlOSUlJdOvWrSUqIiI+/elP\nR1FRUXzwwQdnDYuysrJPOvv/WU1NzXm/Zldlr7Jnr7Jnr7Jnrz4Z+5U9e5U9e5U9e5W9rrhX//vZ\nRm1p9zUW3bt3jzFjxsTGjRtbrVdVVUV5eXmb54wfPz5Onz4ddXV1LWt1dXXR1NQU11xzTbZzAwAA\n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\n1OR6rGQXVVisX78+5s6dGwsWLIja2tooLy+PiRMnxoEDB3I9Wt45fvx43HDDDbF06dIoLi72NsLt\neOutt+KrX/1qbNu2LTZt2hTdunWLCRMmxIcffpjr0fLO4MGD41vf+lbs3Lkz3n777fjd3/3dmDx5\ncrzzzju5Hi2v/eQnP4kXXnghbrjhBn8Xz2LEiBHR0NDQ8mvXrl25Hikv/fKXv4xbb701CgoKYsOG\nDbF379749re/Hf3798/1aHnp7bffbvXnaseOHVFQUBD3339/rkfLO88880w8//zzsXz58njvvfdi\n6dKlsXLlyli0aFGuR8tLX/nKV6Kqqir+/u//Pt59992oqKiICRMmRH19fa5HS5O5iIwdOzbz8MMP\nt1obNmxYZv78+TmaqGv41Kc+lVm7dm2ux+gyfvWrX2WKiooyr776aq5H6RL69u2b+bu/+7tcj5G3\nfvnLX2auvfbazJtvvpm54447MrNnz871SHnn8ccfz1x//fW5HqNLmD9/fmb8+PG5HqPLWrhwYeby\nyy/PnDhxItej5J277747M23atFZrX/rSlzK///u/n6OJ8tf//M//ZLp165b50Y9+1Gp9zJgxmQUL\nFuRoqs5x0TxicerUqdixY0dUVFS0Wq+oqIitW7fmaCouREePHo3m5ua4/PLLcz1KXmtqaorvf//7\nceLEibjttttyPU7eevjhh+O+++6L22+/PTJeEndWdXV1cdVVV0VpaWlMnTo1/uM//iPXI+WlV155\nJcaOHRv3339/DBgwIG688cZYsWJFrsfqEjKZTLz44ovxR3/0Ry1vp8//N3HixNi0aVO89957ERHx\n05/+NDZv3hx33XVXjifLP6dPn46mpqYz/hz17Nmzyz9Fv8N3hbpQHDp0KJqammLAgAGt1vv373/G\nB/pBijlz5sSNN94Y48aNy/UoeWnXrl0xbty4OHnyZBQXF8fLL78cw4cPz/VYeemFF16Iurq6WLdu\nXUSEp0GdxS233BJr166NESNGRGNjYyxcuDDKy8tj9+7d0bdv31yPl1fq6upi5cqVUVlZGV//+tdj\n586dLa/beeSRR3I8XX6rqqqK//zP/4w//uM/zvUoeelP//RP4+c//3l85jOfiW7dusXp06djwYIF\nLR9PwP/Xu3fvGDduXCxcuDCuv/76GDBgQHzve9+Ln/zkJzFs2LBcj5fkogkLOB8qKytj69atUV1d\n7T+BZzFixIj4t3/7tzhy5Ej84z/+YzzwwAOxefPmKCsry/VoeeW9996Lb3zjG1FdXR1FRUUR8dFP\nTD1qcabf+73fa/n6+uuvj3HjxsXQoUNj7dq13ur8NzQ3N8fYsWPj6aefjoiI0aNHx759+2LFihXC\nogMvvPBCjB07NkaNGpXrUfLSsmXLYvXq1fH9738/Ro4cGTt37ow5c+bEkCFD4qGHHsr1eHnnpZde\nioceeigGDRoURUVFMWbMmJg6dWq8/fbbuR4tyUUTFv369YuioqJobGxstd7Y2BglJSU5mooLyaOP\nPhovv/xybN68OYYMGZLrcfLWJZdcEqWlpRERceONN8b27dtjxYoVsXr16hxPll+2bdsWhw4dipEj\nR7asNTU1xY9//ON4/vnn4/jx43HJJZfkcML81atXrxg5cmS8//77uR4l7wwcODCuu+66VmsjRoyI\nDz74IEcTdQ2/+MUv4kc/+lGsXLky16PkraeffjoWLFgQU6ZMiYiIkSNHxv79+2PRokXCog2lpaXx\n5ptvxq9//es4evRoDBgwIO6///649tprcz1akovmNRbdu3ePMWPGxMaNG1utV1VVRXl5eY6m4kIx\nZ86cWL9+fWzatCl++7d/O9fjdClNTU3R3Nyc6zHyzh/8wR/Eu+++G++880688847UVtbG2VlZTF1\n6tSora0VFe04ceJE7Nmzxw+N2nDrrbfG3r17W639+7//ux+GdGDNmjXRs2fPmDp1aq5HyVuZTCYK\nC1v/t7KwsNCjrB0oLi6OAQMGxIcffhgbN26ML3zhC7keKclF84hFxEdPU3nwwQdj7NixUV5eHs89\n91w0NDR4/l8bjh8/Hvv27YuIjx46379/f9TW1sZv/dZvtXzqOh955JFH4rvf/W688sor0adPn5bX\n7PTu3TsuvfTSHE+XX/7iL/4i7r777hg0aFAcO3Ys1q1bF2+99Va8/vrruR4t73z8WR//W69eveLy\nyy8/4yfOF7vHHnssJk2aFIMHD45f/OIX8dRTT8Wvf/3r+PKXv5zr0fLOo48+GuXl5fHMM8/ElClT\nYufOnbF8+XJvCdqOTCYT3/nOd+KBBx6IXr165XqcvDV58uT45je/GUOHDo3rrrsudu7cGX/zN3/j\n7+FZbNy4MZqammLEiBHx/vvvx5//+Z/HZz7zmZg+fXquR0uTw3ekyomVK1dmhgwZkunRo0emrKws\n8+Mf/zjXI+WlzZs3ZwoKCjIFBQWZwsLClq+nT5+e69Hyzm/u0ce/nnjiiVyPlnemTZuWueaaazI9\nevTI9O+M8tqUAAAA2ElEQVTfP3PnnXdmNm7cmOuxugxvN9u2Bx54IDNw4MBM9+7dM1dddVXm3nvv\nzezZsyfXY+Wt1157LTN69OhMz549M8OHD88sX7481yPltU2bNmUKCwsz27dvz/Uoee1Xv/pV5s/+\n7M8yQ4YMyRQXF2dKS0sz3/jGNzInT57M9Wh56eWXX85ce+21mR49emRKSkoys2fPzhw9ejTXYyUr\nyGQ8RgUAAKS5aF5jAQAAnDvCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASPb/\nAB625bXnv+L8AAAAAElFTkSuQmCC\n", "text": [ "" ] } ], "prompt_number": 18 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Here things have degraded a bit due to the long string of wall positions in the map. We cannot be as sure where we are when there is an undifferentiated line of wall positions, so naturally our probabilities spread out a bit." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Finally, for those viewing this in a Notebook or on the web, here is an animation of that algorithm.\n", "" ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "The Effect of Bad Sensor Data" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "You may be suspicious of the results above because I always passed correct sensor data into the functions. However, we are claiming that this code implements a *filter* - it should filter out bad sensor measurements. Does it do that?\n", "\n", "To make this easy to program and visualize I will change the layout of the hallway to mostly alternating doors and hallways:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "hallway = [1, 0, 1, 0, 0, 1, 0, 1, 0, 0]\n", "pos_belief = np.array([.1]*10)\n", "measurements = [1, 0, 1, 0, 0]\n", "\n", "for m in measurements:\n", " update(pos_belief, m, .6, .2)\n", " predict(pos_belief, 1, .8, .1, .1)\n", "bp.bar_plot(pos_belief)\n", "print(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[ 0.225 0.063 0.061 0.058 0.093 0.225 0.063 0.061 0.058 0.093]\n" ] }, { "metadata": {}, "output_type": "display_data", "png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAGNCAYAAACMgOcOAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAIABJREFUeJzt3X901fV9+PFXEgQTixwZgkFQiGVQEakSmUSqnh3MGdZR\ndlSUbrYgnSOzFszcYWnZcSpKLTtsQAk66wFmR4s77XE9yjzEA0oZ9IwIcUjBYbMhPZB0MAuUFTiE\n+/3DY75LCcl178C9gcfjHM4J7/v55PPK++DFJ/dXQSaTyQQAAECCwlwPAAAAdH/CAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGSdhsWGDRti0qRJMWjQoCgsLIyVK1d2+k23b98et912W5SU\nlMSgQYPiqaee6pJhAQCA/NRpWBw9ejSuv/76WLRoURQXF0dBQUGHxx8+fDjuuOOOKC0tjfr6+li0\naFEsWLAgFi5c2GVDAwAA+aXgk3zydu/evWPp0qXxpS996YzHLFu2LGpqaqK5uTl69eoVERFPP/10\nLFu2LH7+85+nTwwAAOSdLn+NxebNm+Nzn/tca1RERFRWVsa+fftiz549XX05AAAgD/To6m/Y1NQU\nV111VZu1AQMGtN529dVXt64fOnSoqy8PAACcZX369DltrcsfsejsNRgAAMD5p8vD4oorroimpqY2\na83Nza23AQAA558ufyrUuHHjYs6cOXH8+PHW11nU1dXFlVde2eZpUL+pvYdTzpb6+vqIiCgvLz9n\n1+yu7FX27FX27FX27NUnY7+yZ6+yZ6+yZ6+y1x33qrOXMWT1drMNDQ3R0NAQp06dij179kRDQ0Ps\n3bs3IiJqampiwoQJrcd/8YtfjJKSkpg2bVrs2LEjfvjDH8azzz4b1dXViT8KAACQrzoNiy1btsSN\nN94YN954Yxw7diwef/zxuPHGG+Pxxx+PiI9ekN3Y2Nh6/KWXXhp1dXWxb9++KC8vj0ceeSQee+yx\nePTRR8/eTwEAAORUp0+Fuv322+PUqVNnvH358uWnrV133XXx1ltvpU0GAAB0G13+4m0AAODCIywA\nAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIllVY1NbWxtChQ6O4uDjK\ny8tj48aNHR6/Zs2auPnmm+PSSy+Nyy+/PCZPnhy7d+/ukoEBAID802lYrF69OmbPnh1z586NhoaG\nqKioiIkTJ8bevXvbPf7999+PyZMnx+233x4NDQ3xxhtvxLFjx+LOO+/s8uEBAID80GlYLFy4MKZP\nnx4zZsyI4cOHx+LFi6O0tDSWLVvW7vENDQ1x6tSpmD9/fpSVlcXo0aNjzpw58bOf/Sz++7//u8t/\nAAAAIPc6DIsTJ07E1q1bo7Kyss16ZWVlbNq0qd1zbrnllvjUpz4VL7zwQrS0tMSRI0dixYoVMXbs\n2Ojbt2/XTQ4AAOSNgkwmkznTjfv27YtBgwbFhg0bYvz48a3rTz75ZKxatSp27drV7nmbNm2KyZMn\nx4cffhinTp2KG264If75n/85Lr/88jbHHTp0qPVrr8EAAID8NWzYsNav+/Tpc9rtXf6uUI2NjTF5\n8uSYPn161NfXx5tvvhm9e/eOKVOmRAcNAwAAdGM9OrqxX79+UVRUFM3NzW3Wm5ubo7S0tN1znn/+\n+Rg8eHA8++yzrWvf/e53Y/DgwbF58+aoqKho97zy8vJPOvv/WX19/Tm/Zndlr7Jnr7Jnr7Jnrz4Z\n+5U9e5U9e5U9e5W97rhX//vZRu3p8BGLnj17xpgxY2Lt2rVt1uvq6s4YCJlMJgoL237bj39/6tSp\nTgcGAAC6n06fClVdXR0rVqyIF198MXbu3BmzZs2KpqammDlzZkRE1NTUxIQJE1qPnzRpUmzdujWe\neuqp2L17d2zdujWmT58eV111VYwZM+bs/SQAAEDOdPhUqIiIKVOmxMGDB2PevHmxf//+GDVqVKxZ\nsyYGDx4cERFNTU3R2NjYevz48eNj9erV8c1vfjO+9a1vRUlJSYwbNy5ef/31KC4uPns/CQAAkDOd\n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\nP/nJT+KFF16I66+/3n+LZzBixIhoampq/bV9+/Zcj5SXfvnLX8Ytt9wSBQUFsWbNmti1a1d8+9vf\njv79++d6tLz09ttvt/lztXXr1igoKIj77rsv16PlnWeeeSaef/75WLJkSbz33nuxaNGiqK2tjfnz\n5+d6tLz0la98Jerq6uLv//7v4913343KysqYMGFC7Nu3L9ejpclcQMaOHZt56KGH2qwNGzYsU1NT\nk6OJuodPfepTmZUrV+Z6jG7jV7/6VaaoqCjz6quv5nqUbqFv376Zv/u7v8v1GHnrl7/8Zeaaa67J\nvPnmm5nbb78988gjj+R6pLzz+OOPZ6677rpcj9Et1NTUZMaPH5/rMbqtefPmZS677LLMsWPHcj1K\n3rnrrrsy06ZNa7P2pS99KfP7v//7OZoof/3P//xPpkePHpkf/ehHbdbHjBmTmTt3bo6m6hoXzCMW\nJ06ciK1bt0ZlZWWb9crKyti0aVOOpuJ8dPjw4Th16lRcdtlluR4lr7W0tMT3v//9OHbsWNx66625\nHidvPfTQQ3HvvffGbbfdFhkviTujxsbGuPLKK6OsrCymTp0a//Ef/5HrkfLSK6+8EmPHjo377rsv\nBgwYEDfccEMsXbo012N1C5lMJl588cX4oz/6o9a30+f/mzhxYqxbty7ee++9iIj46U9/GuvXr487\n77wzx5Pln5MnT0ZLS8tpf44uvvjibv8U/U7fFep8ceDAgWhpaYkBAwa0We/fv/9pH+gHKWbNmhU3\n3HBDjBs3Ltej5KXt27fHuHHj4vjx41FcXBwvv/xyDB8+PNdj5aUXXnghGhsbY9WqVRERngZ1Bjff\nfHOsXLkyRowYEc3NzTFv3ryoqKiIHTt2RN++fXM9Xl5pbGyM2traqK6ujq9//euxbdu21tftPPzw\nwzmeLr/V1dXFf/7nf8Yf//Ef53qUvPSnf/qn8fOf/zw+85nPRI8ePeLkyZMxd+7c1o8n4P/r3bt3\njBs3LubNmxfXXXddDBgwIL73ve/FT37ykxg2bFiux0tywYQFnAvV1dWxadOm2Lhxo/8JPIMRI0bE\nv/3bv8WhQ4fiH//xH+P++++P9evXR3l5ea5HyyvvvfdefOMb34iNGzdGUVFRRHz0L6YetTjd7/3e\n77V+fd1118W4ceNi6NChsXLlSm91/htOnToVY8eOjaeffjoiIkaPHh27d++OpUuXCotOvPDCCzF2\n7NgYNWpUrkfJS4sXL47ly5fH97///Rg5cmRs27YtZs2aFUOGDIkHH3ww1+PlnZdeeikefPDBGDRo\nUBQVFcWYMWNi6tSp8fbbb+d6tCQXTFj069cvioqKorm5uc16c3NzlJaW5mgqziePPvpovPzyy7F+\n/foYMmRIrsfJWxdddFGUlZVFRMQNN9wQW7ZsiaVLl8by5ctzPFl+2bx5cxw4cCBGjhzZutbS0hI/\n/vGP4/nnn4+jR4/GRRddlMMJ81dJSUmMHDky3n///VyPkncGDhwY1157bZu1ESNGxAcffJCjibqH\nX/ziF/GjH/0oamtrcz1K3nr66adj7ty5MWXKlIiIGDlyZOzZsyfmz58vLNpRVlYWb775Zvz617+O\nw4cPx4ABA+K+++6La665JtejJblgXmPRs2fPGDNmTKxdu7bNel1dXVRUVORoKs4Xs2bNitWrV8e6\ndevit3/7t3M9TrfS0tISp06dyvUYeecP/uAP4t1334133nkn3nnnnWhoaIjy8vKYOnVqNDQ0iIoO\nHDt2LHbu3Okfjdpxyy23xK5du9qs/fu//7t/DOnEihUr4uKLL46pU6fmepS8lclkorCw7f9WFhYW\nepS1E8XFxTFgwID48MMPY+3atfGFL3wh1yMluWAesYj46GkqDzzwQIwdOzYqKiriueeei6amJs//\na8fRo0dj9+7dEfHRQ+d79uyJhoaG+K3f+q3WT13nIw8//HB897vfjVdeeSX69OnT+pqd3r17xyWX\nXJLj6fLLX/zFX8Rdd90VgwYNiiNHjsSqVavirbfeitdffz3Xo+Wdjz/r438rKSmJyy677LR/cb7Q\nPfbYYzFp0qQYPHhw/OIXv4innnoqfv3rX8eXv/zlXI+Wdx599NGoqKiIZ555JqZMmRLbtm2LJUuW\neEvQDmQymfjOd74T999/f5SUlOR6nLw1efLk+OY3vxlDhw6Na6+9NrZt2xZ/8zd/47/DM1i7dm20\ntLTEiBEj4v33348///M/j8985jMxffr0XI+WJofvSJUTtbW1mSFDhmR69eqVKS8vz/z4xz/O9Uh5\naf369ZmCgoJMQUFBprCwsPXr6dOn53q0vPObe/TxryeeeCLXo+WdadOmZa6++upMr169Mv3798/c\ncccdmbVr1+Z6rG7D28227/77788MHDgw07Nnz8yVV16ZueeeezI7d+7M9Vh567XXXsuMHj06c/HF\nF2eGDx+eWbJkSa5Hymvr1q3LFBYWZrZs2ZLrUfLar371q8yf/dmfZYYMGZIpLi7OlJWVZb7xjW9k\njh8/nuv0gQo+AAAAXklEQVTR8tLLL7+cueaaazK9evXKlJaWZh555JHM4cOHcz1WsoJMxmNUAABA\nmgvmNRYAAMDZIywAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk/w/4f+M2RB4y\n2gAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 19 }, { "cell_type": "markdown", "metadata": {}, "source": [ "At this point we have correctly identified the likely cases, we either started at position 0 or 5, because we saw the following sequence of doors and walls 1,0,1,0,0. But now lets inject a bad measurement, and see what happens:\n" ] }, { "cell_type": "code", "collapsed": false, "input": [ "update(pos_belief, m, .6, .2)\n", "predict(pos_belief, 1, .8, .1, .1)\n", "bp.bar_plot(pos_belief)" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\n++yzce211/p/8TRGjRoVTU1NbX927dqV65Hy0s9+9rO46aaboqCgIDZs2BB79+6Nb37zmzFw4MBc\nj5aX3nzzzXb/Xe3YsSMKCgrinnvuyfVoeefJJ5+MZ555JlasWBHvvPNOLFu2LGpqamLx4sW5Hi0v\nfelLX4ra2tr4h3/4h3j77bejsrIyJk2aFI2NjbkeLU3mPDJ+/PjMAw880G5txIgRmfnz5+doop7h\nE5/4RGbt2rW5HqPH+PnPf54pKirKvPTSS7kepUfo379/5u///u9zPUbe+tnPfpa56qqrMq+//nrm\n1ltvzTz00EO5HinvPProo5lrrrkm12P0CPPnz89MnDgx12P0WIsWLcpccsklmWPHjuV6lLxzxx13\nZGbMmNFu7Qtf+ELm93//93M0Uf76v//7v0yvXr0yP/jBD9qtjxs3LrNgwYIcTdU9zptHLE6cOBE7\nduyIysrKduuVlZWxdevWHE3FuejIkSPR2toal1xySa5HyWstLS3x3e9+N44dOxY333xzrsfJWw88\n8EDcfffdccstt0TGS+JOq6GhIS6//PIoKyuL6dOnx3/913/leqS89OKLL8b48ePjnnvuiUGDBsV1\n110XK1euzPVYPUImk4nnnnsu/viP/7jt7fT5/yZPnhyvvfZavPPOOxER8eMf/zg2bdoUt99+e44n\nyz8nT56MlpaWU/47uvDCC3v8U/S7fFeoc8X7778fLS0tMWjQoHbrAwcOPOUD/SDFnDlz4rrrrosJ\nEybkepS8tGvXrpgwYUIcP348iouL44UXXoiRI0fmeqy89Oyzz0ZDQ0OsW7cuIsLToE7jxhtvjLVr\n18aoUaOiubk5Fi1aFBUVFbF79+7o379/rsfLKw0NDVFTUxPV1dXx1a9+NXbu3Nn2up0HH3wwx9Pl\nt9ra2vjv//7v+JM/+ZNcj5KX/uzP/ix+8pOfxKc+9ano1atXnDx5MhYsWND28QT8f3379o0JEybE\nokWL4pprrolBgwbFd77znfjRj34UI0aMyPV4Sc6bsICzobq6OrZu3RpbtmzxS+BpjBo1Kv793/89\nDh8+HP/0T/8U9957b2zatCnKy8tzPVpeeeedd+JrX/tabNmyJYqKiiLio38x9ajFqX7v936v7etr\nrrkmJkyYEMOHD4+1a9d6q/Nf09raGuPHj48nnngiIiLGjh0b+/bti5UrVwqLLjz77LMxfvz4GDNm\nTK5HyUvLly+P1atXx3e/+90YPXp07Ny5M+bMmRPDhg2L+++/P9fj5Z3nn38+7r///hgyZEgUFRXF\nuHHjYvr06fHmm2/merQk501YDBgwIIqKiqK5ubndenNzc5SWluZoKs4lDz/8cLzwwguxadOmGDZs\nWK7HyVsXXHBBlJWVRUTEddddF9u3b4+VK1fG6tWrczxZftm2bVu8//77MXr06La1lpaW+OEPfxjP\nPPNMHD16NC644IIcTpi/SkpKYvTo0fHuu+/mepS8M3jw4Lj66qvbrY0aNSree++9HE3UM/z0pz+N\nH/zgB1FTU5PrUfLWE088EQsWLIhp06ZFRMTo0aNj//79sXjxYmHRgbKysnj99dfjF7/4RRw5ciQG\nDRoU99xzT1x11VW5Hi3JefMai969e8e4ceNi48aN7dZra2ujoqIiR1NxrpgzZ06sX78+Xnvttfjt\n3/7tXI/To7S0tERra2uux8g7f/AHfxBvv/12vPXWW/HWW29FfX19lJeXx/Tp06O+vl5UdOLYsWOx\nZ88e/2jUgZtuuin27t3bbu0//uM//GNIF9asWRMXXnhhTJ8+Pdej5K1MJhOFhe1/rSwsLPQoaxeK\ni4tj0KBB8cEHH8TGjRvjc5/7XK5HSnLePGIR8dHTVO67774YP358VFRUxNNPPx1NTU2e/9eBo0eP\nxr59+yLio4fO9+/fH/X19fFbv/VbbZ+6zkcefPDB+Pa3vx0vvvhi9OvXr+01O3379o2LLroox9Pl\nl7/8y7+MO+64I4YMGRIffvhhrFu3Lt5444145ZVXcj1a3vnlZ338qpKSkrjkkktO+Rfn890jjzwS\nU6ZMiaFDh8ZPf/rTWLhwYfziF7+IL37xi7keLe88/PDDUVFREU8++WRMmzYtdu7cGStWrPCWoJ3I\nZDLxrW99K+69994oKSnJ9Th5a+rUqfH1r389hg8fHldffXXs3Lkz/vZv/9b/h6excePGaGlpiVGj\nRsW7774bf/EXfxGf+tSnYubMmbkeLU0O35EqJ2pqajLDhg3L9OnTJ1NeXp754Q9/mOuR8tKmTZsy\nBQUFmYKCgkxhYWHb1zNnzsz1aHnn1/fol38ee+yxXI+Wd2bMmJG58sorM3369MkMHDgwc9ttt2U2\nbtyY67F6DG8327F77703M3jw4Ezv3r0zl19+eeauu+7K7NmzJ9dj5a2XX345M3bs2MyFF16YGTly\nZGbFihW5Himvvfbaa5nCwsLM9u3bcz1KXvv5z3+e+fM///PMsGHDMsXFxZmysrLM1772tczx48dz\nPVpeeuEge0CfAAAAWklEQVSFFzJXXXVVpk+fPpnS0tLMQw89lDly5Eiux0pWkMl4jAoAAEhz3rzG\nAgAAOHOEBQAAkExYAAAAyYQFAACQTFgAAADJhAUAAJBMWAAAAMmEBQAAkOz/AcPg0hjKRQE2AAAA\nAElFTkSuQmCC\n", "text": [ "" ] } ], "prompt_number": 20 }, { "cell_type": "markdown", "metadata": {}, "source": [ "That one bad measurment appears to have significantly eroded our knowledge. However, note that our highest probabilities are still at 0 and 5, which is correct. Now let's continue with a series of correct measurements" ] }, { "cell_type": "code", "collapsed": false, "input": [ "measurements = [0, 1, 0, 1, 0, 0]\n", "\n", "for i,m in enumerate(measurements):\n", " update(pos_belief, m, .6, .2)\n", " predict(pos_belief, 1, .8, .1, .1)\n", " plt.subplot(3, 2, i+1)\n", " bp.bar_plot(pos_belief, title='step{}'.format(i+1))" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\nQmCC\n", "text": [ "" ] } ], "prompt_number": 21 }, { "cell_type": "markdown", "metadata": {}, "source": [ "As you can see we quickly filtered out the bad sensor reading and converged on the most likely positions for our dog." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Drawbacks and Limitations" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Do not be mislead by the simplicity of the examples I chose. This is a robust and complete implementation of a histogram filter, and you may use the code in real world solutions. If you need a multimodal, discrete filter, this filter works.\n", "\n", "With that said, while this filter is used in industry, it is not used often because it has several limitations. Getting around those limitations is the motivation behind the chapters in the rest of this book.\n", "\n", "The first problem is scaling. Our dog tracking problem used only one variable, $pos$, to denote the dog's position. Most interesting problems will want to track several things in a large space. Realistically, at a minimum we would want to track our dogs $(x,y)$ coordinate, and probably his velocity $(\\dot{x},\\dot{y})$ as well. We have not covered the multidimensional case, but instead of a histogram we use a multidimensional grid to store the probabilities at each discrete location. Each *sense()* and *update()* step requires updating all values in the grid, so a simple four variable problem would require $O(n^4)$ running time *per time step*. Realistic filters have 10 or more variables to track, leading to exhorbinant computation requirements.\n", "\n", "The second problem is that the histogram is discrete, but we live in a continuous world. The histogram requires that you model the output of your filter as a set of discrete points. In our dog in the hallway example, we used 10 positions, which is obviously far too few positions for anything but a toy problem. For example, for a 100 meter hallway you would need 10,000 positions to model the hallway to 1cm accuracy. So each sense and update operation would entail performing calculations for 10,000 different probabilities. It gets exponentially worse as we add dimensions. If our dog was roaming in a $100x100 m^2$ courtyard, we would need 100,000,000 bins ($10,000^2$) to get 1cm accuracy.\n", "\n", "A third problem is that the histogram is multimodal. This is not always a problem - an entire class of filters, the particle filters, are multimodal and are often used because of this property. But imagine if the GPS in your car reported to you that it is 40% sure that you are on D street, but 30% sure you are on Willow Avenue. I doubt that you would find that useful. Also, GPSs report their error - they might report that you are at $(109.878W, 38.326N)$ with an error of $9m$. There is no clear mathematical way to extract error information from a histogram. Heuristics suggest themselves to be sure, but there is no exact determination. You may or may not care about that while driving, but you surely do care if you are trying to send a rocket to Mars or track and hit an oncoming missle.\n", "\n", "This difficulty is related to the fact that the filter often does not represent what is physically occuring in the world. Consider this distribution for our dog:" ] }, { "cell_type": "code", "collapsed": false, "input": [ "pos_belief = [0.2245871, 0.06288015, 0.06109133, 0.0581008, 0.09334062, \n", " 0.2245871, 0.06288015, 0.06109133, 0.0581008, 0.09334062]\n", "bp.bar_plot(pos_belief) " ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAGNCAYAAACMgOcOAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAIABJREFUeJzt3X901fV9+PFXEgQTixwZgkFQiGVQEakSmUSqnh3MGdZR\ndlSUbrYgnSOzFszcYWnZcSpKLTtsQAk66wFmR4s77XE9yjzEA0oZ9IwIcUjBYbMhPZB0MAuUFTiE\n+/3DY75LCcl178C9gcfjHM4J7/v55PPK++DFJ/dXQSaTyQQAAECCwlwPAAAAdH/CAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGSdhsWGDRti0qRJMWjQoCgsLIyVK1d2+k23b98et912W5SU\nlMSgQYPiqaee6pJhAQCA/NRpWBw9ejSuv/76WLRoURQXF0dBQUGHxx8+fDjuuOOOKC0tjfr6+li0\naFEsWLAgFi5c2GVDAwAA+aXgk3zydu/evWPp0qXxpS996YzHLFu2LGpqaqK5uTl69eoVERFPP/10\nLFu2LH7+85+nTwwAAOSdLn+NxebNm+Nzn/tca1RERFRWVsa+fftiz549XX05AAAgD/To6m/Y1NQU\nV111VZu1AQMGtN529dVXt64fOnSoqy8PAACcZX369DltrcsfsejsNRgAAMD5p8vD4oorroimpqY2\na83Nza23AQAA558ufyrUuHHjYs6cOXH8+PHW11nU1dXFlVde2eZpUL+pvYdTzpb6+vqIiCgvLz9n\n1+yu7FX27FX27FX27NUnY7+yZ6+yZ6+yZ6+y1x33qrOXMWT1drMNDQ3R0NAQp06dij179kRDQ0Ps\n3bs3IiJqampiwoQJrcd/8YtfjJKSkpg2bVrs2LEjfvjDH8azzz4b1dXViT8KAACQrzoNiy1btsSN\nN94YN954Yxw7diwef/zxuPHGG+Pxxx+PiI9ekN3Y2Nh6/KWXXhp1dXWxb9++KC8vj0ceeSQee+yx\nePTRR8/eTwEAAORUp0+Fuv322+PUqVNnvH358uWnrV133XXx1ltvpU0GAAB0G13+4m0AAODCIywA\nAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACA\nZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTC\nAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIA\nAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABI\nJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYs\nAACAZMICAABIJiwAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIllVY1NbWxtChQ6O4uDjK\ny8tj48aNHR6/Zs2auPnmm+PSSy+Nyy+/PCZPnhy7d+/ukoEBAID802lYrF69OmbPnh1z586NhoaG\nqKioiIkTJ8bevXvbPf7999+PyZMnx+233x4NDQ3xxhtvxLFjx+LOO+/s8uEBAID80GlYLFy4MKZP\nnx4zZsyI4cOHx+LFi6O0tDSWLVvW7vENDQ1x6tSpmD9/fpSVlcXo0aNjzpw58bOf/Sz++7//u8t/\nAAAAIPc6DIsTJ07E1q1bo7Kyss16ZWVlbNq0qd1zbrnllvjUpz4VL7zwQrS0tMSRI0dixYoVMXbs\n2Ojbt2/XTQ4AAOSNgkwmkznTjfv27YtBgwbFhg0bYvz48a3rTz75ZKxatSp27drV7nmbNm2KyZMn\nx4cffhinTp2KG264If75n/85Lr/88jbHHTp0qPVrr8EAAID8NWzYsNav+/Tpc9rtXf6uUI2NjTF5\n8uSYPn161NfXx5tvvhm9e/eOKVOmRAcNAwAAdGM9OrqxX79+UVRUFM3NzW3Wm5ubo7S0tN1znn/+\n+Rg8eHA8++yzrWvf/e53Y/DgwbF58+aoqKho97zy8vJPOvv/WX19/Tm/Zndlr7Jnr7Jnr7Jnrz4Z\n+5U9e5U9e5U9e5W97rhX//vZRu3p8BGLnj17xpgxY2Lt2rVt1uvq6s4YCJlMJgoL237bj39/6tSp\nTgcGAAC6n06fClVdXR0rVqyIF198MXbu3BmzZs2KpqammDlzZkRE1NTUxIQJE1qPnzRpUmzdujWe\neuqp2L17d2zdujWmT58eV111VYwZM+bs/SQAAEDOdPhUqIiIKVOmxMGDB2PevHmxf//+GDVqVKxZ\nsyYGDx4cERFNTU3R2NjYevz48eNj9erV8c1vfjO+9a1vRUlJSYwbNy5ef/31KC4uPns/CQAAkDOd\n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\nP/nJT+KFF16I66+/3n+LZzBixIhoampq/bV9+/Zcj5SXfvnLX8Ytt9wSBQUFsWbNmti1a1d8+9vf\njv79++d6tLz09ttvt/lztXXr1igoKIj77rsv16PlnWeeeSaef/75WLJkSbz33nuxaNGiqK2tjfnz\n5+d6tLz0la98Jerq6uLv//7v4913343KysqYMGFC7Nu3L9ejpclcQMaOHZt56KGH2qwNGzYsU1NT\nk6OJuodPfepTmZUrV+Z6jG7jV7/6VaaoqCjz6quv5nqUbqFv376Zv/u7v8v1GHnrl7/8Zeaaa67J\nvPnmm5nbb78988gjj+R6pLzz+OOPZ6677rpcj9Et1NTUZMaPH5/rMbqtefPmZS677LLMsWPHcj1K\n3rnrrrsy06ZNa7P2pS99KfP7v//7OZoof/3P//xPpkePHpkf/ehHbdbHjBmTmTt3bo6m6hoXzCMW\nJ06ciK1bt0ZlZWWb9crKyti0aVOOpuJ8dPjw4Th16lRcdtlluR4lr7W0tMT3v//9OHbsWNx66625\nHidvPfTQQ3HvvffGbbfdFhkviTujxsbGuPLKK6OsrCymTp0a//Ef/5HrkfLSK6+8EmPHjo377rsv\nBgwYEDfccEMsXbo012N1C5lMJl588cX4oz/6o9a30+f/mzhxYqxbty7ee++9iIj46U9/GuvXr487\n77wzx5Pln5MnT0ZLS8tpf44uvvjibv8U/U7fFep8ceDAgWhpaYkBAwa0We/fv/9pH+gHKWbNmhU3\n3HBDjBs3Ltej5KXt27fHuHHj4vjx41FcXBwvv/xyDB8+PNdj5aUXXnghGhsbY9WqVRERngZ1Bjff\nfHOsXLkyRowYEc3NzTFv3ryoqKiIHTt2RN++fXM9Xl5pbGyM2traqK6ujq9//euxbdu21tftPPzw\nwzmeLr/V1dXFf/7nf8Yf//Ef53qUvPSnf/qn8fOf/zw+85nPRI8ePeLkyZMxd+7c1o8n4P/r3bt3\njBs3LubNmxfXXXddDBgwIL73ve/FT37ykxg2bFiux0tywYQFnAvV1dWxadOm2Lhxo/8JPIMRI0bE\nv/3bv8WhQ4fiH//xH+P++++P9evXR3l5ea5HyyvvvfdefOMb34iNGzdGUVFRRHz0L6YetTjd7/3e\n77V+fd1118W4ceNi6NChsXLlSm91/htOnToVY8eOjaeffjoiIkaPHh27d++OpUuXCotOvPDCCzF2\n7NgYNWpUrkfJS4sXL47ly5fH97///Rg5cmRs27YtZs2aFUOGDIkHH3ww1+PlnZdeeikefPDBGDRo\nUBQVFcWYMWNi6tSp8fbbb+d6tCQXTFj069cvioqKorm5uc16c3NzlJaW5mgqziePPvpovPzyy7F+\n/foYMmRIrsfJWxdddFGUlZVFRMQNN9wQW7ZsiaVLl8by5ctzPFl+2bx5cxw4cCBGjhzZutbS0hI/\n/vGP4/nnn4+jR4/GRRddlMMJ81dJSUmMHDky3n///VyPkncGDhwY1157bZu1ESNGxAcffJCjibqH\nX/ziF/GjH/0oamtrcz1K3nr66adj7ty5MWXKlIiIGDlyZOzZsyfmz58vLNpRVlYWb775Zvz617+O\nw4cPx4ABA+K+++6La665JtejJblgXmPRs2fPGDNmTKxdu7bNel1dXVRUVORoKs4Xs2bNitWrV8e6\ndevit3/7t3M9TrfS0tISp06dyvUYeecP/uAP4t1334133nkn3nnnnWhoaIjy8vKYOnVqNDQ0iIoO\nHDt2LHbu3Okfjdpxyy23xK5du9qs/fu//7t/DOnEihUr4uKLL46pU6fmepS8lclkorCw7f9WFhYW\nepS1E8XFxTFgwID48MMPY+3atfGFL3wh1yMluWAesYj46GkqDzzwQIwdOzYqKiriueeei6amJs//\na8fRo0dj9+7dEfHRQ+d79uyJhoaG+K3f+q3WT13nIw8//HB897vfjVdeeSX69OnT+pqd3r17xyWX\nXJLj6fLLX/zFX8Rdd90VgwYNiiNHjsSqVavirbfeitdffz3Xo+Wdjz/r438rKSmJyy677LR/cb7Q\nPfbYYzFp0qQYPHhw/OIXv4innnoqfv3rX8eXv/zlXI+Wdx599NGoqKiIZ555JqZMmRLbtm2LJUuW\neEvQDmQymfjOd74T999/f5SUlOR6nLw1efLk+OY3vxlDhw6Na6+9NrZt2xZ/8zd/47/DM1i7dm20\ntLTEiBEj4v33348///M/j8985jMxffr0XI+WJofvSJUTtbW1mSFDhmR69eqVKS8vz/z4xz/O9Uh5\naf369ZmCgoJMQUFBprCwsPXr6dOn53q0vPObe/TxryeeeCLXo+WdadOmZa6++upMr169Mv3798/c\ncccdmbVr1+Z6rG7D28227/77788MHDgw07Nnz8yVV16ZueeeezI7d+7M9Vh567XXXsuMHj06c/HF\nF2eGDx+eWbJkSa5Hymvr1q3LFBYWZrZs2ZLrUfLar371q8yf/dmfZYYMGZIpLi7OlJWVZb7xjW9k\njh8/nuv0gQo+AAAAXklEQVTR8tLLL7+cueaaazK9evXKlJaWZh555JHM4cOHcz1WsoJMxmNUAABA\nmgvmNRYAAMDZIywAAIBkwgIAAEgmLAAAgGTCAgAASCYsAACAZMICAABIJiwAAIBk/w/4f+M2RB4y\n2gAAAABJRU5ErkJggg==\n", "text": [ "" ] } ], "prompt_number": 22 }, { "cell_type": "markdown", "metadata": {}, "source": [ " The largest probabilities are in position 0 and position 5. This does not fit our physical intuition at all. A dog cannot be in two places at once (my dog Simon certainly tries - his food bowl and my lap often have equal allure to him). We would have to use heuristics to decide how to interpret this distribution, and there is usually no satisfactory answer. This is not always a weakness - a considerable amount of literature has been written on *Multi-Hypothesis Tracking (MHT)*. We cannot always distill our knowledge to one conclusion, and MHT uses various techniques to maintain multiple story lines at once, using backtracking schemes to go *back in time* to correct hypothesis once more information is known. This will be the subject of later chapters. In other cases we truly have a multimodal situation - we may be optically tracking pedestrians on the street and need to represent all of their positions. \n", " \n", "In practice it is the exponential increase in computation time that leads to the discrete Bayes filter being the least frequently used of all filters in this book. Many problems are best formulated as discrete or multimodal, but we have other filter choices with better performance. With that said, if I had a small problem that this technique could handle I would choose to use it; it is trivial to implement, debug, and understand, all virtues in my book." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Generalizing to Multiple Dimensions" ] }, { "cell_type": "markdown", "metadata": {}, "source": [] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Summary" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The code is very small, but the result is huge! We will go into the math more later, but we have implemented a form of a Bayesian filter. It is commonly called a Histogram filter. The Kalman filter is also a Bayesian filter, and uses this same logic to produce its results. The math is a bit more complicated, but not by much. For now, we will just explain that Bayesian statistics compute the likelihood of the present based on the past. If we know there are two doors in a row, and the sensor reported two doors in a row, it is likely that we are positioned near those doors. Bayesian statistics just formalize that example, and Bayesian filters formalize filtering data based on that math by implementing the sense->update->sense->update process. \n", "\n", "We have learned how to start with no information and derive information from noisy sensors. Even though our sensors are very noisy (most sensors are more than 80% accurate, for example) we quickly converge on the most likely position for our dog. We have learned how the update step always degrades our knowledge, but the addition of another measurement, even when it might have noise in it, improves our knowledge, allowing us to converge on the most likely result.\n", "\n", "If you followed the math carefully you will realize that all of this math is exact. The bar charts that we are displaying are not an *estimate* or *guess* - they are mathematically exact results that exactly represent our knowledge. The knowledge is probabilistic, to be sure, but it is exact, and correct.\n", "\n", "However, we are a long way from tracking an airplane or a car. This code only handles the 1 dimensional case, whereas cars and planes operate in 2 or 3 dimensions. Also, our position vector is *multimodal*. It expresses multiple beliefs at once. Imagine if your GPS told you \"it's 20% likely that you are here, but 10% likely that you are on this other road, and 5% likely that you are at one of 14 other locations\". That would not be very useful information. Also, the data is discrete. We split an area into 10 (or whatever) different locations, whereas in most real world applications we want to work with continuous data. We want to be able to represent moving 1 km, 1 meter, 1 mm, or any arbitrary amount, such as 2.347 cm. \n", "\n", "Finally, the bar charts may strike you as being a bit less certain than we would want. A 25% certaintly may not give you a lot of confidence in the answer. Of course, what is important here is the ratio of this probability to the other probabilities in your vector. If the next largest bar is 23% then we are not very knowledgable about our position, whereas if the next largest is 3% we are in fact quite certain. But this is not clear or intuitive. However, there is an extremely important insight that Kalman filters implement that will signficantly improve our accuracy from the same data.\n", "\n", "\n", "**If you can understand this chapter you will be able to understand and implement Kalman filters.** I cannot stress this enough. If anything is murky, go back and reread this chapter and play with the code. The rest of this book will build on the algorithms that we use here. If you don't intuitively understand why this histogram filter works, and can't at least work through the math, you will have little success with the rest of the material. However, if you grasp the fundamental insight - multiplying probabilities when we measure, and shifting probabilities when we update, leading to a converging solution - then you understand everything important you need to grasp the Kalman filter. " ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "References" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ " * [1] D. Fox, W. Burgard, and S. Thrun. \"Monte carlo localization: Efficient position estimation for mobile robots.\" In *Journal of Artifical Intelligence Research*, 1999.\n", " \n", " http://www.cs.cmu.edu/afs/cs/project/jair/pub/volume11/fox99a-html/jair-localize.html\n", "\n", "\n", " * [2] Dieter Fox, et. al. \"Bayesian Filters for Location Estimation\". In *IEEE Pervasive Computing*, September 2003.\n", " \n", " http://swarmlab.unimaas.nl/wp-content/uploads/2012/07/fox2003bayesian.pdf\n", " \n", " \n", " * [3] Sebastian Thrun. \"Artificial Intelligence for Robotics\".\n", " \n", " https://www.udacity.com/course/cs373\n", " \n", " " ] } ], "metadata": {} } ] }