Θεωρία Υπολογισμού και Πολυπλοκότητα



Σχετικά έγγραφα
Θεωρία Υπολογισμού και Πολυπλοκότητα

Chapter 7, 8 : Time, Space Complexity

Chapter 7, 8 : Time, Space Complexity

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 18: Χρονική και Χωρική Πολυπλοκότητα

CSC 314: Switching Theory

Λύσεις 4ης Σειράς Ασκήσεων

ΘΕΩΡΙΑ ΥΠΟΛΟΓΙΣΜΩΝ ΚΑΙ ΑΥΤΟΜΑΤΩΝ

Chapter 7, 8 : Completeness

t M (w) T ( w ) O( n) = O(n 2 )

Μη Ντετερμινισμός και NP-Πληρότητα

Μη Ντετερμινισμός και NP-Πληρότητα

Πολυπλοκότητα. Παράμετροι της αποδοτικότητας ενός αλγόριθμου: Χρόνος εκτέλεσης. Απαιτούμενοι πόροι, π.χ. μνήμη, εύρος ζώνης. Προσπάθεια υλοποίησης

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Επανάληψη Μαθήματος

Αλγόριθµοι και Πολυπλοκότητα

Κλάσεις Πολυπλοκότητας

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 13: Παραλλαγές Μηχανών Turing και Περιγραφή Αλγορίθμων

Επίπεδα Γραφήματα : Προβλήματα και Υπολογιστική Πολυπλοκότητα

Μη Ντετερμινισμός και NP-Πληρότητα

Σειρά Προβλημάτων 5 Λύσεις

Κεφάλαιο 8. NP και Υπολογιστική Δυσεπιλυσιμότητα. Χρησιμοποιήθηκε υλικό από τις αγγλικές διαφάνειες του Kevin Wayne.

Φροντιστήριο 11 Λύσεις

ΕΛΛΗΝΙΚΟ ΑΝΟΙΚΤΟ ΠΑΝΕΠΙΣΤΗΜΙΟ

Θεωρία Υπολογισμού και Πολυπλοκότητα Αναγωγές

Κατώτερα φράγματα Κατώτερο φράγμα: εκτίμηση της ελάχιστης εργασίας που απαιτείται για την επίλυση ενός προβλήματος. Παραδείγματα: Αριθμός συγκρίσεων π

Η NTM αποδέχεται αν µονοπάτι στο δέντρο που οδηγεί σε αποδοχή.

Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό υλικό, όπως εικόνες, που υπόκειται σε άλλου τύ

ΕΛΛΗΝΙΚΟ ΑΝΟΙΚΤΟ ΠΑΝΕΠΙΣΤΗΜΙΟ

NP-πληρότητα. Λεωνίδας Παληός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων

Σειρά Προβλημάτων 5 Λύσεις

ΑΛΓΟΡΙΘΜΟΙ. Ενότητα 11: Περιορισμοί της Αλγοριθμικής Ισχύος

Φροντιστήριο 10 Λύσεις

Προσεγγιστικοί Αλγόριθμοι

ΚΕΦΑΛΑΙΟ 12: Θεωρία υπολογισµών

Πεπερασμένα Αυτόματα. ιδάσκοντες: Φ. Αφράτη,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

ΔΥΣΚΟΛΙΑ ΣΤΗΝ ΠΡΟΣΕΓΓΙΣΙΜΟΤΗΤΑ

Προσεγγιστικοί Αλγόριθμοι

Κεφάλαιο 8. NP και Υπολογιστική Δυσεπιλυσιμότητα. Παύλος Εφραιμίδης V1.1,

Σειρά Προβλημάτων 5 Λύσεις

num(m(w 1 ;... ; w k )) = f(num(w 1 ),..., num(w k ))

Σειρά Προβλημάτων 5 Λύσεις

Θεωρία Υπολογισμού Άρτιοι ΑΜ. Διδάσκων: Σταύρος Κολλιόπουλος. eclass.di.uoa.gr. Περιγραφή μαθήματος

Θεωρία Υπολογισμού Αρτιοι ΑΜ Διδάσκων: Σταύρος Κολλιόπουλος eclass.di.uoa.gr

Φροντιστήριο 9 Λύσεις

Θεωρήµατα Ιεραρχίας Ειδικά Θέµατα Υπολογισµού και Πολυπλοκότητας, Μάθηµα Βασικής Επιλογής Εαρινού Εξαµήνου Τοµέας Εφαρµογών και Θεµελιώσεων

ΑΛΓΟΡΙΘΜΟΙ ΚΑΙ ΠΟΛΥΠΛΟΚΟΤΗΤΑ Φεβρουάριος 2005 Σύνολο μονάδων: 91

Υπολογιστική Πολυπλοκότητα

Κεφάλαιο 8. NP και Υπολογιστική Δυσεπιλυσιµότητα. Χρησιµοποιήθηκε υλικό από τις αγγλικές διαφάνειες του Kevin Wayne.

Ασυμπτωτικός Συμβολισμός

Σειρά Προβλημάτων 4 Λύσεις

Υποθέσεις - - Θεωρήματα Υποθέσεις - Θεωρήματα Στα μαθηματικά και στις άλλες επιστήμες κάνουμε συχνά υποθέσεις. Οταν δείξουμε ότι μια υπόθεση είναι αλη

Σειρά Προβλημάτων 5 Λύσεις

Η δυαδική σχέση M ( «παράγει σε ένα βήμα» ) ορίζεται ως εξής: (q, w) M (q, w ), αν και μόνο αν w = σw, για κάποιο σ Σ

Υπολογιστική Πολυπλοκότητα Εξέταση Ιουνίου 2017 Σελ. 1 από 5

Θεωρία Υπολογισμού και Πολυπλοκότητα Κανονικές Γλώσσες (1)

Υπολογισιμότητα και Πολυπλοκότητα Computability and Complexity

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 16: Αναγωγές

ΣΧΕΣΕΙΣ ΜΕΤΑΞΥ ΚΛΑΣΕΩΝ ΠΟΛΥΠΛΟΚΟΤΗΤΑΣ

Υπολογιστικό Πρόβληµα

Κυκλώματα και βασικές Ιδιότητες

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 15: Διαγνωσιμότητα (Επιλυσιμότητα) ΙΙ

Σειρά Προβλημάτων 5 Λύσεις

ΚΕΦΑΛΑΙΟ 12: Θεωρία υπολογισμού

Σειρά Προβλημάτων 4 Λύσεις

Θεωρία Υπολογισμού και Πολυπλοκότητα

ILP-Feasibility conp

Θεωρία Υπολογισμού και Πολυπλοκότητα

Υπολογιστική Πολυπλοκότητα

Σειρά Προβλημάτων 4 Λύσεις

Θεωρία Υπολογισμού και Πολυπλοκότητα Διαγνωσιμότητα

Υποθέσεις - Θεωρήματα. Μαθηματικά Πληροφορικής 1ο Μάθημα. Η χρυσή τομή. Υποθέσεις - Εικασίες

Υπολογιστική Πολυπλοκότητα

Στοιχεία Θεωρίας Υπολογισμού

Ασυμπτωτικός Συμβολισμός

Θεμελιώδη Θέματα Επιστήμης Υπολογιστών

Το πρόβλημα μονοδρόμησης (The One-Way Street Problem)

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ

Θεωρία Υπολογισμού και Πολυπλοκότητα

Θεωρία Υπολογισμού και Πολυπλοκότητα Χρονική Πολυπλοκότητα

Τεχνικές Αποδείξεις Κάτω Φραγμάτων

HEAD INPUT. q0 q1 CONTROL UNIT

4.3 Ορθότητα και Πληρότητα

Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Cretive Commons. Για εκπαιδευτικό υλικό, όπως εικόνες, που υπόκειται σε άλλου τύπ

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 2: Μαθηματικό Υπόβαθρο

Αλγόριθμοι Προσέγγισης για NP-Δύσκολα Προβλήματα

Αλγόριθμοι και Πολυπλοκότητα

conp and Function Problems

Κλάση NP, NP-Complete Προβλήματα

ΕΠΛ 211: Θεωρία Υπολογισμού και Πολυπλοκότητας. Διάλεξη 14: Διαγνωσιμότητα (Επιλυσιμότητα)

ΘΕΩΡΙΑ ΥΠΟΛΟΓΙΣΜΩΝ ΚΑΙ ΑΥΤΟΜΑΤΩΝ

ΘΕΩΡΙΑ ΥΠΟΛΟΓΙΣΜΩΝ ΚΑΙ ΑΥΤΟΜΑΤΩΝ

Ασυμπτωτικός Συμβολισμός

Αλγόριθμοι για αυτόματα

Εισαγωγή στην Επιστήμη των Υπολογιστών

Θεωρία Υπολογισμού και Πολυπλοκότητα

για NP-Δύσκολα Προβλήματα

Σειρά Προβλημάτων 4 Λύσεις

Σειρά Προβλημάτων 5 Λύσεις

Εισαγωγή στους Αλγόριθμους. Παύλος Εφραιμίδης, Λέκτορας

Σειρά Προβλημάτων 4 Λύσεις

Τεχνητή Νοημοσύνη. 8η διάλεξη ( ) Ίων Ανδρουτσόπουλος.

Transcript:

Θεωρία Υπολογισμού και Πολυπλοκότητα Κεφάλαιο 14. Χρονική Πολυπλοκότητα 17, 20, 24 Απριλίου 2007 Δρ. Παπαδοπούλου Βίκη 1

Υπολογίσιμα και Εφικτά Υπολογίσιμα Προβλήματα Είδαμε ότι 1. Οτιδήποτε μπορούμε να περιγράψουμε με ένα αλγόριθμο μπορεί να υπολογιστεί με μια μηχανή Turing 2. υπάρχουν προβλήματα που δεν μπορούν να επιλυθούν (π.χ. πρόβλημα τερματισμού 3. υπάρχουν προβλήματα που μπορούν να επιλυθούν Επιλύσιμα προβλήματα Πόσους υπολογιστικούς πόρους απαιτούν χρόνο χώρο? 2

Παράδειγμα Το πρόβλημα του Πλανώδιου πωλητή: Για ένα σύνολο από πόλεις και κόστη διαδρομών από πόλη σε πόλη, βρες μια διαδρομή που να περνά από κάθε κόμβο του δικτύου ακριβώς μια φορά και να ελαχιστοποιεί την συνολικό κόστος της διαδρομής που θα ακολουθηθεί. Μπορεί να λυθεί σε (n-1)! χρόνο. Είναι μη ρεαλιστικός! Συμπέρασμα. Ορισμένα επιλύσιμα προβλήματα είναι υπολογιστικά δύσκολα 3

Ασυμπτωματικός Ρυθμός Ανάπτυξης Μια συνάρτηση f(n) λέμε ότι αυξάνεται πιο αργά από την συνάρτηση g(n) και συμβολίζεται f(n) g(n) εάν Γράφουμε f(n)= o (g(n)) εάν f(n) g(n) f(n)= Ο (g(n)) εάν για όλα τα n 0, f(n) K g(n). Γνωστές συναρτήσεις: (i=σταθερό) 1. Πολυλογαριθμική Σειρά: { (log(n)) i i = 1,2,...} 2. Πολυωνιμική Σειρά: {n i i = 1, 2,...} 3. Υποεκθετική Σειρά: { nlog n i i = 1,2,...} 4. Εκθετική Σειρά: {2 in i = 1,2,...} 5. Υπερεκθετική Σειρά: {2 n i i = 1,2,...} 4

Ιδιότητες Σε κάθε σειρά, εάν i < j τότε η i-οστή συνάρτηση αυξάνεται πιο αργά από την j-οστή. Π.χ., nlog(n) 3 nlog(n) 4. Για οποιεσδήποτε δύο σειρές, κάθε συνάρτηση στην προγενέστερη σειρά αυξάνεται πιο αργά από οποιαδήποτε συνάρτηση στην μεταγενέστερη σειρά. (εκτός απο την πρώτη συνάρτηση της τελευταίας σειράς). Π.χ., (log(n) 64 n 10 2 3n 2n 3. 5

Πολυπλοκότητα Χώρου και Χρόνου Υπολογιστική Πολυπλοκότητα μιας μηχανής Turing Χρόνος Χώρος (μνήμη) ΧΡΟΝΟΣ. Χρόνος εκτέλεσης μιας μηχανής Turing με είσοδο w, Time M (x) : Aριθμός βημάτων της μηχανής έως ότου η μηχανή τερματίσει. Αν δεν τερματίσει ο χρόνος είναι άπειρος Φράγμα χρόνου της M, t(n) x n, ( υποθέτουμε t(n) n+1 ) Time M (x) max{n+1, t(n)} 6

Πολυπλοκότητα Χρόνου Ποιο μοντέλο μηχανής Turing θεωρούμε? Θεώρημα. Για οποιαδήποτε Ντετερμινιστική Μηχανή Τuring (NMT) με πολλές ταινίες M, υπάρχει μια διπλής κατεύθυνσης, μονής ταινίας ΝΜΤ M 1 που υπολογίζει την ίδια συνάρτηση τέτοια ώστε για όλες τις εισόδους x, έχουμε Time M1 (x) c (Time M (x)) 2 γιακάποιασταθερά c > 0. 7

Πολυπλοκότητα Χώρου Για λέξη εισόδου x, ο χώρος μνήμης, Space M (x) τον οποίο η ΝΜΤ M χρησιμοποιεί πάνω στην x είναι οαριθμόςτωνκελιώνπάνωστιςταινίεςεργασίας(διάβασμα, εγγραφή) τα οποία η κεφαλή της ταινίας επισκέπτεται τουλάχιστον μια φορά κατά την διάρκεια του υπολογισμού. Η ΝΜΤ έχει ένα φράγμα χώρου s(n) εάν για είσοδο x, Space M (x) max {1,d s( x )e} Θεώρημα Για οποιοδήποτε ΝΜΤ με πολλές ταινίες Μ, υπάρχει ένα τυπικό ΝΜΤ μονής ταινίας εργασίας M 2 που υπολογίζει την ίδια συνάρτηση τέτοιο ώστε Space M2 (x) Space M (x) για όλα τα x. 8

Πολυπλοκότητα Χρόνου και Χώρου Θεώρημα 1. Για οποιαδήποτε ΝΜΤ M μονής ταινίας εργασίας και οποιαδήποτε είσοδο x, Space M (x) Time M (x) + 1. Συμπέρασμα. Ο χώρος είναι πιο ισχυρός από τον χρόνο, μπορούμε να επαναχρησιμοποιήσουμε τον χώρο ενώ τον χρόνο όχι. Ορισμός. Μια γλώσσα έχει χρονική πολυπλοκότητα f(n) εάν αποφασίζεται από μια ΝΜΤ με πολλές ταινίες με φράγμα χρόνου f(n). Ορισμός. Μιαγλώσσαέχειχωρική πολυπλοκότητα f(n) εάν αποφασίζεται από μια ΝΜΤ με πολλές ταινίες με φράγμα χώρου f(n). Για οποιαδήποτε συνάρτηση f(n), ορίζουμε κλάσεις πολυπλοκότητας: DTIME(f(n)) = {L L έχει χρονική πολυπλοκότητα f(n) } DSPACE(s(n)) = {L L έχει χωρική πολυπλοκότητα s(n) } 9

Συντελεστές της f(n) είναι σημαντικοί? Θεώρημα Συμπίεσης Ταινίας. Για οποιαδήποτε συνάρτηση s(n) και οποιαδήποτε σταθερά c > 0, DSPACE(s(n)) = DSPACE(c s(n)). Θεώρημα Θεώρημα Γραμμικής Επιτάχυνσης. Υποθέστε ότι lim n t(n)/n =. Τότε, για οποιαδήποτε σταθερά c > 0, DTIME(t(n)) = DTIME(c t(n)) Συμπέρασμα. Χρησιμοποιούμε τους τυπικούς ασύμπτωτικους ρυθμούς ανάπτυξης της f(n) (πχ. log n, n 2, 2 n ) για τις κλάσεις πολυπλοκότητας DSPACE(f(n)) και DTIME(f(n)) χωρίς να καθορίσουμε τους συντελεστές της f(n). 10

Κλάσεις Πολυπλοκότητας 11

Κλάση P (Polynomial Time) H ΝΜΤ M είναι μια ΝΜΤ πολυωνυμικού χρόνου εάν η M έχει φράγμα χρόνου t(n) για κάποια πολυωνυμική συνάρτηση t(n) = n c. Μια γλώσσα L είναι πολυνωνυμικά αποφασίσιμη αν υπάρχει μηχανή ΝΜΤ πολυωνυμικού χρόνου Μ που την αποφασίζει. Συμπερασματικά: H κλάση P περιέχει προβλήματα που μπορούν να αποφασιστούν σε πολυωνυμικό χρόνο από μια Ντετερμινιστική μηχανή Turing. Παρατήρηση. Από το Θεώρημα 1 (Space M (x) Time M (x) + 1), P PSPACE 12

Κλάση P Θεώρημα. ΗκλάσηP είναι κλειστή ως προς την πράξη της σύνθεσης, σύμπτυξης, ένωση, τομή, και συμπληρώματος, για γλώσσες. Απόδειξη. (ένωση A B) Έστω Μ 1 η ΝΜΤ που αποφασίζει για την γλώσσα A με φράγμα χρόνου p 1 Έστω Μ 2 η ΝΜΤ που αποφασίζει για την γλώσσα την B με φράγμα χρόνου p 2 p 1, p 2 : πολυωνυμικές συναρτήσεις ΗμηχανήΜ δύο ταινιών, για είσοδο w, αντιγράφει την w στην 2 η ταινία. Πρώτα προσομοιώνει την Μ 1 με είσοδο w στην 1η ταινία Mετά προσομοιώνει την M 2 με είσοδο w στην 2η ταινία Εάν είτε η Μ 1 είτε η Μ 2 αποδέχεται τη λέξη, η Μ αποδέχεται τη λέξη Αλλιώς την απορρίπτει. η Μ αποδέχεται την w εάν και μόνο αν είτε w Α ή w B. 13

Θήκη Kleene Έστω μια γλώσσα A P. Δείχνουμε ότι τότε Α * P. w in A* εάν και μόνο αν υπάρχει διαμερισμός της w ( w =n) σε υποσυμβολισειρές x=x 1 L x m, 1 m n, τέτοια ώστε x i A, για κάθε i=1, L m. Θεώρημα. ΗκλάσηP είναι κλειστή ως προς την πράξη της θήκης Kleene για γλώσσες. Απόδειξη. (Φροντιστήριο) 14

Γενικά Αποδεκτή Άποψη. ΗκλάσηP αντιπροσωπεύει την κλάση των εφικτών επιλύσιμων γλωσσών, ήαπλάεφικτών προβλημάτων. 15

Κλάση PSPACE (polynomial space) Περιέχει τα προβλήματα που μπορούν να λυθούν σε πολυωνυμικό χώρο. Ένα πρόβλημα που απαιτεί για παράδειγμα εκθετικό χρόνο μπορεί να απαιτεί μόνο πολυωνυμικό χώρο. Επειδή μπορούμε να αναγραφούμε στην ταινία στα σημεία τα οποία δεν θα τα χρειαστούμε στο μέλλον. Θεώρημα. PSPACE EXPPOLY Μια γλώσσα στην PSPACE μπορεί να επιλυθεί σε υποεκθετικό χρόνο. Μπορεί να λυθεί σε πολυνωνυμικό χρόνο? Μεγάλο αναπάντητο ερώτημα.. 16

Κλάση P 17

Προβλήματα στην κλάση P Μια κανονική γλώσσα L μπορεί να αποφασιστεί σε πολυωνυμικό χρόνο: Πώς?: από το διάγραμμα καταστάσεων ενός αυτόματου που δέχεται τη γλώσσα προκύπτει ένας αλγόριθμος που ελέγχει εάν w L, σε χρόνο w. Σύνολο Κανονικών γλωσσών P Μια γλώσσα χωρίς συμφραζόμενα L μπορεί να αποφασιστεί σε πολυωνυμικό χρόνο: Πώς?: από το διάγραμμα καταστάσεων του αυτόματου στοίβας το οποίο δέχεται τη γλώσσα προκύπτει ένας αλγόριθμος που ελέγχει εάν w L, σε χρόνο w.(σύνθετος αλγόριθμος, επειδή τα αυτόματα στοίβας είναι μη ντετερμινιστικά) Σύνολο γλωσσών χωρίς συμφραζόμενα P 18

Προβλήματα Πρόβλημα Συνεκτικότητας. Δεδομένου ενός κατευθυνόμενου γραφήματος G, υπάρχει ένα μονοπάτι μεταξύ δύο κόμβων v i, v j, όπου v i, v j V? Το πρόβλημα ανήκει στο P? H κλάση P αφορά γλώσσες!! Μετατρέπουμε το πρόβλημα έτσι ώστε να αφορά γλώσσες : Το Πρόβλημα Συνεκτικότητας σε μορφή γλώσσας: Γλώσσα R = {κ(g) b(i) b(j) : υπάρχει μονοπάτι από τον v i, v j στο G(V, E) } κ(g) = κωδικοποίηση G : δίνεται με ένα πίνακα γειτνίασης a(), a(i,j) =1 εάν και μόνο εάν υπάρχει ακμή μεταξύ των κόμβων v i και v j, όπου i, j n. b(i), b(j) = κωδικοποίηση των κόμβων v i και v j 19

Προβλήματα και Γλώσσες Έτσι, αναφερόμαστε σε προβλήματα και εννοούμε ότι τις αντίστοιχες γλώσσες τους. Το πρόβλημα συνεκτικότητας ανήκει P λύνεται σε χρόνο O(n 2 )(n=πλήθος κόμβων του G) Πώς? Μέσω ψαξίματος κατά πλάτος αρχίζοντας από τον κόμβο v i. 20

Προβλήματα.. Πρόβλημα Κύκλου Euler: Δεδομένου ενός γραφήματος G, υπάρχει κλειστό μονοπάτι στο G, το οποίο χρησιμοποιεί κάθε ακμή του G ακριβώς μια φορά? Σε μορφή γλώσσας: L = {κ(g) : το G είναι ένα γράφημα Euler (=έχει ένα κύκλο Euler)} Η L ανήκει στο P: Γιατί υπάρχει ένας χαρακτηρισμός (τηςμορφήςοg είναι γράφος Euler εάν και μόνο αν ισχύει κάτι) οοποίοςμπορεί να ελεγχθεί σε πολυωνυμικό χρόνο. 21

Προβλήματα που φαίνεται να ΜΗΝ ανήκουνστηνκλάσηp 22

Προβλήματα Πρόβλημα Κύκλου Hamilton: Δεδομένου ενός γραφήματος G, υπάρχειέναςκύκλοςπουναπερνάαπόκάθεκορυφήτουg ακριβώς μια φορά? Ένας αλγόριθμος για το πρόβλημα: εξέτασε όλες τα πιθανά μονοπάτια κόμβων έλεγξε εάν είναι Hamilton κύκλος. Απαιτεί εκθετικό χρόνο! Δενείναιγνωστόςπολυωνυμικόςαλγόριθμοςγιατοπρόβλημα 23

Προβλήματα Βελτιστοποίησης Το πρόβλημα του Πλανώδιου πωλητή: Για ένα δεδομένο δίκτυο με n κόμβους και αποστάσεις d ij που συμβολίζει την απόσταση των κόμβων v i v j, βρες μια διαδρομή π: που να περνά από κάθε κόμβο του δικτύου ακριβώς μια φορά και ελαχιστοποιεί τηνσυνολικήαπόστασηπουθαδιανυθεί. Δηλ. Βρες μια μετάθεση π του {1, 2, n} (δηλ. π(i) είναι η σειρά που περνούμε από την πόλη i στην διαδρομή) που να ελαχιστοποιεί το άθροισμα: c(π)= d π(1)π(2) + d π(1)π(2) +.+ d π(1)π(2) Μας ενδιαφέρει ΟΧΙ ΜΟΝΟ να βρουμε κάτι αλλά υπάρχει μια συνάρτηση κόστους c(π) ΚΑΙ επιθυμούμε να ικανοποιείται από το κατι. Ως γλώσσα: Δεδομένου ενός δικτύου με n κόμβους και αποστάσεις d ij και ενός ακεραίου B, υπάρχει μια μετάθεση του δικτύου τέτοια ώστε c(π) Β? 24

Το πρόβλημα του Πλανώδιου πωλητή ΠΑΡΑΤΗΡΗΣΗ. Αν μπορούσαμε να λύσουμε το πρόβλημα βελτιστοποίησης, θα μπορούσαμε να λύσουμε και το πρόβλημα ως γλώσσα. δηλ. το πρόβλημα βελτιστοποίησης είναι πιο δύσκολο από την έκδοση του προβλήματος ως γλώσσα Δεν είναι γνωστός πολυνωνυμικός αλγόριθμος για το πρόβλημα 25

Το πρόβλημα Μέγιστου Ανεξάρτητου Συνόλου Το πρόβλημα μέγιστου ανεξάρτητου συνόλου: Για ένα δεδομένο γράφημα G(V, E) βρες ένα υποσύνολο I V τέτοιο ώστε για κάθε v i, v j Ι ισχύει (v i, v j ) Ε το Ι είναι το μέγιστο δυνατό για το γράφημα G. Σε μορφή γλώσσας: Το πρόβλημα μέγιστου ανεξάρτητου συνόλου: Για ένα δεδομένο γράφημα G(V, E) και ενός ακεραίου K, υπάρχει ένα υποσύνολο I V τέτοιο ώστε για κάθε v i, v j Ι (v i, v j ) V Ι K? Δεν είναι γνωστός πολυωνυμικός αλγόριθμος για το πρόβλημα 26

Ικανοποιησιμότητα Τύπων Bool Ορισμός. Τύπος Bool Χ={x 1, L, x n } : Δυαδικές Μεταβλητές Bool : αρνήσεις των x 1 L, x n ή literals Συνθήκη = (x i L x j )= (x i, L, x j ) = x 1 ή ή x j (x i : στοιχεία της C) Τύπος Bool σε κανονική διαζευκτική μορφή: F = {C 1, L, C m } = C 1 και C 2 και C m Παράδειγμα. 27

Ικανοποιησιμότητα Τύπων Bool Ορισμός (συνέχεια). Απόδοση τιμών αληθείας (truth assignment) Τ για τον F είναι μια συνάρτηση Τ: Χ {>, }, όπου > = αληθές = ψευδές Η Τ ικανοποιεί τον F εάν: για κάθε συνθήκη C F υπάρχει τουλάχιστον μια μεταβλητή x i, τέτοια ώστε είτε 1. T(x i ) = > και x i C (x i : αληθές στοιχείο) είτε 2. T(x i ) = και : αληθές στοιχείο) O F είναι ικανοποιήσιμος εάν υπάρχει μια απόδοση τιμών αληθείας που τον ικανοποιεί. 28

Παράδειγμα. H Τ είναι αληθής για την F. 29

Παράδειγμα. Παράδειγμα 2. Ο F δεν είναι ικανοποιήσιμος! Γιατί? 30

Πρόβλημα Ικανοποιησιμότητας Ορισμός. Ικανοποιησιμότητα (Satisfiability) ή SAT : Δεδομένου ενός τύπου Bool F σε κανονική διαζευκτική μορφή, είναι ικανοποιήσιμος? Δεν υπάρχει γνωστός πολυωνυμικός αλγόριθμος για το πρόβλημα 31

Ειδικές περιπτώσεις δύσκολων προβλημάτων Περιορισμός SAT σε δύο στοιχεία για κάθε συνθήκη : 2-SAT Παράδειγμα. 32

Πολυωνυμικός Αλγόριθμος για το 2-SAT 1. Ξεκαθάρισμα: 1. Εάν έχουμε μια συνθήκη με μόνο ένα στοιχείο, θέτουμε την αντίστοιχη σε μεταβλητή έτσι ώστε η συνθήκη να είναι αληθής. 2. Ελέγχουμε τις υπόλοιπες συνθήκες: 1. αν έχουν το ίδιο στοιχείο είναι αληθείς. Oπότε τις αφαιρούμε. 2. αν έχουν την άρνηση του στοιχείου σημαίνει ότι το 2 ο στοιχείο της συνθήκης πρέπει να είναι αληθές, οπότε εκτελούμε το Ξεκαθάρισμα για το στοιχείο αυτό. Παράδειγμα. 33

2. (Τώρα έχουμε 2 μεταβλητές σε κάθε συνθήκη) Για κάθε μεταβλητή x i σε κάθε συνθήκη: Θέτουμε Τ(x i ) => και κάνουμε Ξεκαθάρισμα. Επαναφέρουμε τον F στην αρχική μορφή (πριν το προηγούμενο βήμα), θέτουμε Τ(x i )= και κάνουμε Ξεκαθάρισμα. Αν και τα δύο Ξεκαθαρίσματα αποτύχουν συμπεραίνουμε ότι ο F είναι μη ικανοποιήσιμος. Αλλιώς αναθέτουμε στην x i την επιτυχή τιμή αληθείας και επαναλαμβάνουμε το βήμα 2 για την επόμενη μεταβλητή. Παράδειγμα. 34

Πολυωνυμικός Αλγόριθμος για το 2-SAT Χρονική Πολυπλοκότητα Αλγόριθμου: Σε κάθε μεταβλητή γίνονται το πολύ δύο ξεκαθαρίσματα Κάθε Ξεκαθάρισμα παίρνει πολυωνυμικό χρόνο. Πόσο? Ο αλγόριθμος παίρνει πολυωνυμικό χρόνο. Πόσο? 35

Κλάση NP 36

Μη-Ντετερμινιστικές Μηχανές Turing: Eίναι δυνατόν σε μια συνολική κατάσταση να υπάρχουν πολλές δυνατές επόμενες συνολικές καταστάσεις (μεταβάσεις). Ο υπολογισμός σε μια ΝΜΤ είναι ένα μονοπάτι από συνολικές καταστάσεις. Ο υπολογισμός σε μια ΜΜΤ είναι ένα δένδρο από συνολικές καταστάσεις. Mια ΜΜΤ M δέχεται μια είσοδο x εάν υπάρχει τουλάχιστον ένα πεπερασμένο μονοπάτι υπολογισμού (a 0, L, a m ), a i : συνολική κατάσταση, στο δέντρο υπολογισμού της M με ρίζα a 0 = (s, BxB) και φύλλο a m = (h, uyv), όπου a i a i+1. Για κάποιες εισόδους η M το δένδρο υπολογισμού μπορεί να είναι άπειρο. 37

Λειτουργία ΜΜΤ Ορισμός. Για μια ΜΜT M, L(M) να είναι το σύνολο όλων των λέξεων που δέχεται η M. Στάδιο Εικασίας (μαντέματος, guessing) Μαντεύει ποια είναι η κατάλληλη μεταβίβαση για την είσοδο που έχει και την εκτελεί. Στάδιο επαλήθευσης: Ελέγχει ντετερμινιστικά αν το μάντεμα ήταν σωστό για την είσοδο που έχει. 38

Πολυπλοκότητα Χρόνου σε μια ΜΜΤ Πολυπλοκότητα Χρόνου σε μια ΜΜΤ M: Για x L(M), Time M (x) είναι ο αριθμός βημάτων στο πιο σύντομο μονοπάτι υπολογισμού αποδοχής της x. Δηλ. στο στάδιο του μαντέματος, μαντεύει με την πρώτη προσπάθεια το σωστό (αν υπάρχει). Εάν η M απορρίπτει την x, θέτουμε Time M (x) =. Η M έχει φράγμα χρόνου t(n) εάν Time M (x) max{ x + 1, t( x )} για όλα τα x L(M). Ορισμός. Μια γλώσσα έχει χρονική πολυπλοκότητα f(n) εάν αποφασίζεται από μια ΜΜΤ σε φράγμα χρόνο f(n). 39

Πολυπλοκότητα Χρόνου και Χώρου για ΜΜΤ Πολυπλοκότητα Χώρου σε μια ΜΜΤ M: Εάν x L(M), τότε θέτουμε Space M (x), να είναι ο αριθμός των κελιών ταινίας στην ταινίας εργασίας (διαβάζει, γράφει) που επισκέπτεται η M είναι ένα υπολογιστικό μονοπάτι αποδοχής που χρησιμοποιεί τον ελάχιστο χώρο. Εάν η M απορρίπτει την x, θέτουμε Space M (x) =. Η M έχει φράγμα χώρου s(n) εάν Space M (x) max{ x + 1, s( x )} για όλα τα x L(M). Ορισμός. Μιαγλώσσαέχειχωρική πολυπλοκότητα s(n) εάν αποφασίζεται από μια MΜΤ φράγμα χώρου f(n). 40

Κλάσεις Πολυπλοκότητας σε ΜΜΤ NTIME( t(n) ) = {L(M) M είναι μια ΜΜΤ με φράγμα χρόνου t(n)} NSPACE( s(n) ) = {L(M) M είναι μια ΜΜΤ με φράγμα χώρου s(n)} NP = U c>0 NTIME(n c ) (Non-Deterministic Polynomial Time) NPSPACE = U c>0 NSPACE(n c )(Non-Deterministic Polynomial Space) 41

Γνωστά Θεωρήματα Παρατηρείστε: P NP NP NPSPACE Θεώρημα. Για οποιαδήποτε σταθερά c > 0, ΝSPACE(s(n)) = ΝSPACE(c s(n)). Θεώρημα. Υποθέστε ότι lim n t(n)/n=. Τότε, για οποιαδήποτε σταθερά c>0, ΝTIME(t(n)) = ΝTIME(c t(n)) Θεώρημα Savitch. Εάν s(n) log n τότε NSPACE( s(n) ) DSPACE( ( s(n) 2 ). Πόρισμα 1. PSPACE = NPSPACE (από Θεώρημα Savitch και PSPACE NPSPACE) Πόρισμα 2. NP PSPACE (αφού ΝP NPSPACE = PSPACE) 42

Πλεονέκτημα Μη Ντετερμινισμού Μια μη-ντετερμινιστική μηχανή Turing μπορεί να μαντεύει τα υποψήφια μονοπάτια μπορεί να είναι εκθετικού πλήθους Μια ντετερμινιστική μηχανή Turing θα έπρεπε να τα ελέγχει όλα για να βρει το σωστό εκθετικός χρόνος Μια μη-ντετερμινιστική μηχανή μπορεί να μαντέψει το σωστό και να ελέγξει ότι όντως είναι. Κλάση NP Περιλαμβάνει τα προβλήματα για τα οποία μια μηντετερμινιστική μηχανή μπορεί να μαντέψει ένα μονοπάτι υπολογισμού του προβλήματος (μια υποψήφια λύση) και να ελέγξει εάν είναι σωστό σε πολυωνυμικό χρόνο. 43

Ένα Μεγάλο Ερώτημα ΗκλάσηNP φαίνεται ότι περιέχει μεγαλύτερη πληθώρα προβλημάτων Υπάρχει ανάλογο του Πορίσματος 1 (PSPACE=NPSPACE) για τις (χρονικές) κλάσεις P και NP? Δηλ. P=NP? Το ερώτημα παραμένει ανοικτό από το 1970 και θεωρείται το πιο σημαντικό ανοικτό ερώτημα στη Θεωρία Πολυπλοκότητας co-np = κλάση συνόλων Α ταοποίατασυμπληρώματαανήκουνστηνnp. Οι μη ντετερμινιστικές κλάσεις πολυπλοκότητας που είναι χρονικά φραγμένες δεν είναι γνωστό ότι είναι κλειστές ως προς το συμπλήρωμα. 44

Φροντιστήριο Παράδειγμα. Δείξτε ότι NSPACE(n) & NSPACE(n 2 log n). 45

Σχέσεις κλάσεων πολυπλοκότητας A B σημαίνει A $ B, A? B σημαίνει A B, αλλά δεν είναι γνωστό κατά πόσο A = B. 46

Προβλήματα που ανήκουν στην κλάση NP Το πρόβλημα SAT ανήκει στην κλάση NP. Απόδειξη. Σχεδιάζουμε μια ΜΜΤ M η οποία αποφασίζει σε πολυωνυμικό μη ντετερμινιστικό χρόνο για οποιαδήποτε στιγμιότυπο I=(X,F) του προβλήματος SAT εάν είναι ικανοποιήσιμο. 1 η φάση. Έστω F το στιγμιότυπο του SAT στην είσοδο της μηχανής. Μετρά τις μεταβλητές του F(=n)καιγράφεισεμιαδεύτερηταινίατη λέξη BI n. 2 η φάση (Μη-ντετερμινιστική φάση). Μη ντετερμινιστικά (μαντεύοντας), αντικαθιστά τη λέξη B I n με μια λέξη w {>, }. 3 η φάση (Ντετερμινιστική φάση). Ελέγχει εάν w ικανοποιεί την F. Ο αλγόριθμος τρέχει σε πολυωνυμικό μη ντετερμινιστικό χρόνο. Γιατί? 47

Παράδείγμα. (Φροντιστήριο) Να δείξετε ότι το πρόβλημα του πλανώδιου πωλητή ανήκει στην κλάση NP. Απόδειξη. Είσοδος: I= (D, B) πίνακας n n, στοιχεία : d ij Μάντεμα (μη ντετερμινιστική φάση): Μαντεύει μια λύση για το I: Η ΜΜΤ γράφει σε μια 2 η ταινία μια συμβολοσειρά από 0, 1 και t μήκους I. Έλεγχος (ντετερμινιστική φάση): 1. Ελέγχει αν η λέξη που έγραψε είναι μια δυαδική κωδικοποίηση μιας μετάθεσης n αριθμών διαχωρισμένων με ένα κενό, δηλ. της μορφής π(1) t π(2) L t π(n). A. Εάν ναι, τότε υπολογίζει το κόστος της μετάθεσης π, c(π) με βάση των πίνακα με τα κόστη διαδρομών D. a) Εάν c(π) B αποφασίζει YES. 2. Αλλιώς αποφασίζει NO. Ο αλγόριθμος ολοκληρώνεται σε πολυωνυμικό μη ντετερμινιστικό χρόνο. 48

Θεώρημα. Αν L NP τότε L EXP. Απόδειξη. Έστω Μ μια μη ντετερμινιστική μηχανή Turing που αποφασίζει την L σε πολυωνυμικό χρόνο p(n). Θα κατασκευάσουμε μια ντετερμινιστική μηχανή Turing M ηοποία αποφασίζει για την L σε χρόνο c p(n)., όπου c<2 k, k=σταθερή παράμετρος γλώσσας. H M προσομοιώνει την Μ για όλους τους δυνατούς υπολογισμούς της μήκους 1, 2,, p(n). 49

Συμπέρασμα. P ΝP EXP. Ε={(p(m),w) η Μ δέχεται την είσοδο w σε το πολύ 2 w βήματα. Ε EXP Ε P (θεώρημα προηγούμενης διάλεξης). είτε P & ΝP ή ΝP & EXP. Ποιο από τα δύο ισχύει είναι ένα μεγάλο ανοικτό ερώτημα! 50