108 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <cstdlib>
 | |
| #include <cassert>
 | |
| 
 | |
| #include <iostream>
 | |
| #include <fstream>
 | |
| #include <sstream>
 | |
| 
 | |
| #include "BayesBallGraph.h"
 | |
| #include "Util.h"
 | |
| 
 | |
| 
 | |
| void
 | |
| BayesBallGraph::addNode (BBNode* n)
 | |
| {
 | |
|   assert (Util::contains (varMap_, n->varId()) == false);
 | |
|   nodes_.push_back (n);
 | |
|   varMap_[n->varId()] = n;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void
 | |
| BayesBallGraph::addEdge (VarId vid1, VarId vid2)
 | |
| {
 | |
|   unordered_map<VarId, BBNode*>::iterator it1;
 | |
|   unordered_map<VarId, BBNode*>::iterator it2;
 | |
|   it1 = varMap_.find (vid1);
 | |
|   it2 = varMap_.find (vid2);
 | |
|   assert (it1 != varMap_.end());
 | |
|   assert (it2 != varMap_.end());
 | |
|   it1->second->addChild  (it2->second);
 | |
|   it2->second->addParent (it1->second);
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| const BBNode*
 | |
| BayesBallGraph::getNode (VarId vid) const
 | |
| {
 | |
|   unordered_map<VarId, BBNode*>::const_iterator it;
 | |
|   it = varMap_.find (vid);
 | |
|   return it != varMap_.end() ? it->second : 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| BBNode*
 | |
| BayesBallGraph::getNode (VarId vid)
 | |
| {
 | |
|   unordered_map<VarId, BBNode*>::const_iterator it;
 | |
|   it = varMap_.find (vid);
 | |
|   return it != varMap_.end() ? it->second : 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void
 | |
| BayesBallGraph::setIndexes (void)
 | |
| {
 | |
|   for (size_t i = 0; i < nodes_.size(); i++) {
 | |
|     nodes_[i]->setIndex (i);
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void
 | |
| BayesBallGraph::clear (void)
 | |
| {
 | |
|   for (size_t i = 0; i < nodes_.size(); i++) {
 | |
|     nodes_[i]->clear();
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void
 | |
| BayesBallGraph::exportToGraphViz (const char* fileName)
 | |
| {
 | |
|   ofstream out (fileName);
 | |
|   if (!out.is_open()) {
 | |
|     cerr << "error: cannot open file to write at " ;
 | |
|     cerr << "BayesBallGraph::exportToDotFile()" << endl;
 | |
|     abort();
 | |
|   }
 | |
|   out << "digraph {" << endl;
 | |
|   out << "ranksep=1" << endl;
 | |
|   for (size_t i = 0; i < nodes_.size(); i++) {
 | |
|     out << nodes_[i]->varId() ;
 | |
|     out << " [" ;
 | |
|     out << "label=\"" << nodes_[i]->label() << "\"" ;
 | |
|     if (nodes_[i]->hasEvidence()) {
 | |
|       out << ",style=filled, fillcolor=yellow" ;
 | |
|     }
 | |
|     out << "]" << endl;
 | |
|   }
 | |
|   for (size_t i = 0; i < nodes_.size(); i++) {
 | |
|     const vector<BBNode*>& childs = nodes_[i]->childs();
 | |
|     for (size_t j = 0; j < childs.size(); j++) {
 | |
|       out << nodes_[i]->varId() << " -> " << childs[j]->varId();
 | |
|       out << " [style=bold]" << endl ;
 | |
|     }
 | |
|   }
 | |
|   out << "}" << endl;
 | |
|   out.close();
 | |
| }
 | |
| 
 |