Reasoning over Time  Often, we want to reason about a sequence of observations  Speech recognition  Robot localization  User attention  Medical monitoring.

Slides:



Advertisements
Similar presentations
Lirong Xia Probabilistic reasoning over time Tue, March 25, 2014.
Advertisements

Dynamic Bayesian Networks (DBNs)
Lirong Xia Hidden Markov Models Tue, March 28, 2014.
Lirong Xia Approximate inference: Particle filter Tue, April 1, 2014.
Hidden Markov Models Reading: Russell and Norvig, Chapter 15, Sections
Advanced Artificial Intelligence
Bayes Filters Pieter Abbeel UC Berkeley EECS Many slides adapted from Thrun, Burgard and Fox, Probabilistic Robotics TexPoint fonts used in EMF. Read the.
1 Reasoning Under Uncertainty Over Time CS 486/686: Introduction to Artificial Intelligence Fall 2013.
QUIZ!!  T/F: Rejection Sampling without weighting is not consistent. FALSE  T/F: Rejection Sampling (often) converges faster than Forward Sampling. FALSE.
HMMs Tamara Berg CS Artificial Intelligence Many slides throughout the course adapted from Svetlana Lazebnik, Dan Klein, Stuart Russell, Andrew.
… Hidden Markov Models Markov assumption: Transition model:
10/28 Temporal Probabilistic Models. Temporal (Sequential) Process A temporal process is the evolution of system state over time Often the system state.
CS 188: Artificial Intelligence Fall 2009 Lecture 20: Particle Filtering 11/5/2009 Dan Klein – UC Berkeley TexPoint fonts used in EMF. Read the TexPoint.
CS 188: Artificial Intelligence Spring 2007 Lecture 14: Bayes Nets III 3/1/2007 Srini Narayanan – ICSI and UC Berkeley.
CS 188: Artificial Intelligence Fall 2006 Lecture 17: Bayes Nets III 10/26/2006 Dan Klein – UC Berkeley.
CPSC 322, Lecture 32Slide 1 Probability and Time: Hidden Markov Models (HMMs) Computer Science cpsc322, Lecture 32 (Textbook Chpt 6.5) March, 27, 2009.
Announcements Homework 8 is out Final Contest (Optional)
CPSC 422, Lecture 14Slide 1 Intelligent Systems (AI-2) Computer Science cpsc422, Lecture 14 Feb, 4, 2015 Slide credit: some slides adapted from Stuart.
CS 188: Artificial Intelligence Fall 2009 Lecture 19: Hidden Markov Models 11/3/2009 Dan Klein – UC Berkeley.
CS 188: Artificial Intelligence Fall 2009 Lecture 18: Decision Diagrams 10/29/2009 Dan Klein – UC Berkeley.
CHAPTER 15 SECTION 3 – 4 Hidden Markov Models. Terminology.
CS 188: Artificial Intelligence Fall 2008 Lecture 18: Decision Diagrams 10/30/2008 Dan Klein – UC Berkeley 1.
QUIZ!!  T/F: The forward algorithm is really variable elimination, over time. TRUE  T/F: Particle Filtering is really sampling, over time. TRUE  T/F:
CSE 573: Artificial Intelligence Autumn 2012
Simultaneous Localization and Mapping Presented by Lihan He Apr. 21, 2006.
Recap: Reasoning Over Time  Stationary Markov models  Hidden Markov models X2X2 X1X1 X3X3 X4X4 rainsun X5X5 X2X2 E1E1 X1X1 X3X3 X4X4 E2E2 E3E3.
CS 188: Artificial Intelligence Fall 2008 Lecture 19: HMMs 11/4/2008 Dan Klein – UC Berkeley 1.
CHAPTER 15 SECTION 1 – 2 Markov Models. Outline Probabilistic Inference Bayes Rule Markov Chains.
CS 188: Artificial Intelligence Fall 2006 Lecture 18: Decision Diagrams 10/31/2006 Dan Klein – UC Berkeley.
UIUC CS 498: Section EA Lecture #21 Reasoning in Artificial Intelligence Professor: Eyal Amir Fall Semester 2011 (Some slides from Kevin Murphy (UBC))
Announcements  Project 3 will be posted ASAP: hunting ghosts with sonar.
Bayes’ Nets: Sampling [These slides were created by Dan Klein and Pieter Abbeel for CS188 Intro to AI at UC Berkeley. All CS188 materials are available.
CS 416 Artificial Intelligence Lecture 17 Reasoning over Time Chapter 15 Lecture 17 Reasoning over Time Chapter 15.
CHAPTER 8 DISCRIMINATIVE CLASSIFIERS HIDDEN MARKOV MODELS.
CSE 473: Artificial Intelligence Spring 2012 Reasoning about Uncertainty & Hidden Markov Models Daniel Weld Many slides adapted from Dan Klein, Stuart.
The famous “sprinkler” example (J. Pearl, Probabilistic Reasoning in Intelligent Systems, 1988)
QUIZ!!  In HMMs...  T/F:... the emissions are hidden. FALSE  T/F:... observations are independent given no evidence. FALSE  T/F:... each variable X.
Probabilistic reasoning over time Ch. 15, 17. Probabilistic reasoning over time So far, we’ve mostly dealt with episodic environments –Exceptions: games.
CS 188: Artificial Intelligence Bayes Nets: Approximate Inference Instructor: Stuart Russell--- University of California, Berkeley.
CPS 170: Artificial Intelligence Markov processes and Hidden Markov Models (HMMs) Instructor: Vincent Conitzer.
Bayes Nets & HMMs Tamara Berg CS 560 Artificial Intelligence Many slides throughout the course adapted from Svetlana Lazebnik, Dan Klein, Stuart Russell,
CSE 473: Artificial Intelligence Spring 2012 Reasoning about Uncertainty & Hidden Markov Models Daniel Weld Many slides adapted from Dan Klein, Stuart.
CSE 573: Artificial Intelligence Autumn 2012 Particle Filters for Hidden Markov Models Daniel Weld Many slides adapted from Dan Klein, Stuart Russell,
Instructor: Eyal Amir Grad TAs: Wen Pu, Yonatan Bisk Undergrad TAs: Sam Johnson, Nikhil Johri CS 440 / ECE 448 Introduction to Artificial Intelligence.
CSE 473: Artificial Intelligence Spring 2012 Reasoning about Uncertainty & Hidden Markov Models Daniel Weld Many slides adapted from Dan Klein, Stuart.
CS 541: Artificial Intelligence Lecture VIII: Temporal Probability Models.
CS 541: Artificial Intelligence Lecture VIII: Temporal Probability Models.
CS498-EA Reasoning in AI Lecture #23 Instructor: Eyal Amir Fall Semester 2011.
HMM: Particle filters Lirong Xia. HMM: Particle filters Lirong Xia.
Probabilistic reasoning over time
Probabilistic Reasoning
Artificial Intelligence
CS 4/527: Artificial Intelligence
CAP 5636 – Advanced Artificial Intelligence
Probabilistic Reasoning
CS 188: Artificial Intelligence Spring 2007
Probability Topics Random Variables Joint and Marginal Distributions
Inference Inference: calculating some useful quantity from a joint probability distribution Examples: Posterior probability: Most likely explanation: B.
Instructors: Fei Fang (This Lecture) and Dave Touretzky
CS 188: Artificial Intelligence
Probabilistic Reasoning
Probabilistic Reasoning
Hidden Markov Models Markov chains not so useful for most agents
CS 188: Artificial Intelligence Fall 2008
Hidden Markov Models Lirong Xia.
Speech recognition, machine learning
Announcements Assignments HW10 Due Wed 4/17 HW11
HMM: Particle filters Lirong Xia. HMM: Particle filters Lirong Xia.
Probabilistic reasoning over time
Speech recognition, machine learning
Presentation transcript:

Reasoning over Time  Often, we want to reason about a sequence of observations  Speech recognition  Robot localization  User attention  Medical monitoring  Need to introduce time into our models  Basic approach: hidden Markov models (HMMs)  More general: dynamic Bayes’ nets 1 This slide deck courtesy of Dan Klein at UC Berkeley

Markov Models  A Markov model is a chain-structured BN  Each node is identically distributed (stationarity)  Value of X at a given time is called the state  As a BN:  Parameters: called transition probabilities or dynamics, specify how the state evolves over time (also, initial probs) X2X2 X1X1 X3X3 X4X4

Conditional Independence  Basic conditional independence:  Past and future independent of the present  Each time step only depends on the previous  This is called the (first order) Markov property  Note that the chain is just a (growing) BN  We can always use generic BN reasoning on it if we truncate the chain at a fixed length X2X2 X1X1 X3X3 X4X4 3

Example: Markov Chain  Weather:  States: X = {rain, sun}  Transitions:  Initial distribution: 1.0 sun  What’s the probability distribution after one step? rainsun This is a CPT, not a BN! 4

Mini-Forward Algorithm  Question: probability of being in state x at time t?  Slow answer:  Enumerate all sequences of length t which end in s  Add up their probabilities … 5

Mini-Forward Algorithm  Question: What’s P(X) on some day t? sun rain sun rain sun rain sun rain Forward simulation 6

Example  From initial observation of sun  From initial observation of rain P(X 1 )P(X 2 )P(X 3 )P(X  ) P(X 1 )P(X 2 )P(X 3 )P(X  ) 7

Stationary Distributions  If we simulate the chain long enough:  What happens?  Uncertainty accumulates  Eventually, we have no idea what the state is!  Stationary distributions:  For most chains, the distribution we end up in is independent of the initial distribution  Called the stationary distribution of the chain  Usually, can only predict a short time out

Web Link Analysis  PageRank over a web graph  Each web page is a state  Initial distribution: uniform over pages  Transitions:  With prob. c, uniform jump to a random page (dotted lines, not all shown)  With prob. 1-c, follow a random outlink (solid lines)  Stationary distribution  Will spend more time on highly reachable pages  E.g. many ways to get to the Acrobat Reader download page  Somewhat robust to link spam  Google 1.0 returned the set of pages containing all your keywords in decreasing rank, now all search engines use link analysis along with many other factors (rank actually getting less important over time) 9

Hidden Markov Models  Markov chains not so useful for most agents  Eventually you don’t know anything anymore  Need observations to update your beliefs  Hidden Markov models (HMMs)  Underlying Markov chain over states S  You observe outputs (effects) at each time step  As a Bayes’ net: X5X5 X2X2 E1E1 X1X1 X3X3 X4X4 E2E2 E3E3 E4E4 E5E5

Example  An HMM is defined by:  Initial distribution:  Transitions:  Emissions:

Ghostbusters HMM  P(X 1 ) = uniform  P(X|X’) = usually move clockwise, but sometimes move in a random direction or stay in place  P(R ij |X) = same sensor model as before: red means close, green means far away. 1/9 P(X 1 ) P(X|X’= ) 1/6 0 1/ X5X5 X2X2 R i,j X1X1 X3X3 X4X4 E5E5

Conditional Independence  HMMs have two important independence properties:  Markov hidden process, future depends on past via the present  Current observation independent of all else given current state  Quiz: does this mean that observations are independent?  [No, correlated by the hidden state] X5X5 X2X2 E1E1 X1X1 X3X3 X4X4 E2E2 E3E3 E4E4 E5E5

Real HMM Examples  Speech recognition HMMs:  Observations are acoustic signals (continuous valued)  States are specific positions in specific words (so, tens of thousands)  Machine translation HMMs:  Observations are words (tens of thousands)  States are translation options  Robot tracking:  Observations are range readings (continuous)  States are positions on a map (continuous)

Filtering / Monitoring  Filtering, or monitoring, is the task of tracking the distribution B(X) (the belief state) over time  We start with B(X) in an initial setting, usually uniform  As time passes, or we get observations, we update B(X)  The Kalman filter was invented in the 60’s and first implemented as a method of trajectory estimation for the Apollo program

Example: Robot Localization t=0 Sensor model: never more than 1 mistake Motion model: may not execute action with small prob. 10 Prob Example from Michael Pfeiffer

Example: Robot Localization t=1 10 Prob

Example: Robot Localization t=2 10 Prob

Example: Robot Localization t=3 10 Prob

Example: Robot Localization t=4 10 Prob

Example: Robot Localization t=5 10 Prob

Inference Recap: Simple Cases E1E1 X1X1 X2X2 X1X1

Passage of Time  Assume we have current belief P(X | evidence to date)  Then, after one time step passes:  Or, compactly:  Basic idea: beliefs get “pushed” through the transitions  With the “B” notation, we have to be careful about what time step t the belief is about, and what evidence it includes X2X2 X1X1

Example: Passage of Time  As time passes, uncertainty “accumulates” T = 1T = 2T = 5 Transition model: ghosts usually go clockwise

Observation  Assume we have current belief P(X | previous evidence):  Then:  Or:  Basic idea: beliefs reweighted by likelihood of evidence  Unlike passage of time, we have to renormalize E1E1 X1X1

Example: Observation  As we get observations, beliefs get reweighted, uncertainty “decreases” Before observationAfter observation

Example HMM

SS E S E

The Forward Algorithm  We are given evidence at each time and want to know  We can derive the following updates We can normalize as we go if we want to have P(x|e) at each time step, or just once at the end…

Online Belief Updates  Every time step, we start with current P(X | evidence)  We update for time:  We update for evidence:  The forward algorithm does both at once (and doesn’t normalize)  Problem: space is |X| and time is |X| 2 per time step X2X2 X1X1 X2X2 E2E2

Best Explanation Queries  Query: most likely seq: X5X5 X2X2 E1E1 X1X1 X3X3 X4X4 E2E2 E3E3 E4E4 E5E5 31

State Path Trellis  State trellis: graph of states and transitions over time  Each arc represents some transition  Each arc has weight  Each path is a sequence of states  The product of weights on a path is the seq’s probability  Can think of the Forward (and now Viterbi) algorithms as computing sums of all paths (best paths) in this graph sun rain sun rain sun rain sun rain 32

Viterbi Algorithm sun rain sun rain sun rain sun rain 33

Example 34

Filtering  Filtering is the inference process of finding a distribution over X T given e 1 through e T : P( X T | e 1:t )  We first compute P( X 1 | e 1 ):  For each t from 2 to T, we have P( X t-1 | e 1:t-1 )  Elapse time: compute P( X t | e 1:t-1 )  Observe: compute P(X t | e 1:t-1, e t ) = P( X t | e 1:t ) 35

Belief Updates  Every time step, we start with current P(X | evidence)  We update for time:  We update for evidence:  The forward algorithm does both at once (and doesn’t normalize)  Problem: space is |X| and time is |X| 2 per time step X2X2 X1X1 X2X2 E2E2

Filtering  Filtering is the inference process of finding a distribution over X T given e 1 through e T : P( X T | e 1:t )  We first compute P( X 1 | e 1 ):  For each t from 2 to T, we have P( X t-1 | e 1:t-1 )  Elapse time: compute P( X t | e 1:t-1 )  Observe: compute P(X t | e 1:t-1, e t ) = P( X t | e 1:t ) 37

38

Recap: Reasoning Over Time  Stationary Markov models  Hidden Markov models X2X2 X1X1 X3X3 X4X4 rainsun X5X5 X2X2 E1E1 X1X1 X3X3 X4X4 E2E2 E3E3 E4E4 E5E5 XEP rainumbrella0.9 rainno umbrella0.1 sunumbrella0.2 sunno umbrella0.8

Recap: Filtering  Elapse time: compute P( X t | e 1:t-1 ) Observe: compute P( X t | e 1:t ) X2X2 E1E1 X1X1 E2E2 Belief: Prior on X 1 Observe Elapse time Observe

Particle Filtering  Filtering: approximate solution  Sometimes |X| is too big to use exact inference  |X| may be too big to even store B(X)  E.g. X is continuous  Solution: approximate inference  Track samples of X, not all values  Samples are called particles  Time per step is linear in the number of samples  But: number needed may be large  In memory: list of particles, not states  This is how robot localization works in practice

Particle Filtering: Elapse Time  Each particle is moved by sampling its next position from the transition model  This is like prior sampling – samples’ frequencies reflect the transition probs  Here, most samples move clockwise, but some move in another direction or stay in place  This captures the passage of time  If we have enough samples, close to the exact values before and after (consistent)

 Slightly trickier:  We don’t sample the observation, we fix it  This is similar to likelihood weighting, so we downweight our samples based on the evidence  Note that, as before, the probabilities don’t sum to one, since most have been downweighted (in fact they sum to an approximation of P(e)) Particle Filtering: Observe

Particle Filtering: Resample  Rather than tracking weighted samples, we resample  N times, we choose from our weighted sample distribution (i.e. draw with replacement)  This is equivalent to renormalizing the distribution  Now the update is complete for this time step, continue with the next one

Particle Filtering  Sometimes |X| is too big to use exact inference  |X| may be too big to even store B(X)  E.g. X is continuous  |X| 2 may be too big to do updates  Solution: approximate inference  Track samples of X, not all values  Samples are called particles  Time per step is linear in the number of samples  But: number needed may be large  In memory: list of particles, not states  This is how robot localization works in practice

Representation: Particles  Our representation of P(X) is now a list of N particles (samples)  Generally, N << |X|  Storing map from X to counts would defeat the point  P(x) approximated by number of particles with value x  So, many x will have P(x) = 0!  More particles, more accuracy  For now, all particles have a weight of 1 46 Particles: (3,3) (2,3) (3,3) (3,2) (3,3) (3,2) (2,1) (3,3) (2,1)

Particle Filtering: Elapse Time  Each particle is moved by sampling its next position from the transition model  This is like prior sampling – samples’ frequencies reflect the transition probs  Here, most samples move clockwise, but some move in another direction or stay in place  This captures the passage of time  If we have enough samples, close to the exact values before and after (consistent)

Particle Filtering: Observe  Slightly trickier:  Don’t do rejection sampling (why not?)  We don’t sample the observation, we fix it  This is similar to likelihood weighting, so we downweight our samples based on the evidence  Note that, as before, the probabilities don’t sum to one, since most have been downweighted (in fact they sum to an approximation of P(e))

Particle Filtering: Resample  Rather than tracking weighted samples, we resample  N times, we choose from our weighted sample distribution (i.e. draw with replacement)  This is equivalent to renormalizing the distribution  Now the update is complete for this time step, continue with the next one Old Particles: (3,3) w=0.1 (2,1) w=0.9 (3,1) w=0.4 (3,2) w=0.3 (2,2) w=0.4 (1,1) w=0.4 (3,1) w=0.4 (2,1) w=0.9 (3,2) w=0.3 Old Particles: (2,1) w=1 (3,2) w=1 (2,2) w=1 (2,1) w=1 (1,1) w=1 (3,1) w=1 (2,1) w=1 (1,1) w=1

Robot Localization  In robot localization:  We know the map, but not the robot’s position  Observations may be vectors of range finder readings  State space and readings are typically continuous (works basically like a very fine grid) and so we cannot store B(X)  Particle filtering is a main technique  [Demos]

P4: Ghostbusters 2.0 (beta)  Plot: Pacman's grandfather, Grandpac, learned to hunt ghosts for sport.  He was blinded by his power, but could hear the ghosts’ banging and clanging.  Transition Model: All ghosts move randomly, but are sometimes biased  Emission Model: Pacman knows a “noisy” distance to each ghost Noisy distance prob True distance = 8 [Demo]

Dynamic Bayes Nets (DBNs)  We want to track multiple variables over time, using multiple sources of evidence  Idea: Repeat a fixed Bayes net structure at each time  Variables from time t can condition on those from t-1  Discrete valued dynamic Bayes nets are also HMMs G1aG1a E1aE1a E1bE1b G1bG1b G2aG2a E2aE2a E2bE2b G2bG2b t =1t =2 G3aG3a E3aE3a E3bE3b G3bG3b t =3

Exact Inference in DBNs  Variable elimination applies to dynamic Bayes nets  Procedure: “unroll” the network for T time steps, then eliminate variables until P(X T |e 1:T ) is computed  Online belief updates: Eliminate all variables from the previous time step; store factors for current time only 53 G1aG1a E1aE1a E1bE1b G1bG1b G2aG2a E2aE2a E2bE2b G2bG2b G3aG3a E3aE3a E3bE3b G3bG3b t =1t =2t =3 G3bG3b

DBN Particle Filters  A particle is a complete sample for a time step  Initialize: Generate prior samples for the t=1 Bayes net  Example particle: G 1 a = (3,3) G 1 b = (5,3)  Elapse time: Sample a successor for each particle  Example successor: G 2 a = (2,3) G 2 b = (6,3)  Observe: Weight each entire sample by the likelihood of the evidence conditioned on the sample  Likelihood: P(E 1 a |G 1 a ) * P(E 1 b |G 1 b )  Resample: Select prior samples (tuples of values) in proportion to their likelihood 54 [Demo]

SLAM  SLAM = Simultaneous Localization And Mapping  We do not know the map or our location  Our belief state is over maps and positions!  Main techniques: Kalman filtering (Gaussian HMMs) and particle methods  [DEMOS] DP-SLAM, Ron Parr