प्रस्तावना: var, nonvar और जमीन के बीच अंतर

Aug 18 2020

प्रोलॉग में, विशेष रूप से यह मेटाप्रोग्रामिंग पहलुओं में है, लोग अक्सर जमीन और गैर-जमीन चर के बारे में बात करते हैं । साथ ही var / 1 , nonvar / 1 और ground / 1 जैसे विधेय का उपयोग कर रहा है । लेकिन वास्तव में उनके बीच अंतर क्या है?

मेरी वर्तमान समझ निम्नलिखित है:

  • एक var पूरी तरह से अनियंत्रित है (उदा। X)
  • एक नॉनवर को त्वरित किया जाता है, लेकिन इसमें कुछ चर गहरे हो सकते हैं (उदाहरण के लिए। (1,2, Y))। यह हास्केल से एक कमजोर सिर के सामान्य रूप के समान है।
  • एक ग्राउंड संस्करण पूरी तरह से त्वरित है, सभी तरह से नीचे (जैसे। अवधि (1,2,3))।

क्या यह सही है?

जवाब

DavidTonhofer Aug 18 2020 at 01:22

करीब-करीब।

  • यदि var(X)तब चर Xकुछ ऐसा डिजाइन करता है जो अनइंस्टालिएटेड है, तो एक "होल"। Xएक "ताजा चर" है। नोट: उस विधेय को वास्तव में नामित किया जाना चाहिए fresh(...)। क्या Xएक चर है वास्तव में कार्यक्रम पाठ के बारे में एक सवाल है। लेकिन हम यह जानना चाहते हैं कि क्या कोष्ठक के बीच में एक ताजा चर है (उस समय कॉल किया जाता है, क्योंकि, काफी गैर-तार्किक रूप से, यह बदल सकता है।)

  • nonvar(X)के पूरक के var(X)रूप में ही है \+ var(X)। जो कुछ भी कोष्ठक में नामित कुछ के बीच है (अगर यह एक चर रहा है) या है कुछ (अगर यह एक गैर-चर शब्द है, के रूप में nonvar(foo)) है कि एक "छेद" नहीं है।

  • ground(X) इसका मतलब यह है कि जो कुछ भी पेरेंटहैस के बीच होता है वह कुछ बनाता है या ऐसा कुछ है जिसकी संरचना में कोई छेद नहीं है (प्रभाव में, शब्द की पत्तियों पर कोई छेद नहीं)।

कुछ परीक्षण कोड। मुझे उम्मीद थी कि कंपाइलर ने इससे अधिक चेतावनी जारी की है।

:- begin_tests(var_nonvar).

% Amazingly, the compiler does not warn about the code below.

test("var(duh) is always false", fail) :-
  var(duh). 

% Amazingly, the compiler does not warn about the code below.

test("var(X) is true if X is a fresh variable (X designates a 'hole')") :-
   var(_). 

% Compiler warning: " Singleton variable, Test is always true: var(X)"

test("var(X) is true if X is a fresh variable (X designates a 'hole')") :-
   var(X). 
   
% The hole designated by X is filled with f(_), which has its own hole.
% the result is nonvar (and also nonground)

test("var(X) maybe true but become false as computation progresses") :-
   var(X),X=f(_),nonvar(X).
   
test("var(X) is false otherwise") :-
   var(_).   

% The hole is designated by an anonymous variable

test("a fresh variable is not ground, it designates a 'hole'", fail) :-
   ground(_). 
   
% Both hhe holes are designated by anonymous variables

test("a structure with 'holes' at the leaves is non-ground", fail) :-
   ground(f(_,_)). 
   
test("a structure with no 'holes' is ground") :-
   ground(f(x,y)).

test("a structure with no 'holes' is ground, take 2") :-
   X=f(x,y), ground(X).
   
% var/1 or ground/1 are questions about the state of computation,
% not about any problem in logic that one models. For example:

test("a structure that is non-ground can be filled as computation progresses") :-
   K=f(X,Y), \+ ground(f(X,Y)), X=x, Y=y, ground(f(X,Y)).
   
:- end_tests(var_nonvar).