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). | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 |