57 lines
		
	
	
		
			989 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			989 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| % learn distribution for school database.
 | |
| 
 | |
| :- use_module(library(pfl)).
 | |
| 
 | |
| :- use_module(library(clpbn/learning/em)).
 | |
| 
 | |
| bayes abi(K)::[h,m,l] ; abi_table ; [professor(K)].
 | |
| 
 | |
| bayes pop(K)::[h,m,l], abi(K) ; pop_table ; [professor(K)].
 | |
| 
 | |
| abi_table([0.3,0.3,0.4]).
 | |
| 
 | |
| pop_table([0.3,0.3,0.4,0.3,0.3,0.4,0.3,0.3,0.4]).
 | |
| 
 | |
| goal_list([/*abi(p0,h),
 | |
| 	abi(p1,m),
 | |
| 	abi(p2,m),
 | |
| 	abi(p3,m),
 | |
| 	abi(p4,l),*/
 | |
| 	pop(p5,h),
 | |
| 	abi(p5,_),
 | |
| 	abi(p6,_),
 | |
| 	pop(p7,_)]).
 | |
| 
 | |
| professor(p1).
 | |
| professor(p2).
 | |
| professor(p3).
 | |
| professor(p4).
 | |
| professor(p5).
 | |
| professor(p6).
 | |
| professor(p7).
 | |
| professor(p8).
 | |
| 
 | |
| %:- clpbn:set_clpbn_flag(em_solver,gibbs).
 | |
| %:- clpbn:set_clpbn_flag(em_solver,jt).
 | |
| :- clpbn:set_clpbn_flag(em_solver,ve).
 | |
| %:- clpbn:set_clpbn_flag(em_solver,bp).
 | |
| 
 | |
| timed_main :-
 | |
| 	statistics(runtime, _),
 | |
| 	main(Lik),
 | |
| 	statistics(runtime, [T,_]),
 | |
| 	format('Took ~d msec and Lik ~3f~n',[T,Lik]).
 | |
| 
 | |
| main(Lik) :-
 | |
| 	goal_list(L),
 | |
| %	run_queries(L),
 | |
|         em(L,0.01,10,_,Lik).
 | |
| 
 | |
| run_queries([]).
 | |
| run_queries(Q.L) :-
 | |
| 	call(Q),
 | |
| 	run_queries(L).
 | |
| 
 | |
| 
 | |
| 
 |