ifix interface to clp(bn) machinery.
This commit is contained in:
parent
7b84608e5e
commit
172f59cee5
@ -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,10 +68,9 @@ 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),
|
||||||
Table \= avg,
|
Table \= avg,
|
||||||
gen_table(Table, Phi),
|
gen_table(Table, Phi),
|
||||||
all_tuples(Constraints, Vs, Tuples).
|
all_tuples(Constraints, Vs, Tuples).
|
||||||
@ -84,8 +79,8 @@ is_factor(pf(Id, Ks, Rs, Phi, Tuples)) :-
|
|||||||
get_ranges([],[]).
|
get_ranges([],[]).
|
||||||
get_ranges(K.Ks, Range.Rs) :- !,
|
get_ranges(K.Ks, Range.Rs) :- !,
|
||||||
skolem(K,Domain),
|
skolem(K,Domain),
|
||||||
length(Domain,Range),
|
length(Domain,Range),
|
||||||
get_ranges(Ks, Rs).
|
get_ranges(Ks, Rs).
|
||||||
|
|
||||||
|
|
||||||
gen_table(Table, Phi) :-
|
gen_table(Table, Phi) :-
|
||||||
@ -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).
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user