Eu estava brincando com os predicados de pró-roteirizaçãofreeze/2
e frozen/2
:
?- freeze(X,a=a), frozen(X,Goal).
?- freeze(X,a=a), freeze(Y,b=b), X=Y, frozen(X,Goal).
O sicstus-prolog (versão 4.5.1 para x86_64) deu as seguintes respostas:
| ? - congelar (X, a = a), congelado (X, meta). Objetivo = prólogo: congelar (X, usuário: (a = a)) , prólogo: congelar (X, usuário: (a = a))? ; não | ? - congelar (X, a = a), congelar (Y, b = b), X = Y, congelar (X, meta). Y = X, Meta = (usuário: (a = a), prólogo: congelar (X, usuário: (b = b))) , prolog: congelar (X, usuário: (a = a)), prólogo: congelar (X, usuário: (b = b))? ; não
Agora eu não esperava!Goal = prolog:freeze(X,user:(a=a))
O que eu fiz esperar eram respostas como os dados por SWI-Prolog versão 8.0.3:
? - congelar (X, a = a), congelado (X, meta). Meta = usuário: (a = a) , congelar (X, a = a). ? - congelar (X, a = a), congelar (Y, b = b), X = Y, congelar (X, meta). X = Y, Meta = (usuário: (a = a), usuário: (b = b)) , congelar (Y, a = a), congelar (Y, b = b).
Indiscutivelmente, as respostas SICStus e SWI estão corretas ...
Mas existe uma razão mais profunda para as respostas um tanto peculiares dadas pelo SICStus?