1 / 63

Prolog Tutorial

Prolog Tutorial. Επεξεργασία και Αναπαράσταση Γνώσης Άνοιξη 2010 Τμήμα Επιστήμης Υπολογιστών Πανεπιστημίου Κρήτης. Προγράμματα στην Prolog. Ένα πρόγρ αμ μα στην Prolog είναι ένα σύνολο προτάσεων που περιγράφουν τα δεδομένα του προβλήματος και τις σχέσεις μεταξύ τους.

tad-deleon
Download Presentation

Prolog Tutorial

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Prolog Tutorial Επεξεργασία και Αναπαράσταση Γνώσης Άνοιξη 2010 Τμήμα Επιστήμης Υπολογιστών Πανεπιστημίου Κρήτης

  2. Προγράμματα στην Prolog • Ένα πρόγραμμα στην Prolog είναι ένα σύνολο προτάσεων που περιγράφουν τα δεδομένα του προβλήματος και τις σχέσεις μεταξύ τους. • Οι προτάσεις αυτές λέγονται προτάσεις Horn και αποτελούν υποσύνολο της λογικής πρώτης τάξης. • Προτάσεις Horn A ← A0,A1,…,An : Για να δείξεις το Α πρέπει να δείξεις το Α0 και το Α1,…,και το Αν 2

  3. Γεγονότα και Κανόνες • Υπάρχουν δύο είδη προτάσεων σε ένα πρόγραμμα Prolog, τα γεγονότα και οι κανόνες. • Τα γεγονότα εκφράζουν σχέσεις ανάμεσα στα αντικείμενα και αποτελούν κατά ένα τρόπο τα δεδομένα του προβλήματος, π.χ. father(george, mary). • Οι κανόνες εκφράζουν γενικότερες σχέσεις ανάμεσα στα αντικείμενα οι οποίες ορίζονται με τη βοήθεια άλλων σχέσεων, π.χ. parent(X,Y):- father(X,Y). parent(X,Y):- mother(X,Y). • Τα X, Y είναι μεταβλητές. Το σύμβολο :- εκφράζει το λογικό «ΑΝ» 3

  4. Αλληλεπίδραση με την Prolog • Ο χρήστης αλληλεπιδρά με ένα σύστημα Prolog, δίνοντας σε αυτό ερωτήσεις (queries), τις οποίες το σύστημα προσπαθεί να απαντήσει με βάση τα γεγονότα και τους κανόνες. • Οι απαντήσεις που επιστρέφονται είναι είτε • yes/no • Αν η ερώτηση περιέχει μεταβλητές, κατάλληλες τιμές για τις μεταβλητές αυτές. 4

  5. Παράδειγμα προγράμματος (1/3) father(george,mary). father(george,nick). father(peter,marina). mother(helen,mary). mother(helen,nick). mother(ann,marina). parent(X,Y):- father(X,Y). parent(X,Y):- mother(X,Y). 5

  6. Παράδειγμα προγράμματος (2/3) • Θεωρούμε ότι οι παραπάνω προτάσεις είναι αποθηκευμένες σε ένα απλό αρχείο κειμένου και ότι «φορτώθηκαν» σε κάποιο διερμηνευτή της Prolog. • Πιθανές ερωτήσεις - απαντήσεις που μπορούν να γίνουν με βάση το παραπάνω πρόγραμμα είναι: ?- father(george,mary). - yes ?- father(george,marina). - no ?- father(peter,X). - X=marina 6

  7. Παράδειγμα προγράμματος (3/3) ?- mother(X,marina). - X=ann ?- parent(george,X). - X=mary; - X=nick ?- parent(paul,X). - no ?- mother(X,Y). - X=helen, Y=mary; X=helen, Y=nick; X=ann, Y=marina; no 7

  8. Σύνταξη της Prolog • Όροι • Γεγονότα • Κανόνες • Ερωτήσεις 8

  9. Σύνταξη της Prolog • Τα στοιχεία της γλώσσας είναι • οι όροι • τα γεγονότα • οι κανόνες • οι ερωτήσεις • Σχόλια • Τα σχόλια στην Prolog εισάγονται είτε με τον χαρακτήρα “%”, είτε περικλείονται στους χαρακτήρες /* και */. 9

  10. Σύνταξη της Prolog • Όροι • Γεγονότα • Κανόνες • Ερωτήσεις 10

  11. Όροι Όροι στην Prolog Απλοί Σύνθετοι Σταθερές Μεταβλητές Συναρτησιακό σύμβολο Ορίσματα Σύνθετοι όροι άτομα αριθμοί Απλοί όροι 11

  12. Απλοί όροι • Το μοναδικό data type στην Prolog είναι οι όροι (term). • Οι απλοί όροι είναι οι αριθμοί, τα άτομα και οι μεταβλητές. • Οι αριθμοί έχουν τη συνηθισμένη μορφή, κοινή με τις υπόλοιπες γλώσσες προγραμματισμού (floats ή integers). • Τα άτομα είναι συμβολοσειρές, οι οποίες πρέπει απαραίτητα να ξεκινούν από πεζό γράμμα ή να περιλαμβάνονται σε μονά εισαγωγικά, π.χ. • anna, x25, x_25, x_, ‘Tom’, ‘cd player’ 12

  13. Μεταβλητές(1/2) • Οι μεταβλητές είναι συμβολοσειρές που μπορεί να περιέχουν γράμματα, ψηφία ή τον χαρακτήρα «_», και πρέπει πάντα να ξεκινούν με κεφαλαίο γράμμα ή με τον χαρακτήρα «_», π.χ. • X, Result, Object2, _a23 • Οι μεταβλητές που ξεκινούν με τον χαρακτήρα «_» ονομάζονται ανώνυμες μεταβλητές. Χρησιμοποιούνται στις περιπτώσεις που δεν μας ενδιαφέρει η τιμή που θα λάβει η συγκεκριμένη μεταβλητή, π.χ. ?- father(peter,_). 13

  14. Μεταβλητές(2/2) • Στην Prolog, σε μία μεταβλητή η οποία έχει πάρει μία τιμή δεν μπορεί να δοθεί νέα (non destructive assignment). • Οι μεταβλητές στην Prolog δεν έχουν τύπο (typeless)και άρα δεν απαιτούν δηλώσεις και μπορούν να πάρουν σαν τιμή οποιοδήποτε όρο. • Υπάρχουν μόνο τοπικές μεταβλητές, των οποίων η εμβέλεια είναι μέσα στον κανόνα που εμφανίζονται. 14

  15. Σύνθετοι Όροι • Οι σύνθετοι όροι είναι σύνθετες δομές με γενική μορφή f(k1,k2,…,kn) • To f ονομάζεται συναρτησιακό σύμβολο (functor) τάξης nκαι τα k1,k2,…,kn λέγονται ορίσματα. Η τάξη είναι το πλήθος των ορισμάτων του σύνθετου όρου. Τα ορίσματα μπορεί να είναι είτε απλοί ή σύνθετοι όροι, π.χ. date(2,august,1997) triangle(point(4,2),point(6,4),point(7,1)) 15

  16. Σύνταξη της Prolog • Όροι • Γεγονότα • Κανόνες • Ερωτήσεις 16

  17. Γεγονότα • Η πιο απλή μορφή προτάσεων Horn είναι τα γεγονότα.Ένα γεγονός εκφράζει την απευθείας σχέση που συνδέει κάποια αντικείμενα. Αποτελείται από μία σχέση ή κατηγόρημα (predicate), το οποίο είναι ένα άτομο, ακολουθούμενο από έναν οποιοδήποτε αριθμό παραμέτρων ή ορισμάτων σε παρενθέσεις. Σαν ορίσματα μπορούμε να έχουμε οποιοδήποτε όρο είτε απλό είτε σύνθετο. • Το πλήθος των ορισμάτων ονομάζεται τάξη του γεγονότος. • Παραδείγματα: student(john,class(a),grade(b)). Γεγονός τάξης 3 με κατηγόρημα student. room(48,top_floor). Γεγονός τάξης 2 με κατηγόρημα room. day_sunny. Γεγονός μηδενικής τάξης με κατηγόρημα day_sunny. 17

  18. Σύνταξη γεγονότων • Ένα γεγονός ακολουθείται πάντα από τελεία. Το τμήμα του γεγονότος που προηγείται της τελείας, δηλαδή το κατηγόρημα και τα ορίσματά του είναι ο ατομικός τύπος. Γεγονός + Ατομικός τύπος Τελεία + Κατηγόρημα Ορίσματα 18

  19. Σύνταξη της Prolog • Όροι • Γεγονότα • Κανόνες • Ερωτήσεις 19

  20. Κανόνες • Οι κανόνες(rules) είναι προτάσεις που ορίζουν νέες σχέσεις με τη βοήθεια άλλων σχέσεων που έχουν ήδη οριστεί. • Οι κανόνες έχουν τη γενική μορφή: A:- B1,B2,…,Bn. (n>=1) • Το Α ονομάζεται κεφαλή (head) του κανόνα και μπορεί να είναι οποιοσδήποτε ατομικός τύπος. Η κεφαλή διαχωρίζεται από το σώμα με τους χαρακτήρες «:-» οι οποίοι μπορούν να διβαστούν ως «αν». Τα Β1,Β2,…,Βn ονομάζονται σώμα (body) του κανόνακαι είναι και αυτοί ατομικοί τύποι. Οι ατομικοί τύποι στο σώμα του κανόνα χωρίζονται συνήθως με κόμμα, ο οποίος δηλώνει λογική σύζευξη (λογικό «και»). • Παράδειγμα brother(X,Y):- parent(Z,X),parent(Z,Y). 20

  21. Σύνταξη της Prolog • Όροι • Γεγονότα • Κανόνες • Ερωτήσεις 21

  22. Ερωτήσεις • Οι ερωτήσεις(queries) είναι η μέθοδος που χρησιμοποιείται στην Prolog για την εξαγωγή γνώσης από το πρόγραμμα. Η σύνταξη τους είναι ?- ατομικός τύπος. • Ο ατομικός τύπος ονομάζεται κλήση (call) της ερώτησης • Οι ερωτήσεις μπορούν να θεωρηθούν ως λογικές προτάσεις προς απόδειξη. Αν η προς απόδειξη ερώτηση ικανοποιείται, η απάντηση στην ερώτηση είναι θετική, και περιλαμβάνει τις τιμές για τις μεταβλητές που περιλαμβάνονται σε αυτή. Διαφορετικά το σύστημα απαντάει αρνητικά. 22

  23. Απλές Ερωτήσεις • Οι απλές ερωτήσεις περιέχουν μία μόνο κλήση. Παράδειγμα προγράμματος και απλών ερωτήσεων: big(bear). big(elephant). small(cat). brown(bear). gray(elephant). black(cat). Ερωτήσεις ?- brown(elephant). - no ?- big(X). - X=bear; X= elephant 23

  24. Σύνθετες Ερωτήσεις • Οι σύνθετες ερωτήσεις περιέχουν παραπάνω από μία κλήσεις. Οι κλήσεις αυτές χωρίζονται με κόμμα που εκφράζει το λογικό «και». Η απάντηση σε μία σύνθετη ερώτηση είναι καταφατική μόνο αν αληθεύουν οι επιμέρους κλήσεις που την αποτελούν. Παραδείγματα ?- small(X),gray(X). - no ?- big(X),gray(X). - X=elephant ?- big(X),black(Y). - X=bear Y=cat; X=elephant Y=cat 24

  25. Εκτέλεση Προγραμμάτων • Η εκτέλεση ενός προγράμματος ξεκινά με μία ερώτηση που υποβάλλει ο χρήστης και φτάνουμε σε λύση όταν έχουν εξαντληθεί όλες οι κλήσεις που αποτελούν την ερώτηση. Η απάντηση στην ερώτηση είναι το αποτέλεσμα του προγράμματος. • Η ερώτηση που υποβάλλει ο χρήστης μπορεί να είναι απλή (να περιέχει μία κλήση) ή σύνθετη (σύζευξη πολλαπλών κλήσεων), π.χ. ?- friend(X,nick). ?- friend(X,nick), friend(X,john). 25

  26. Βήματα εκτέλεσης • Αν δεν υπάρχει άλλη κλήση στην ερώτηση του χρήστη τότε η εκτέλεση του προγράμματος τερματίζεται με επιτυχία και επιστρέφονται στον χρήστη οι τιμές των μεταβλητών που περιείχε η ερώτηση. • Επιλέγονται με τη σειρά, από αριστερά προς τα δεξιά, οι κλήσεις της ερώτησης. Για κάθε κλήση, ο μηχανισμός ελέγχου αναλαμβάνει να βρει μία πρόταση του προγράμματος της οποίας η κεφαλή έχει το ίδιο κατηγόρημα και τάξη με αυτά της κλήσης. • Η ερώτηση θεωρείται ότι απαντήθηκε όταν απαντηθούν επιτυχώς όλες οι κλήσεις της. Εφόσον οι κλήσεις περιέχουν κοινές μεταβλητές, θα πρέπει αυτές να πάρουν την ίδια τιμή. 26

  27. Αναζήτηση προτάσεων (1/2) • Για να ελέγξει η Prolog αν μία κλήση ικανοποιείται από μία πρόταση, χρησιμοποιεί ένα μηχανισμό ταυτοποίησης. Αυτός προσπαθεί να καταστήσει ταυτόσημες μία κλήση μιας ερώτησης και την κεφαλή μίας πρότασης, εκτελώντας τις ελάχιστες απαραίτητες αναθέσεις τιμών σε μεταβλητές (most general unifier). • Όταν μία κλήση ταυτοποιείται με ένα από τα γεγονότα του προγράμματος τότε αυτή ικανοποιείται και απομακρύνεται από την ερώτηση. • Αν η κλήση ταυτοποιείται με έναν κανόνα, τότε αυτή απομακρύνεται από την ερώτηση και τη θέση της παίρνει το σώμα του κανόνα αυτού. 27

  28. Αναζήτηση προτάσεων (2/2) • Αν στο πρόγραμμα υπάρχουν περισσότερες της μία προτάσεις με τις οποίες μπορεί να ταυτοποιηθεί μία κλήση, τότε ταυτοποιείται με την πρόταση που εμφανίζεται πρώτη στο πρόγραμμα. Το σημείο αυτό ονομάζεται σημείο οπισθοδρόμησης. • Σε περίπτωση αποτυχίας εύρεσης λύσης ή σε περίπτωση που ο χρήστης ζητά και άλλη λύση, ο μηχανισμός οπισθοδρόμησης επιστρέφει στο τελευταίο σημείο οπισθοδρόμησης. 28

  29. Κανόνες Ταυτοποίησης (1/2) • Μία μεταβλητή που δεν έχει πάρει τιμή μπορεί να ταυτοποιηθεί με σταθερή, μεταβλητή ή σύνθετο όρο. • Μία σταθερά μπορεί να ταυτοποιηθεί μόνο με τον εαυτό της. • Ένας σύνθετος όρος μπορεί να ταυτοποιηθεί με έναν άλλο σύνθετο μόνο εφόσον έχουν το ίδιο συναρτησιακό σύμβολο και την ίδια τάξη, και με την προϋπόθεση ότι τα αντίστοιχα ορίσματά τους μπορούν να ταυτοποιηθούν. 29

  30. Κανόνες Ταυτοποίησης (2/2) 30

  31. Παράδειγμα εκτέλεσης προγράμματος (1/2) • Έστω το πρόγραμμα greek(socrates). human(turing). human(socrates). fallible(X):- human(X). • και έστω ότι τίθεται το ερώτημα. ?- fallible(Y),greek(Y). 31

  32. Παράδειγμα εκτέλεσης προγράμματος (2/2) greek(socrates). human(turing). human(socrates). fallible(X):- human(X). ?-fallible(Y),greek(Y). {Y=X} ?-human(Y),greek(Y). {Y=socrates} {Y=turing} ?-greek(turing). ?-greek(socrates). αποτυγχάνει yes 32

  33. Αναδρομή • Με τον όρο αναδρομή εννοούμε τη δυνατότητα ένας κανόνας να περιέχει στο σώμα του μια κλήση προς τον εαυτό του. • Οι κανόνες που χρησιμοποιούν αναδρομή ονομάζονται αναδρομικοί, ενώ αυτοί που δεν χρησιμοποιούν μη αναδρομικοί. 33

  34. Παράδειγμα Αναδρομής (1/3) • Έστω τα γεγονότα: parent(john,george). parent(john,nick). parent(jim,bill). parent(jim,jack). parent(gregory,john). parent(gregory,jim). parent(bob,gregory). parent(joseph,bob). • Θέλουμε να ορίσουμε έναν κανόναpredecessor(X,Y), ο οποίος να αληθεύει αν ο Χ είναι πρόγονος του Υ. 34

  35. Παράδειγμα Αναδρομής (2/3) • Λύση με μη αναδρομικούς κανόνες: predecessor(X,Z):- parent(X,Z). predecessor(X,Z):- parent(X,Y),parent(Y,Z). predecessor(X,Z):- parent(X,Y1),parent(Y1,Y2), parent(Y2,Z). … • Με αυτόν τον τρόπο δεν μπορούμε να ορίσουμε τη σχέση για πολύ μακρινούς απογόνους. Π.χ. στην ερώτηση ?- predecessor(X,george). X=john X=gregory X=bob 35

  36. Παράδειγμα Αναδρομής (3/3) • Λύση με αναδρομικούς κανόνες: predecessor(X,Z):- parent(X,Z). predecessor(X,Z):- parent(X,Y),predecessor(Y,Z). • Παρατήρηση: Όταν ένα κατηγόρημα ορίζεται αναδρομικά, εμφανίζεται πάντα με τουλάχιστον δύο κανόνες. Ο πρώτος συνήθως δεν περιέχει αναδρομική κλήση, λειτουργώντας σαν τερματική συνθήκη. 36

  37. Λίστες • Μία λίσταείναι μια ακολουθία από οποιονδήποτε αριθμό στοιχείων. Τα στοιχεία αυτά μπορεί να είναι απλοί όροι, σύνθετοι όροι ή ακόμα και άλλες λίστες. Τα στοιχεία μίας λίστας τοποθετούνται μέσα σε αγκύλες και χωρίζονται μεταξύ τους με κόμμα, π.χ. [dog,3,f(a,b),X,[1,2],s] • Μία λίστα μπορεί να είναι: • Κενή: μία δομή χωρίς όρους που συμβολίζεται με [] • Μία δομή με δύο όρους: την κεφαλή (head)που είναι το πρώτο στοιχείο της λίστας και την ουρά (tail) που είναι το υπόλοιπο τμήμα της λίστας. • Η κεφαλή μίας λίστας μπορεί να είναι οτιδήποτε. Η ουρά όμως πρέπει να είναι πάντα λίστα είτε κενή ή με τη δικιά της κεφαλή και ουρά, π.χ. στην παραπάνω λίστα dogείναι η κεφαλή και[3,f(a,b),X,[1,2],s]η ουρά. 37

  38. Ταυτοποίηση λιστών • Δύο λίστες ταυτοποιούνται εφόσον έχουν τον ίδιο αριθμό στοιχείων και τα αντίστοιχα στοιχεία μπορούν να ταυτοποιηθούν,π.χ. 38

  39. Χειρισμός Λιστών (1/4) • Εύρεση τελευταίου στοιχείου last(X,[X]). last(X,[Head|Tail]):-last(X,Tail). ?-last(c,[a,b,c]). Πρόταση 2 ?-last(c,[b,c]). Πρόταση 2 ?-last(c,[c]). Πρόταση 2 Πρόταση 1 ?-last(c,[]). YES fail 39

  40. Χειρισμός Λιστών (2/4) • Έλεγχος συμπερίληψης member(X,[X|Y]). member(X,[Head|Tail]):-member(X,Tail). • Συνένωση λιστών append([],L,L). append([X|L1],L2,[X|L3]):-append(L1,L2,L3). Η συνένωση μίας λίσταςLμε μία κενή λίστα έχει ως αποτέλεσμα την ίδια τη λίστα. Αν η πρώτη λίστα δεν είναι κενή, μπορεί να χωριστεί σε κεφαλή και ουρά:[X|L1]. Τότε η συνένωση της λίστας[X|L1]και τηςL2 είναι η[X|L3]όπου L3είναι το αποτέλεσμα της συνένωσης των λιστώνL1 και L2. 40

  41. Χειρισμός Λιστών (3/4) • Προσθήκη στοιχείου στην αρχή μίας λίστας add(List,Element,[Element|List]).π.χ. ?-add([a,b,c,d],q,L). L=[q,a,b,c,d]; • Προσθήκη στοιχείου σε οποιαδήποτε θέση στη λίστα add(List,Element,NewList):-append(List1,List2,List), append(List1,[Element|List2],Newlist). Έτσι: ?-add([a,b,c],q,L). L=[q,a,b,c]; L=[a,q,b,c]; L=[a,b,q,c]; L=[a,b,c,q]; no 41

  42. Χειρισμός Λιστών (4/4) • Αφαίρεση στοιχείων από μία λίστα delete(Element,List,NewList):-append(List1,[Element|List2],List), append(List1,List2,NewList). • Αναστροφή λιστών reverse([],[]). reverse([Head|Tail],ReversedList):- reverse(Tail,ReversedTail), append(ReversedTail,[Head],ReversedList). 42

  43. Τελεστές Σύγκρισης(1/2) • Οι τελεστές σύγκρισης χρησιμοποιούνται στα σώματα κανόνων, με σκοπό τον έλεγχο συνθηκών μεταξύ αριθμών και μεταβλητών 43

  44. Τελεστές Σύγκρισης(2/2) • =:= (συντακτική ισότητα – identical) • = (ταυτοποίησης– unification) • Διαφορά μεταξύ = και =:= ?- 1+2 =:= 2+1. yes ?- 1+2 = 2+1. no ?- 1+A = B+2. A=2 B=1 44

  45. Παραδείγματα χρήσης τελεστών σύγκρισης • Έλεγχος για το αν μία λίστα είναι ταξινομημένη sorted([]). sorted([_]). sorted([X,Y|List]):- X=<Y,sorted([Y|List]). • Εύρεση μέγιστου στοιχείου λίστας list_max([X],X). list_max([X|Tail],M):-list_max(Tail,M1),max(X,M1,M). max(X,Y,X):-X>Y. max(X,Y,Y):-X=<Y. 45

  46. Τελεστές αριθμητικών πράξεων 46

  47. Τελεστής απόδοσης τιμής • Η απόδοση των τιμών αριθμητικών εκφράσεων σε μεταβλητές δεν μπορεί να γίνει χρησιμοποιώντας των τελεστή = ?- X=3+4 X=3+4 • Για απόδοση τιμής χρησιμοποιούμε τον τελεστή is ?- X is 3+4 X=7 • Είναι προφανές ότι μπορούμε να χρησιμοποιούμε και μεταβλητές στην έκφραση που ακολουθεί στα δεξιά του τελεστή is. Σε αυτήν την περίπτωση θα πρέπει όλες οι μεταβλητές να έχουν πάρει τιμές τη στιγμή που θα εκτελεστεί ο τελεστής. 47

  48. Παραδείγματα χρήσης τελεστών • Μέγιστός Κοινός Διαιρετής gcd(X,X,X). gcd(X,Y,D):-X<Y, Y1=Y-X, gcd(X,Y1,D). gcd(X,Y,D):-X1 is X-Y, gcd(X1,Y,D). • Άθροισμα στοιχείων λίστας sum_list([],0). sum_list([X|T],Sum):-sum_list(T,Sum1),Sum is Sum1+X. • Εύρεση ν-οστού στοιχείου λίστας n_elem(1,[X|T},X). n_elem(N,[H|T],X):-N1 is N-1, n_elem(N1,T,X). 48

  49. Διαδικασίες εισόδου / εξόδου • Στην Prolog, η επικοινωνία μεταξύ χρήστη και προγράμματος γίνεται συνήθως με τη μορφή ερωτήσεων από την πλευρά του χρήστη και απαντήσεων από την πλευρά του συστήματος. • Η Prolog όμως περιέχει και ειδικές ενσωματωμένες διαδικασίες (built-in procedures), οι οποίες διαβάζουν όρους ή χαρακτήρες από το προκαθορισμένο κανάλι εισόδου (πληκτρολόγιο / αρχείο) και επιστρέφουν το αποτέλεσμα στο προκαθορισμένο κανάλι εξόδου (οθόνη / αρχείο). 49

  50. Είσοδος από το πληκτρολόγιο • get(X): Διαβάζει τον επόμενο χαρακτήρα που πληκτρολογεί ο χρήστης. • read(X): Διαβάζει τον επόμενο όρο που εισάγεται από το πληκτρολόγιο. • Παραδείγματα: ?- get(X),get(Y). Αν ο χρήστης πληκτρολογήσειab η απάντηση που θα επιστραφεί είναι:X=a, Y=b. ?- read(X). a. X=a a no (λείπει η τελεία) [l,k]. X=[l,k] ‘a bc. No (λείπει η δεξιά απόστροφος) 50

More Related