ifix interface to clp(bn) machinery.

This commit is contained in:
Vítor Santos Costa 2012-03-22 19:08:36 +00:00
parent 7b84608e5e
commit 172f59cee5

View File

@ -29,14 +29,11 @@
]). ]).
:- load_foreign_files(['horus'], [], init_predicates). :- use_module(horus).
:- set_horus_flag(use_logarithms, false). :- set_horus_flag(use_logarithms, false).
%:- set_horus_flag(use_logarithms, true). %:- set_horus_flag(use_logarithms, true).
fove([[]], _, _) :- !. fove([[]], _, _) :- !.
fove([QueryVars], AllVars, Output) :- fove([QueryVars], AllVars, Output) :-
writeln(queryVars:QueryVars), writeln(queryVars:QueryVars),
@ -46,7 +43,6 @@ fove([QueryVars], AllVars, Output) :-
finalize_fove_solver(ParfactorGraph), finalize_fove_solver(ParfactorGraph),
clpbn_bind_vals([QueryVars], LPs, Output). clpbn_bind_vals([QueryVars], LPs, Output).
init_fove_solver(_, AllAttVars, _, fove(ParfactorGraph, DistIds)) :- init_fove_solver(_, AllAttVars, _, fove(ParfactorGraph, DistIds)) :-
writeln(allattvars:AllAttVars), writeln(''), writeln(allattvars:AllAttVars), writeln(''),
get_parfactors(Parfactors), get_parfactors(Parfactors),
@ -72,7 +68,6 @@ init_fove_solver(_, AllAttVars, _, fove(ParfactorGraph, DistIds)) :-
get_parfactors(Factors) :- get_parfactors(Factors) :-
findall(F, is_factor(F), Factors). findall(F, is_factor(F), Factors).
is_factor(pf(Id, Ks, Rs, Phi, Tuples)) :- is_factor(pf(Id, Ks, Rs, Phi, Tuples)) :-
factor(Id, Ks, Vs, Table, Constraints), factor(Id, Ks, Vs, Table, Constraints),
get_ranges(Ks,Rs), get_ranges(Ks,Rs),
@ -96,7 +91,6 @@ gen_table(Table, Phi) :-
call(user:Table, Phi) call(user:Table, Phi)
). ).
all_tuples(Constraints, Tuple, Tuples) :- all_tuples(Constraints, Tuple, Tuples) :-
setof(Tuple, Constraints^run(Constraints), Tuples). setof(Tuple, Constraints^run(Constraints), Tuples).
@ -115,7 +109,8 @@ get_dist_ids(pf(Id, _, _, _, _).Parfactors, Id.DistIds) :-
get_observed_vars([], []). get_observed_vars([], []).
get_observed_vars(V.AllAttVars, [K:E|ObservedVars]) :- get_observed_vars(V.AllAttVars, [K:E|ObservedVars]) :-
writeln('checking ev for':V), writeln('checking ev for':V),
clpbn:get_atts(V,[key(K),evidence(E)]), !, clpbn:get_atts(V,[key(K)]),
( clpbn:get_atts(V,[evidence(E)]) ; pfl:evidence(K,E) ), !,
writeln('evidence!!!':K:E), writeln('evidence!!!':K:E),
get_observed_vars(AllAttVars, ObservedVars). get_observed_vars(AllAttVars, ObservedVars).
get_observed_vars(V.AllAttVars, ObservedVars) :- get_observed_vars(V.AllAttVars, ObservedVars) :-
@ -137,8 +132,8 @@ get_query_vars_2(V.AttVars, [RV|RVs]) :-
get_dists_parameters([], []). get_dists_parameters([], []).
get_dists_parameters([Id|Ids], [dist(Id)|DistsInfo]) :- get_dists_parameters([Id|Ids], [dist(Id, Params)|DistsInfo]) :-
get_dist_params(Id, Params), get_pfl_parameters(Id, Params),
get_dists_parameters(Ids, DistsInfo). get_dists_parameters(Ids, DistsInfo).