Αστέρι Κλέινι
Στα Μαθηματικά, στην Λογική, και στην Επιστήμη Υπολογιστών, το Αστέρι Κλέινι (Kleene star), ή η κλειστότητα Κλέινι (Kleene closure), είναι μια πράξη με ένα όρισμα, που εφαρμόζεται σε σύνολα συμβόλων ή χαρακτήρων ή σε συμβολοσειρές. Η εφαρμογή του Αστεριού Κλέινι σε ένα σύνολο V συμβολίζεται ως V*. Χρησιμοποιείται ευρύτατα για κανονικές εκφράσεις, αφού ειδικά για το σκοπό αυτόν το εισήγαγε ο Στίβεν Κλέινι (Stephen Kleene)[1], όταν χαρακτήρισε ορισμένα αυτόματα.
Ορισμός
ΕπεξεργασίαΕπί ενός αλφαβήτου , ως ορίζεται το σύνολο όλων των συμβολοσειρών που δημιουργούνται με τα σύμβολα του , περιλαμβάνοντας και την κενή συμβολοσειρά.
Τυπικές Γλώσσες
ΕπεξεργασίαΕξ ορισμού το αστέρι Κλέινι είναι πράξη που μπορεί να εφαρμόζεται σε τυπικές γλώσσες. Έστω γλώσσα , τότε είναι το σύνολο συμβολοσειρών που προκύπτει από τη συνένωση μηδέν ή περισσότερων συμβολοσειρών της . Επομενως:
για κάποιο και
όπου w κάποια συμβολοσειρά.
Με βάση το Αστέρι Κλέινι ορίζεται και η πράξη που συμβολίζεται με και περιγράφει τη συνένωση (concatenation) , οριζόμενη ως ακολούθως:
για κάποιο και
όπου
- η γλώσσα,
- το Αστέρι Κλέινι,
- κάποια συμβολοσειρά.
Δηλαδή η είναι η μικρότερη γλώσσα που περιέχει την και όλες τις συμβολοσειρές που προκύπτουν με συνένωση (concatenation). Σημειώνεται ότι είναι η κλειστότητα της υπό την πράξη της συνένωσης.[2]
Παραδείγματα
ΕπεξεργασίαΕφαρμογή αστεριού Κλέινι σε σύνολο στοιχειοσειρών :
- {"ab", "c"}* = {ε, "ab", "c", "abab", "abc", "cab", "cc", "ababab", "ababc", "abcab", "abcc", "cabab", "cabc", "ccab", "ccc", ...}
Εφαρμογή αστεριού Κλέινι σε σύνολο χαρακτήρων :
- {'a', 'b', 'c'}* = {ε, "a", "b", "c", "aa", "ab", "ac", "ba", "bb", "bc", ...}
Γενίκευση
ΕπεξεργασίαΤο αστέρι Κλέινι συχνά γενικεύεται για οποιοδήποτε Μονοειδές (monoid) (M, .).
Μονοειδές είναι ένα σύνολο M, για τα στοιχεία του οποίου είναι ορισμένη μιά πράξη (μαθηματικά) με δύο ορίσματα '.', η οποία έχει τις εξής ιδιότητες :
- (Κλειστότητα) : για κάθε a και b που ανήκουν στο M ισχύει ότι το (a . b) ανήκει στο M
- (Προσεταιρισμός) : για κάθε a, b και c που ανήκουν στο M ισχύει ότι ((a . b) . c) = (a . (b . c))
- (Ουδέτερο στοιχείο) : υπάρχει ένα ε που ανήκει στο M, τέτοιο ώστε για κάθε a που ανήκει στο M ισχύει ότι (a . ε) = (ε . a) = a
Αν το V είναι ένα υποσύνολο του M, τότε το V* ορίζεται ως το μικρότερο υπερσύνολο του V που περιέχει το ε (την κενή στοιχειοσειρά) και είναι κλειστό για την περιγραφείσα πράξη. Το V* είναι επίσης ένα μονοειδές, και ονομάζεται μονοειδές παραγόμενο από το V.
Αυτή είναι γενίκευση του αστεριού Κλέινι που περιγράφτηκε προηγουμένως αφού το σύνολο όλων των στοιχειοσειρών που σχηματίζονται από κάποιο σύνολο συμβόλων είναι ένα μονοειδές (με ορισμένη πράξη την συναλύσωση στοιχειοσειρών).
Πηγές
ΕπεξεργασίαΒλέπε επίσης
Επεξεργασία- Άλγεβρα Κλέινι (Kleene algebra)
- Μορφή Μπάκους-Νάουρ
- Εκτεταμένη μορφή Μπάκους-Νάουρ (Extended Backus-Naur form)
- Λήμμα αντλίας (Pumping Lemma)
- Πρόβλημα ύψους αστεριού (Star height problem), Γενικευμένο πρόβλημα ύψους αστεριού, Γλώσσα χωρίς αστέρια (star-free language)