假设我有这样的事实:
fact(abc,2).
我想要这样的东西(伪代码):
fact_update(Functor,Name,AddToValue) :-
if Fact_exist then update_fact : NewVal is CurrentValue + AddToValue
else create_new_fact : Functor(Name,AddToValue)
我尝试了 2 种不同的方法。第一个我不太喜欢:
fact_add(Functor,Name,Val) :-
Fact =.. [Functor, Name, Val],
assert(Fact),
say([fact, Fact]).
fact_update(true, Functor,Name,Val) :-
Fact =.. [Functor, Name, Amt],
Fact,
retractall(Fact),
X is Amt + Val,
fact_add(Functor,Name,X). %% retractall??
fact_update(false,Functor,Name,Val) :-
fact_add(Functor,Name,Val).
第二个不起作用:
fact_update(Functor,Name,Val) :-
Fact =.. [Functor, Name, Amt],
(
Fact -> retractall(Fact)
;
(
(nonvar(Amt) -> NewAmt is Amt + Val ; NewAmt is Val),
Fact =.. [Functor, Name, NewAmt],
assert(Fact)
)
),
say([upd_fact, Fact]).
因为当Fact
不成功时Amt
没有实例化,所以我总是得到NewAmt is Val
.