Three Concepts: Probability | Projects
(none yet)
When designing a learning algorithm to construct models from data sets with non-informative prior information (i.e., no preference for the structure in advance) a challenging and interesting task is to evaluate the "quality" of the learning algorithm. There are several possible ways to study the performance of the learning algorithm, and many of the schemes are based on simulating the future prediction tasks by reusing the data available. These approaches have problems of their own and they tend to be complex for cases where one is interested in probabilistic models for the joint distributions. Therefore in many cases in the literature the so-called synthetic or "Golden Standard" approach is used to evaluate the learning algorithm. In this approach one first selects a "true model" (Golden standard) and then generates data stochastically from this model. The quality of the learning algorithm is judged by its ability to reconstruct this model from the generated data. In this project we will study this evaluation approach.
The first task is to write a program that generates data from a discrete Bayesian network. It should take as input a Bayesian network in a format described below produce as output a set of i.i.d. data vectors generated stochastically from this model. The amount of generated data is naturally a parameter for the program. The generated data set should be in tabular format in a text file so that it can be used by B-Course software. The usual general requirements for the software hold: it is reasonably documented and runs in our machine (CSL#2 Linux). All documentation should be presented as a WEB-page.
The network description language is based on the one used by the Hugin tool. The data generator should accept networks written in the grammar below. Since writing a proper parser may be a big effort for those who are not exprerienced parser writers, data generators that cheat by using regular expression matching or something similiar will be tolerated, as long as they are able to parse the Hugin networks exported by B-Course (B-Course refers these as "Hugin Lite files")
The second task is to study the actual process of evaluating a learning algorithm against the Golden Standard. Although writing a Bayesian network learner on your own would be a useful task, for this project you should use B-Course learning engine for the candidate algorithm to be evaluated. In this case we are particularly interested in
The test setting should be approximately as follows
One should thus test combinations of these test parameters with several different Bayesian networks. The observations and empirical results should be reported as a WEB-page with discussion on the possible reasons for the differences between the generating Bayesian network and the discovered network structure. Notice that B-Course provides you with a nice graphical representation of the constructed Bayesian network and it would be helpful to show at least some of the Golden Standard networks in graphical format also.
Along with the documentation, the sources for the generator program, and the network descriptions used must be provided.
Automated B-Course Driver
As the above setting requires you to repeat network learning multiple times, it doesn't necessarily make sense to use B-Course by hand. To ease your life we provide you a Python script which takes your sampled data (in normal B-Course format), sends it to B-Course, learns a network (with varying number of iterations) and gives you the learned network as a HUGIN file (bnetwork.net) and a nice PNG graph (bnetwork.png). Here's the driver: auto-bcourse.py .
Usage:
python auto-bcourse.py samples.txt 30
The last number makes script to wait for 30 seconds before returning the net. The longer
you wait the better network you'll get, roughly.
The project will be evaluated both for the first part (generator design) and the analysis of the experiments. All reported (documented) bugs found in B-Course will give you extra bonus, but should be reported immediately to Tommi!
B-Course search is stochastic and thus can produce different networks for different runs. This cannot be totally eliminated but one should let B-Course search engine to search long enough!
Three Concepts: Probability |