Σύστημα F
Το λήμμα παραθέτει τις πηγές του αόριστα, χωρίς παραπομπές. |
To Σύστημα F, επίσης γνωστό ως πολυμορφικός λ-λογισμός των Ζιράρ-Ρέινολντς και λ-λογισμός δευτέρας τάξης, είναι ένας λ-λογισμός με τύπους που επεκτείνει τον λ-λογισμό με απλούς τύπους εισάγοντας ένα μηχανισμό καθολικής ποσόδειξης επί των τύπων. Ως εκ τούτου, το Σύστημα F αποτελεί φορμαλισμό της έννοιας του παραμετρικού πολυμορφισμού στις γλώσσες προγραμματισμού, και μια θεωρητική βάση γλωσσών όπως η Haskell και η ML. Το Σύστημα F επινοήθηκε ανεξάρτητα από τον λογικολόγο Ζαν-Υβ Ζιράρ και τον επιστήμονα υπολογιστών Τζον Σ. Ρέινολντς.
Επεκτείνοντας το λ-λογισμό με απλούς τύπους που έχει μεταβλητές επί των όρων, το Σύστημα F έχει επιπρόσθετα μεταβλητές επί των τύπων. Για παράδειγμα, το γεγονός ότι η ταυτοτική συνάρτηση μπορεί να έχει οιονδήποτε τύπο της μορφής A→ A γράφεται στο Σύστημα F ως
όπου α είναι μεταβλητή τύπου. Το κεφαλαίο χρησιμοποιείται συνήθως για να εκφράσει συναρτήσεις στο επίπεδο των τύπων, σε αντιπαραβολή με το πεζό που χρησιμοποιείται για συναρτήσεις στο επίπεδο των όρων.
Ως ένα σύστημα αναγωγής όρων, το Σύστημα F είναι ισχυρά κανονικοποιήσιμο. Η εξαγωγή τύπων στο Σύστημα F χωρίς ρητές επισημειώσεις τύπων είναι ωστόσο μη αποφάνσιμη. Με τον ισομορφισμό Κάρι-Χάουαρντ το Σύστημα F αντιστοιχίζεται στην διαισθητική λογική δευτέρας τάξης με μόνη την καθολική ποσόδειξη. Το Σύστημα F μπορεί να θεωρηθεί τμήμα του λ-κύβου, μαζί με εκφραστικότερους λ-λογισμούς με τύπους, συμπεριλαμβανομένων αυτών με εξαρτώμενους τύπους.
Λογική και Κατηγορήματα
[Επεξεργασία | επεξεργασία κώδικα]Ο τύπος του Μπουλ ορίζεται ως: , όπου είναι μεταβλητή τύπου. Αυτός συνεπάγεται τους ακόλουθους ορισμούς για τις αληθοτιμές και :
Εν συνεχεία, με αυτούς τους δύο -όρους, μπορούμε να ορίσουμε μερικούς λογικούς τελεστές:
Απουσιάζει η ανάγκη για μια IFTHENELSE συνάρτηση καθώς οι ίδιοι οι όροι τύπου μπορούν να χρησιμοποιηθούν ως συναρτήσεις απόφασης. Μολοταύτα, αν ζητηθεί γράφεται ως:
Ένα κατηγόρημα είναι συνάρτηση που επιστρέφει μια τιμή τύπου . Το θεμελιωδέστερο κατηγόρημα είναι το ISZERO που επιστρέφει αν και μόνο αν το όρισμά του είναι ο αριθμός Τσερτς 0:
Δομές του Συστήματος F
[Επεξεργασία | επεξεργασία κώδικα]Το Σύστημα F επιτρέπει την φυσική ενσωμάτωση αναδρομικών κατασκευών, σε σχέση με τη θεωρία τύπων του Μάρτιν-Λεφ. Οι αφηρημένες δομές (S) δημιουργούνται με τη χρήση κατασκευαστών, δηλαδή συναρτήσεων με τύπο:
- .
Η αναδρομικότητα εμφανίζεται όταν το ίδιο το παρουσιάζεται μεταξύ κάποιου εκ των τύπων . Δοθέντων τέτοιων κατασκευαστών, ο τύπος του ορίζεται ως:
Για παράδειγμα, οι φυσικοί αριθμοί μπορούν να ορισθούν ως ο επαγωγικός τύπων δεδομένων με κατασκευαστές
Ο αντίστοιχος τύπος στο Σύστημα F είναι . Οι όροι αυτού του τύπου συνιστούν μια τυποποιημένη εκδοχή των αριθμών Τσερτς, μερικοί εκ των οποίων είναι:
- 0 :=
- 1 :=
- 2 :=
- 3 :=
Αντιστρέφοντας τη σειρά των ορισμάτων (i.e., ) ο αριθμός Τσερτς για το είναι μια συνάρτηση που δέχεται μια συνάρτηση f ως όρισμα και επιστρέφει την -ιοστή δύναμη του f. Με άλλα λόγια, ένας αριθμός Τσερτς είναι μια συνάρτηση υψηλής τάξης – δέχεται μια συνάρτηση f ενός ορίσματος και επιστρέφει μια άλλη συνάρτηση ενός ορίσματος.
Χρήση στις γλώσσες προγραμματισμού
[Επεξεργασία | επεξεργασία κώδικα]Η εκδοχή του Συστήματος F που χρησιμοποιήθηκε στο παρόν άρθρο είναι τύπου Τσερτς (οι τύποι επισημειώνονται ρητώς). Η πληροφορία τυποποίησης που εμπεριέχεται στους λ-όρους κάνει τον έλεγχο τύπων ευθύ. Για μια παραλλαγή τύπου Κάρι (χωρίς ρητή επισημείωση τύπων) του Συστήματος F ο Τζο Ουέλς (1994) περιέγραψε ένα "ντροπιαστικό ανοιχτό πρόβλημα" αποδεικνύοντας ότι ο έλεγχος τύπων είναι μη αποφάνσιμος.[1][2]
Το αποτέλεσμα του Ουέλς υπονοεί ότι η εξαγωγή τύπων για το Σύστημα F είναι αδύνατη. Ένας περιορισμός του Συστήματος F, γνωστός ως "Χίντλεϊ-Μίλνερ", ή απλά "HM", έχει ένα εύκολο αλγόριθμο εξαγωγής τύπων και χρησιμοποιείται για πολλές συναρτησιακές γλώσσες προγραμματισμού όπως η Haskell 98 και η ML. Προϊόντος του χρόνου, καθώς οι περιορισμοί των συστημάτων τύπου Χίντλεϊ-Μίλνερ έγιναν εμφανείς, οι γλώσσες σταθερά κινούνταν προς εκφραστικότερες λογικές για τα συστήματα τύπων τους. Για παράδειγμα, από το 2008 ο GHC, ένας μεταγλωττιστής της Haskell, υπερέβη το HM, και τώρα χρησιμοποιεί το Σύστημα F επεκτεταμένο με μη συντακτική ισότητα τύπων.
Σύστημα Fω
[Επεξεργασία | επεξεργασία κώδικα]Ενώ το Σύστημα F αντιστοιχίζεται με τον πρώτο άξονα του λ-κύβου του Μπάρεντρεγκτ, το Σύστημα Fω συνδυάζει τον πρώτο άξονα (πολυμορφισμό) με το δεύτερο άξονα (τελεστές τύπων) αποτελώντας ένα διαφορετικό, πολυπλοκότερο σύστημα.
Το Σύστημα Fω μπορεί να οριστεί επαγωγικά σε μια οικογένεια συστημάτων, όπου η επαγωγή βασίζεται στα είδη που επιτρέπονται σε κάθε σύστημα:
- Το επιτρέπει τα είδη:
- (είδος των τύπων) και
- όπου και (είδος των συναρτήσεων από τύπους σε τύπους, όπου ο τύπος όρισμα είναι κατώτερης τάξης)
Στο όριο μπορεί να ορισθεί το ως
Δηλαδή το Fω είναι το σύστημα που επιτρέπει συναρτήσεις από τύπους σε τύπους όπου το όρισμα και το αποτέλεσμα μπορούν να είναι οιασδήποτε τάξης.
Σημειώνεται ότι τα ορίσματα αυτών των απεικονίσεων στο Fω παρά την απουσία περιορισμών στην τάξη τους, προέρχονται από ένα περιορισμένο σύμπαν: πρέπει να είναι τύποι και όχι τιμές. Το Σύστημα Fω δεν επιτρέπει απεικονίσεις από τιμές σε τύπους (εξαρτώμενοι τύποι), αλλά επιτρέπει απεικονίσεις από τιμές σε τιμές ( αφαίρεση), από τύπους σε τιμές ( αφαίρεση, εμφανίζεται και ως ) και από τύπους σε τύπους ( αφαίρεση στο επίπεδο των τύπων).
Δείτε επίσης
[Επεξεργασία | επεξεργασία κώδικα]- Οι υπαρξιακοί τύποι είναι το υπαρξιακώς ποσοδειγμένο αντίστοιχο των καθολικών τύπων.
- Το System F<: επεκτείνει το Σύστημα F με υποτύπους, προσεγγίζοντας πολύ περισσότερο πραγματικές γλώσσες προγραμματισμού της οικογένειας ML.
Αναφορές
[Επεξεργασία | επεξεργασία κώδικα]- ↑ http://www.macs.hw.ac.uk/~jbw/research-summary.html
- ↑ «Αρχειοθετημένο αντίγραφο». Αρχειοθετήθηκε από το πρωτότυπο στις 16 Φεβρουαρίου 2007. Ανακτήθηκε στις 10 Φεβρουαρίου 2012.
- Girard, Jean-Yves (1971). «Une Extension de l'Interpretation de Gödel à l'Analyse, et son Application à l'Élimination des Coupures dans l'Analyse et la Théorie des Types». Proceedings of the Second Scandinavian Logic Symposium. Amsterdam, pp. 63–92.
- Reynolds, John (1974). «Towards a Theory of Type Structure». Colloque sur la Programmation. Paris, France, pp. 408–425. ftp://ftp.cs.cmu.edu/user/jcr/theotypestr.pdf. Ανακτήθηκε στις 6 Apr 2010.[νεκρός σύνδεσμος]
- Girard, Lafont and Taylor, Proofs and Types. Cambridge University Press, 1989, ISBN 0 521 37181 3.
- J. B. Wells. "Typability and type checking in the second-order lambda-calculus are equivalent and undecidable." In Proceedings of the 9th Annual IEEE Symposium on Logic in Computer Science (LICS), pages 176–185, 1994. [1]
Πρόσθετες Πηγές
[Επεξεργασία | επεξεργασία κώδικα]- Pierce, Benjamin (2002). Types and Programming Languages. MIT Press. ISBN 0-262-16209-1. Chapter 23: Universal Types, and Chapter 25: An ML Implementation of System F.
Εξωτερικοί σύνδεσμοι
[Επεξεργασία | επεξεργασία κώδικα]- Summary of System F by Franck Binard.