CSE 4308/5360 - Assignments - Programming Assignment 5

Due dates:
Interim report: Wednesday, August 4, 2010, 11:55pm
Full assignment: Wednesday August 11, 11:55pm.

Summary

The goal in this assignment is to get practice on designing Bayesian networks, estimating probability distributions in Bayesian networks, and implementing Bayesian networks.


Part 1: Designing a Bayesian network graph

20 points

George doesn't watch much TV in the evening, unless there is a baseball game on. When there is baseball on TV, George is very likely to watch. George has a cat that he feeds every night, although he forgets every now and then. He's much more likely to forget when he's watching TV. He's also very unlikely to feed the cat if he has run out of cat food (although sometimes he gives the cat some of his own food). Design a Bayesian network for modeling the relations between these four events:

Your task is to connect these nodes with arrows pointing from causes to effects. No programming is needed for this part, just include an electronic document (PDF, Word file, or OpenOffice document) showing your Bayesian network design.


Part 2: Learning Probabilities from Training Data

20 points

For the Bayesian network of Part 1, the text file at this link contains training data from every evening of an entire year. Every line in this text file corresponds to an evening, and contains four numbers. Each number is a 0 or a 1. In more detail:

Based on the data in this file, determine the probability table for each node in the Bayesian network you have designed for Part 1. You need to include these four tables in the drawing that you produce for question 1. You also need to submit the code/script that computes these probabilities.


Figure 1: A Bayesian network establishing relations between events on the burglary-earthquake-alarm domain, together with complete specifications of all probability distributions.

Part 3: Implementing a Bayesian Network

60 points

For the Bayesian network of Figure 1, implement a program that computes and prints out the probability of any combination of events given any other combination of events. If the executable is called bnet, here are some example invocations of the program:

  1. To print out the probability P(Burglary=true and Alarm=false | MaryCalls=false).
    bnet Bt Af given Mf
    
  2. To print out the probability P(Alarm=false and Earthquake=true).
    bnet Af Et
    
  3. To print out the probability P(JohnCalls=true and Alarm=false | Burglary=true and Earthquake=false).
    bnet Jt Af given Bt Ef
    
  4. To print out the probability P(Burglary=true and Alarm=false and MaryCalls=false and JohnCalls=true and Earthquake=true).
    bnet Bt Af Mf Jt Et
    
In general, bnet takes 1 to 6(no more, no fewer) command line arguments, as follows: The implementation should not contain hardcoded values for all combinations of arguments, but instead should use the tables shown on Figure 1 and the appropriate formulas to evaluate the probability of the specified event. More specifically, for full credit, the code should include and use:


Grading

Each part will be graded as follows:

How to submit

Submit a ZIPPED directory called programming5.zip (no other forms of compression accepted, contact the instructor or TA if you do not know how to produce .zip files). The directory should contain source code, the answer for part 1 in a document, the answer (and code) for part 2, and the code for part 3. The submission should also contain a file called readme.txt, which should specify precisely:

Insufficient or unclear instructions will be penalized by up to 20 points. Code that does not run on omega machines gets AT MOST half credit (50 points).

Submission checklist