clp(bn) support

This commit is contained in:
Vítor Santos Costa 2012-03-22 23:24:09 +00:00
parent 372f3d795e
commit 07335ce047
2 changed files with 9 additions and 8 deletions

View File

@ -260,20 +260,21 @@ skim_for_theta([[P|Other]], not(P), [Other], _) :- !.
skim_for_theta([[P|Other]|More], Ps*not(P), [Other|Left], New ) :- skim_for_theta([[P|Other]|More], Ps*not(P), [Other|Left], New ) :-
skim_for_theta(More, Ps, Left, New ). skim_for_theta(More, Ps, Left, New ).
get_evidence(V, Tree, Values, F0, F) :- get_evidence(V, Tree, Values, F0, (Tree=Outs).F0) :-
clpbn:get_atts(V, [evidence(Pos)]), !, clpbn:get_atts(V, [evidence(Pos)]), !,
zero_pos(0, Pos, Tree, Values, F0, F). zero_pos(0, Pos, Values),
get_outs(F0, Outs).
%% no evidence !!! %% no evidence !!!
get_evidence(_V, Tree, _Values, F0, (Tree=Outs).F0) :- get_evidence(_V, Tree, _Values, F0, (Tree=Outs).F0) :-
get_outs(F0, Outs). get_outs(F0, Outs).
zero_pos(_, _Pos, _Tree, [], [], []) :- !. zero_pos(_, _Pos, []).
zero_pos(Pos, Pos, Tree, 1.Values, [Tree=Vs|F], [Tree=Vs]) :- zero_pos(Pos, Pos, 1.Values) :- !,
I is Pos+1, I is Pos+1,
zero_pos(I, Pos, Tree, Values, F, []). zero_pos(I, Pos, Values).
zero_pos(I0, Pos, Tree, 0.Values, _.F, NF) :- zero_pos(I0, Pos, 0.Values) :-
I is I0+1, I is I0+1,
zero_pos(I, Pos, Tree, Values, F, NF). zero_pos(I, Pos, Values).
get_outs([V=_F], V) :- !. get_outs([V=_F], V) :- !.
get_outs((V=_F).Outs, (V + F0)) :- get_outs((V=_F).Outs, (V + F0)) :-

View File

@ -163,7 +163,7 @@ term_to_cudd(DdManager *manager, YAP_Term t)
else if (i==1.0) else if (i==1.0)
return Cudd_ReadOne(manager); return Cudd_ReadOne(manager);
} else if (YAP_IsVarTerm(t)) { } else if (YAP_IsVarTerm(t)) {
fprintf(stderr,"Unbound Variable should be input argument to BDD\n"); fprintf(stderr,"Unbound Variable should not be input argument to BDD\n");
} }
return NULL; return NULL;
} }