ΜΥΕ003: Ανάκτηση Πληροφορίας. Διδάσκουσα: Ευαγγελία Πιτουρά Κεφάλαιο 21: Ανάλυση Συνδέσμων.

Σχετικά έγγραφα
ΜΥΕ003: Ανάκτηση Πληροφορίας. Διδάσκουσα: Ευαγγελία Πιτουρά Κεφάλαιο 21: Ανάλυση Συνδέσμων.

Information Retrieval

Ανάκληση Πληροφορίας. Διδάσκων Δημήτριος Κατσαρός

Κοινωνικά Δίκτυα Αναζήτηση Πληροφοριών σε Δίκτυα

Ανάκληση Πληποφοπίαρ. Διδάζκων Δημήηριος Καηζαρός

Ανάκτηση Κειμένου (εισαγωγικά θέματα) Θέματα σχετικά με Εξόρυξη από τον Παγκόσμιο Ιστό. Εξόρυξη Δεδομένων

ΕΠΛ660. Ανάλυση Υπερσυνδέσµων

Συστήματα Markov Ένα σύστημα Markov διαγράμματος μετάβασης καταστάσεων

Μηχανές Αναζήτησης. Εξόρυξη εδοµένων: Ακ. Έτος ΑΝΑΛΥΣΗ ΣΥΝ ΕΣΕΩΝ 1

Web Searching I: History and Basic Notions, Crawling II: Link Analysis Techniques III: Web Spam Page Identification

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό. Η µέθοδος HITS. Η µέθοδος SALSA. Hypertext Induced Topic Search. ιδάσκων ηµήτριος Κατσαρός, Ph.D.

Μελέτη Περίπτωσης: Random Surfer

Τεχνικές Εκτίμησης Υπολογιστικών Συστημάτων 1ο Σετ Ασκήσεων - Λύσεις

Εισαγωγή στην ανάλυση συνδέσμων

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό

Μαρκοβιανές Αλυσίδες

Ανάκτηση Κειμένου (εισαγωγικά θέματα) Θέματα σχετικά με Εξόρυξη από τον Παγκόσμιο Ιστό. Εξόρυξη Δεδομένων

Web Mining. Χριστίνα Αραβαντινού Ιούνιος 2014

Ανάκληση Πληροφορίας. Διδάσκων Δημήτριος Κατσαρός

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό

Εύρεση & ιαχείριση Πληροφορίας στον Παγκόσµιο Ιστό. Ζητήµατα Μεγάλης-Κλίµακας Υλοποίησης του PageRank. Αρχιτεκτονική Μηχανής Αναζήτησης

Ασκήσεις μελέτης της 4 ης διάλεξης. ), για οποιοδήποτε μονοπάτι n 1

Ανάκληση Πληροφορίας. Διδάσκων Δημήτριος Κατσαρός

ΜΥΕ003: Ανάκτηση Πληροφορίας. Διδάσκουσα: Ευαγγελία Πιτουρά Κεφάλαιο 11: Πιθανοτική ανάκτηση πληροφορίας.

Ανάκληση Πληροφορίας. Διδάσκων Δημήτριος Κατσαρός

Ανάκληση Πληποφοπίαρ. Διδάζκων Δημήηριος Καηζαρός

Συστήματα Ανάκτησης Πληροφοριών ΗΥ-463

ΤΕΧΝΗΤΗ ΝΟΗΜΟΣΥΝΗ. Ενότητα 5: Παραδείγματα. Ρεφανίδης Ιωάννης Τμήμα Εφαρμοσμένης Πληροφορικής

Χαρακτηριστική Εξίσωση Πίνακα

ΑΛΓΟΡΙΘΜΙΚΕΣ ΜΕΘΟΔΟΙ ΒΕΛΤΙΣΤΟΠΟΙΗΣΗΣ

Εφαρμοσμένα Μαθηματικά ΙΙ Τελική Εξέταση Ι. Λυχναρόπουλος

Minimum Spanning Tree: Prim's Algorithm

Ανάκληση Πληροφορίας. Διδάσκων Δημήτριος Κατσαρός

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Network Algorithms and Complexity Παραλληλοποίηση του αλγορίθμου του Prim. Αικατερίνη Κούκιου

Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα)

Graph Algorithms. Παρουσίαση στα πλαίσια του μαθήματος «Παράλληλοι Αλγόριθμοι» Καούρη Γεωργία Μήτσου Βάλια

ΣΤΟΧΑΣΤΙΚΕΣ ΔΙΕΡΓΑΣΙΕΣ & ΒΕΛΤΙΣΤΟΠΟΙΗΣΗ

7 ΑΛΓΕΒΡΑ ΜΗΤΡΩΝ. 7.2 ΜΗΤΡΕΣ ΕΙΔΙΚΗΣ ΜΟΡΦΗΣ (Ι)

Information Retrieval

Ανάκτηση Πληροφορίας

Παραδείγματα Ιδιοτιμές Ιδιοδιανύσματα

ΓΡΑΜΜΙΚΗ ΑΛΓΕΒΡΑ (ΗΥ-119)

Νικος Χαλιδιας Μαθηματικό Τμήμα κατεύθυνση Στατιστικής και Αναλογιστικών-Χρηματοοικονομικών Μαθηματικών Πανεπιστημιο Αιγαιου

ΓΡΑΜΜΙΚΗ ΑΛΓΕΒΡΑ (Εξ. Ιουνίου - 02/07/08) ΕΠΙΛΕΓΜΕΝΕΣ ΑΠΑΝΤΗΣΕΙΣ

καθ. Βασίλης Μάγκλαρης

2 ΟΥ και 8 ΟΥ ΚΕΦΑΛΑΙΟΥ

Κεφάλαιο 7 Ορθογώνιοι Πίνακες

Πιθανοτικός Συμπερασμός: Πού βρίσκομαι στο πλέγμα; [ΠΛΗ 513] Αυτόνομοι πράκτορες - Project Εξαμήνου ΠΟΛΥΤΕΧΝΕΙΟ ΚΡΗΤΗΣ

Ανάκληση Πληποφοπίαρ. Διδάζκων Δημήηπιορ Καηζαπόρ

Ιδιάζουσες τιμές πίνακα. y έχουμε αντίστοιχα τις σχέσεις : Αυτές οι παρατηρήσεις συμβάλλουν στην παραγοντοποίηση ενός πίνακα

Εφαρμοσμένα Μαθηματικά ΙΙ Τελική Εξέταση 8/6/2017 Διδάσκων: Ι. Λυχναρόπουλος

Στοιχεία Θεωρίας Γράφων (Graph Theory)

Η ΚΑΝΟΝΙΚΗ ΜΟΡΦΗ JORDAN

Προβλήματα Ελάχιστου Κόστους Ροής σε Δίκτυο. Δίκτυα Ροής Ελάχιστου Κόστους (Minimum Cost Flow Networks)

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

Γράφημα. Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 4 5 πλήθος κορυφών πλήθος ακμών

Ευρετήρια. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Τι (άλλο) θα δούμε σήμερα;

ΠΡΟΓΡΑΜΜΑ ΣΠΟΥΔΩΝ ΣΤΗΝ ΠΛΗΡΟΦΟΡΙΚΗ ΜΑΘΗΜΑΤΙΚΑ Ι (ΘΕ ΠΛΗ 12) ΕΡΓΑΣΙΑ 2 η Ημερομηνία Αποστολής στον Φοιτητή: 28 Νοεμβρίου 2011

Γραμμική Άλγεβρα και Μαθηματικός Λογισμός για Οικονομικά και Επιχειρησιακά Προβλήματα

Ασκήσεις3 Διαγωνίσιμες Γραμμικές Απεικονίσεις

Κεφάλαιο 4 Διανυσματικοί Χώροι

Αριθμητική Ανάλυση 4.5 Ιδιοτιμές και ιδιοδιανύσματα πινάκων. Γ. Παπαευαγγέλου, ΕΔΙΠ, ΤΑΤΜ/ΑΠΘ

Μέθοδοι πολυδιάστατης ελαχιστοποίησης

Θεωρία Γραφημάτων 6η Διάλεξη

Εφαρμοσμένα Μαθηματικά ΙΙ Τελική Εξέταση 19/6/2018 Διδάσκων: Ι. Λυχναρόπουλος

Θέματα Μεταγλωττιστών

Φυσική Β Γυμνασίου Κεφάλαιο 3 Δυνάμεις

Προβλήματα, αλγόριθμοι, ψευδοκώδικας

= 7. Στο σημείο αυτό θα υπενθυμίσουμε κάποιες βασικές ιδιότητες του μετασχηματισμού Laplace, δηλαδή τις

Γράφηµα (Graph) Εργαστήριο 10. Εισαγωγή

ΜΕΜ251 Αριθμητική Ανάλυση

Λυμένες ασκήσεις στροφορμής

Ασκήσεις3 Διαγωνισιμότητα Βασικά σημεία Διαγωνίσιμοι πίνακες: o Ορισμός και παραδείγματα.

8.1 Διαγωνοποίηση πίνακα

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Διάλεξη 04: Παραδείγματα Ανάλυσης Πολυπλοκότητας/Ανάλυση Αναδρομικών Αλγόριθμων

Γραφικά Υπολογιστών: Βασικά Μαθηματικά

Διάλεξη 04: Παραδείγματα Ανάλυσης

ιαχείριση και Ανάκτηση Εικόνας µε χρήση Οµοιότητας Γράφων (WW-test)

Κεφ. 7: Συνήθεις διαφορικές εξισώσεις (ΣΔΕ) - προβλήματα αρχικών τιμών

ΣΤΟΧΑΣΤΙΚΕΣ ΔΙΕΡΓΑΣΙΕΣ & ΒΕΛΤΙΣΤΟΠΟΙΗΣΗ Αίθουσα Νέα Κτίρια ΣΗΜΜΥ Ε.Μ.Π.

Σπιν 1 2. Γενικά. Ŝ και S ˆz γράφονται. ιδιοκαταστάσεις αποτελούν ορθοκανονική βάση στον χώρο των καταστάσεων του σπιν 1 2.

ΗΥ360 Αρχεία και Βάσεις εδοµένων

Βασίλειος Μαχαιράς Πολιτικός Μηχανικός Ph.D.

HY380 Αλγόριθμοι και πολυπλοκότητα Hard Problems

Matrix Algorithms. Παρουσίαση στα πλαίσια του μαθήματος «Παράλληλοι. Αλγόριθμοι» Γ. Καούρη Β. Μήτσου

Κεφάλαιο 4 Διανυσματικοί Χώροι

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 4. Παραδείγματα Ανάλυσης Πολυπλοκότητας Ανάλυση Αναδρομικών Αλγόριθμων

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

Κεφ. 6Β: Συνήθεις διαφορικές εξισώσεις (ΣΔΕ) - προβλήματα αρχικών τιμών

Αριθμητική Ανάλυση και Εφαρμογές

Ανάκληση Πληπουοπίαρ. Διδάζκων Δημήηπιορ Καηζαπόρ

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

Στοχαστικές Ανελίξεις (3) Αγγελική Αλεξίου

ΤΕΙ ΛΑΜΙΑΣ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΤΕΧΝΟΛΟΓΙΑ ΥΠΟΛΟΓΙΣΤΩΝ

ΤΜΗΜΑ ΟΙΚΟΝΟΜΙΚΩΝ ΕΠΙΣΤΗΜΩΝ ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΑΤΡΩΝ ΑΚ. ΕΤΟΣ Μαθηματικά για Οικονομολόγους ΙI-Μάθημα 4 Γραμμικά Συστήματα

Transcript:

ΜΥΕ3: Ανάκτηση Πληροφορίας Διδάσκουσα: Ευαγγελία Πιτουρά Κεφάλαιο 2: Ανάλυση Συνδέσμων.

Κεφ 2 Τι θα δούμε σήμερα Πως μπορούμε να χρησιμοποιήσουμε το δίκτυο στη διάταξη των αποτελεσμάτων Δεν είναι όλες οι σελίδες (κόμβοι) ίσες. Ποιες σελίδες είναι «σημαντικές»? 2

Κεφ 2 Τι θα δούμε σήμερα Ανάλυση συνδέσμων (link analysis) PageRank HITS (Κομβικές σελίδες και σελίδες κύρους) SALSA Υπολογισμός μιας τιμής ανά σελίδα (κόμβο) που εκφράζει το πόσο σημαντική είναι στο δίκτυο 3

Διάταξη με βάση τη δημοτικότητα Διάταξη των σελίδων με βάσει τον αριθμό των εισερχόμενων ακμών (in-degree, degree centrality)

Αρκεί η δημοτικότητα; Δεν είναι σημαντικό πόσοι κόμβοι δείχνουν σε μια σελίδα αλλά το πόσο σημαντικοί είναι αυτοί οι κόμβοι

Κεφ 2 PageRank 6

Κεφ. 2.2 PageRank Βασική ιδέα: Μια σελίδα είναι σημαντική αν δείχνουν σε αυτήν σημαντικές σελίδες H αξία (PageRank) ενός κόμβου είναι το άθροισμα της αξίας των φίλων του 7

Κεφ. 2.2 PageRank: Βασική ιδέα Έχουμε μια «μονάδα κύρους» που τη λέμε PageRank (r) και την μοιράζουμε στις σελίδες. Κάθε σελίδα έχει ένα PageRank Κάθε σελίδα μοιράζει το PageRank στις σελίδες που δείχνει Το PageRank μιας σελίδας είναι το άθροισμα των PageRank των σελίδων που δείχνουν σε αυτήν 8

Κεφ. 2.2 PageRank: Ορισμός PageRank(v) = u inneigbors(v) PageRank(u) outdegree(u) 9

Κεφ. 2.2 PageRank: παράδειγμα

Κεφ. 2.2 PageRank: παράδειγμα v 2 v v 3 v 5 v 4

PageRank: παράδειγμα v 2 r(u ) = /3 r(u 4 ) + /2 r(u 5 ) r(u 2 ) = /2 r(u ) + r(u 3 ) + /3 r(u 4 ) r(u 3 ) = /2 r(u ) + /3 r(u 4 ) r(u 4 ) = /2 r(u 5 ) r(u 5 ) = r(u 2 ) v v 3 v 5 v 4 r(u ) + r(u 2 ) + r(u 3 ) + r(u 4 ) + r(u 5 ) = r(u): PageRank(u)

Ένα απλό παράδειγμα: υπολογισμός w Το συνολικό PageRank μοιράζεται στους 3 κόμβους w + w + w = w w Λύνοντας το σύστημα εξισώσεων παίρνουμε το PageRank των κόμβων w = ½ w = ¼ w = ¼ w = w + w w = ½ w w = ½ w

Κεφ. 2.2 PageRank: Επαναληπτικός Αλγόριθμος Σε ένα γράφο με n nodes, αναθέτουμε σε όλους το ίδιο αρχικό PageRank = /n. Εκτελούμε μια ακολουθία από k ενημερώσεις των PageRank τιμών με βάση των παρακάτω κανόνα:. Κάθε σελίδα μοιράζει την τρέχουσα PageRank τιμή της ισόποσα στις εξερχόμενες ακμές και τις περνά στους αντίστοιχους κόμβους 2. Κάθε σελίδα ανανεώνει την PageRank τιμή της ώστε να είναι ίση με το άθροισμα τον ποσών που δέχεται μέσω των εισερχόμενων ακμών της. 4

Κεφ. 2.2 PageRank: Αλγόριθμος Επαναληπτικός υπολογισμός 5

Κεφ. 2.2 Υπολογισμός: Παράδειγμα 6

Κεφ. 2.2 Ένα μεγαλύτερο παράδειγμα Αρχικά όλοι οι κόμβοι PageRank /8 Ένα είδος ροής ( fluid ) που κινείται στο δίκτυο Το συνολικό PageRank στο δίκτυο παραμένει σταθερό (δε χρειάζεται κανονικοποίηση) 7

Κεφ. 2.2 Ισορροπία Ένας απλός τρόπος να ελέγξουμε αν το σύνολο PageRank τιμών αντιστοιχεί σε ισορροπία: οι τιμές αθροίζουν σε και δεν αλλάζουν αν εφαρμόσουμε τον κανόνα ενημέρωσης 8

Κεφ. 2.2 PageRank: Διανυσματική αναπαράσταση Stochastic Adjacency Matrix (Στοχαστικός) Πίνακας Γειτνίασης Μ Πίνακας M πίνακας γειτνίασης του web Αν j -> i, τότε Μ ij = /outdegree(j) Αλλιώς, M ij = Page Rank Vector r Ένα διάνυσμα με μία τιμή για κάθε σελίδα (το PageRank της σελίδας) r i = 9

Κεφ. 2.2 PageRank: Διανυσματική αναπαράσταση Column stochastic: οι τιμές στις στήλες αθροίζουν στο 2

Κεφ. 2.2 PageRank: παράδειγμα v 2 v v 3 v 5 v 4 2

Κεφ. 2.2 PageRank: Διανυσματική αναπαράσταση Συγκλίνει; Συγκλίνει σε αυτό που θέλουμε; Ποια είναι η φυσική σημασία; 22

Κεφ. 2.2 Τυχαίος Περίπατος (Random Walks) Ο αλγόριθμος προσομοιώνει ένα τυχαίο περίπατο (random walk) στο γράφο Τυχαίος περίπατος: Ξεκίνα από κάποιον τυχαίο κόμβο (επιλεγμένο uniformly at random) με πιθανότητα /n Επέλεξε τυχαία (uniformly at random) μια από τις εξερχόμενες ακμές του κόμβου Ακολούθησε την ακμή Επανέλαβε 23

Παράδειγμα Step v 2 v v 3 v 5 v 4

Παράδειγμα Step v 2 v v 3 v 5 v 4

Παράδειγμα Step v 2 v v 3 v 5 v 4

Παράδειγμα Step v 2 v v 3 v 5 v 4

Παράδειγμα Step 2 v 2 v v 3 v 5 v 4

Παράδειγμα Step 2 v 2 v v 3 v 5 v 4

Παράδειγμα Step 3 v 2 v v 3 v 5 v 4

Παράδειγμα Step 3 v 2 v v 3 v 5 v 4

Παράδειγμα Step 4 v 2 v v 3 v 5 v 4

Κεφ. 2.2 Τυχαίος Περίπατος Η πιθανότητα να είσαι στη σελίδα X μετά από k βήματα του τυχαίου περιπάτου είναι το PageRank της σελίδας X μετά από k επαναλήψεις του υπολογισμού του PageRank Το μοντέλο του Random Surfer Του χρήστη που τριγυρνά στο web, ξεκινώντας από μια τυχαία σελίδα και συνεχίζει ακολουθώντας τυχαία κάποια από τις συνδέσεις της σελίδας 33

Κεφ. 2.2 PageRank: Επεκτάσεις Δύο προβλήματα. Dead ends: σελίδες χωρίς εξερχόμενες ακμές Έχουν ως αποτέλεσμα να ξεφεύγει (leak out) to PageRank 2. Spider traps: Ομάδα σελίδων που όλες οι εξερχόμενες ακμές είναι μεταξύ τους Τελικά απορροφούν όλο το PageRank 34

Κεφ. 2.2 PageRank: Αδιέξοδα Αδιέξοδα (dead ends): σελίδες που δεν έχουν εξερχόμενες ακμές?? Ο τυχαίος περίπατος μπορεί να κολλήσει σε ένα τέτοιον κόμβο Λέγονται και sink nodes 35

Κεφ. 2.2 PageRank: Αδιέξοδα 36

Κεφ. 2.2 PageRank: Αδιέξοδα Teleports: ακολούθησε με πιθανότητα τυχαία links από τους αδιέξοδους κόμβους Αντίστοιχη τροποποίηση του πίνακα 37

Κεφ. 2.2 PageRank: Spider Traps loop 38

Κεφ. 2.2 PageRank: Spider Traps 39

Κεφ. 2.2 Random Walks with Jumps Τυχαία περίπατοι με «άλματα» Με πιθανότητα β, ο περιπατητής ακολουθεί μια τυχαία εξερχόμενη ακμή όπως πριν και με πιθανότητα -β επιλέγει (jumps) σε μια τυχαία σελίδα στο δίκτυο, επιλεγμένη με πιθανότητα (/n) 4

Κεφ. 2.2 Random Walks with Jumps Brin-Page, 998 Προτεινόμενη τιμή,8,9 bm /3/3/3 ( b) /3/3/3 /3/3/3 Μοντέλο του Random Surfer Του χρήστη που τριγυρνά στο web, ξεκινώντας από μια τυχαία σελίδα συνεχίζει ακολουθώντας τυχαία συνδέσεις ή με κάποια πιθανότητα βαριέται και πάει (jumps) σε μια άλλη τυχαία σελίδα 5 links και jump 4

Κεφ. 2.2 PageRank, τυχαίοι περίπατοι και αλυσίδες Markov 42

Τυχαίος περίπατος Ποια είναι η πιθανότητα p i t να είσαι στον κόμβο i μετά από t βήματα; v 2 p = 5 p t = 3 p 4 t + 2 p 5 t v v 3 p 2 = 5 p 2 t = 2 p t + p 3 t + 3 p 4 t p 3 = 5 p 3 t = 2 p t + 3 p 4 t p 4 = 5 p 4 t = 2 p 5 t v 5 v 4 p 5 = 5 p 5 t = p 2 t

Αλυσίδες Markov Περιγράφουν μια στοχαστική διαδικασία διακριτού χρόνου σε ένα σύνολο από καταστάσεις S S = {s, s 2,, s n } με βάση έναν πίνακα πιθανότητων μεταβάσης (transition probability matrix) P Όπου P[i, j] είναι η πιθανότητα s i -> s j να μεταβούμε στην κατάσταση s j όταν είμαστε στην κατάσταση s i Οι γραμμές αθροίζουν σε (row stochastic) Memoryless: η επόμενη κατάσταση εξαρτάται μόνο από την τωρινή κατάσταση και όχι από τον παρελθόν της διαδικασίας

Αλυσίδες Markov State probability distribution vector p t = (p t, p 2 t,, p n t ) Διάνυσμα που αποθηκεύει την πιθανότητα να είμαστε στην κατάσταση p i μετά από t βήματα Μπορούμε να το υπολογίσουμε ως: p t = P p t To state probability vector συγκλίνει σε μια μοναδική κατανομή αν η αλυσίδα είναι μη περιοδική (aperiodic) και αμείωτη (irreducible)

Αλυσίδες Markov Irreducible: υπάρχει πάντα μια ακολουθία μεταβάσεων με μη μηδενική πιθανότητα από μια οποιαδήποτε κατάσταση σε μία άλλη (connectivity) Aperiodicity: οι καταστάσεις δε μπορούν να χωριστούν σε σύνολα τέτοια ώστε όλες οι μεταβάσεις να συμβαίνουν κυκλικά από το ένα σύνολο στο άλλο

Τυχαίοι Περίπατοι Οι τυχαίοι περίπατοι στους γράφους αντιστοιχούν σε Αλυσίδες Markov Το σύνολο των καταστάσεων S είναι οι κόμβοι του γράφου Ο πίνακας πιθανοτήτων μετάβασης είναι η πιθανότητα να ακολουθήσουμε μια ακμή από έναν κόμβο σε ένα άλλο P i, j = /outdegree i Στα επόμενα θα θεωρήσουμε τον ανάστροφο (transpose) του πίνακα Μ

Ένα παράδειγμα 2 2 3 3 3 2 2 P v 2 v 3 v 4 v 5 v A

Το διάνυσμα πιθανοτήτων p t = (p t, p 2 t,, p n t ) Διάνυσμα που αποθηκεύει την πιθανότητα να είμαστε στον κόμβο u i μετά από t βήματα p i πιθανότητα να αρχίσουμε από τον κόμβο i (συνηθώς) ομοιόμορφη p t = P p t

Ένα παράδειγμα P 3 2 2 3 2 3 2 v v 2 v 3 p t = 3 p 4 t + 2 p 5 t p 2 t = 2 p t + p 3 t + 3 p 4 t v 5 v 4 p 3 t = 2 p t + 3 p 4 t p 4 t = 2 p 5 t p 5 t = p 2 t

Stationary distribution Η stationary κατανομή ενός τυχαίου περίπατου με πίνακα μετάβασης P είναι η κατανομή πιθανοτήτων π τέτοια ώστε π = π P Το ιδιοδιάνυσμα (principal left eigenvector) του πίνακα P (οι στοχαστικοί πίνακες έχουν μέγιστη ιδιοτιμή ) Το ποσοστό των φορών που επισκεπτόμαστε την κατάσταση (κόμβο) i όταν t Θεωρία Αλυσίδων Markov: Ο τυχαίος περίπατος συγκλίνει σε μια μοναδική stationary distribution ανεξάρτητα από την αρχική κατάσταση αν ο γράφος είναι ισχυρά συνεκτικός και δεν είναι διμερής

Power Method Υπολογισμός Initialize q to some distribution Repeat q t = q t P Until convergence Μετά από πολλές επαναλήψεις q t π ανεξάρτητα από το αρχικό διάνυσμα q Power method γιατί υπολογίζει το q t = q P t Ρυθμός σύγκλισης Καθορίζεται από τη δεύτερη ιδιοτιμή λ 2 t

Stationary distribution Τι σημαίνει η stationary distribution π ενός τυχαίου περίπατου π(i): η πιθανότητα να είμαστε στον κόμβο i μετά από ένα πολύ μεγάλο (άπειρο) αριθμό από βήματα π = p P, όπου P ο πίνακας μετάβασης, p το αρχικό διάνυσμα P i, j : πιθανότητα μετάβασης από το i στο j σε ένα βήμα P 2 (i, j): πιθανότητα μετάβασης από το i στο j σε δύο βήματα (πιθανότητα όλων των μονοπατιών μήκους 2) P i, j = π(j): πιθανότητα μετάβασης από το i στο j σε άπειρα βήματα δεν έχει σημασία το αρχικό σημείο

Κεφ. 2.2 Περίληψη: ορισμός Ένας κόμβος είναι σημαντικός αν δείχνουν σε αυτόν σημαντικοί κόμβοι Κάθε κόμβος έχει ένα PageRank Κάθε κόμβος μοιράζει το PageRank του στους κόμβους που δείχνει Το PageRank ενός κόμβου είναι το άθροισμα των PageRank των κόμβων που δείχνουν σε αυτόν PageRank(v) = u v PageRank(u) outdegree(u) 54

Περίληψη: παράδειγμα r(u ) = /3 r(u 4 ) + /2 r(u 5 ) r(u 2 ) = /2 r(u ) + r(u 3 ) + /3 r(u 4 ) r(u 3 ) = /2 r(u ) + /3 r(u 4 ) r(u 4 ) = /2 r(u 5 ) r(u 5 ) = r(u 2 ) v v 2 v 3 r(u): PageRank(u) v 5 v 4

Κεφ. 2.2 Περίληψη: αλγόριθμος Επαναληπτικός υπολογισμός (power iteration method) Initialize r (v) n t = repeat r t (v) u v t = t + until convergence r t (u) outdegree(u) 56

/2 M /2 Περίληψη: πίνακες Μ: M[i, j] /outdegree(j) αν j i,, αλλιώς r το διάνυσμα στήλη με τις PageRank τιμές r = M r /3 /3 /3 /2 /2 v v 2 v 3 r r(u r(u r(u r(u r(u 2 3 4 5 ) ) ) ) ) v 5 r(u ) = /3 r(u 4 ) + /2 r(u 5 ) r(u 2 ) = /2 r(u ) + r(u 3 ) + /3 r(u 4 ) r(u 3 ) = /2 r(u ) + /3 r(u 4 ) r(u 4 ) = /2 r(u 5 ) r(u 5 ) = r(u 2 ) v 4

Κεφ. 2.2 Περίληψη: πίνακες Επεκτάσεις Dead ends: η στήλη στο Μ που του αντιστοιχεί /n /n /n Spider traps (loops): ακμές με πιθανότητα -β /n /n β Μ + (-β) /n 58

Περίληψη: random walks Ξεκίνα από κάποιον τυχαίο κόμβο Επέλεξε τυχαία μια από τις εξερχόμενες ακμές του Ακολούθησε την ακμή Επανέλαβε (με άλματα) Με πιθανότητα β Επέλεξε τυχαία μια από τις εξερχόμενες ακμές του Ακολούθησε την ακμή Με πιθανότητα -β Επέλεξε ένα τυχαίο κόμβο Random surfer PageRank του κόμβου u: το ποσοστό των φορών (πιθανότητα) που επισκεπτόμαστε τον κόμβο όταν t

PageRank: τυχαίος περίπατος (επανάληψη) Vanilla random walk Κάνουμε το πίνακα γειτνίασης στοχαστικό και τρέχουμε ένα τυχαίο περίπατο 2 2 3 3 3 2 2 P

Τι συμβαίνει με τα αδιέξοδα (sink nodes); Όταν ο τυχαίος περίπατος φτάσει σε έναν κόμβο χωρίς εξερχόμενες ακμές; 2 2 3 3 3 2 2 P PageRank: τυχαίος περίπατος Στις διαφάνειες έχουμε τον ανάστροφο του Μ

2 2 3 3 3 5 5 5 5 5 2 2 P' Αντικαθιστούμε αυτά τα διανύσματα με ένα διάνυσμα v συνήθως, το ομοιόμορφο διάνυσμα P = P + dv T otherwise sink is i if d PageRank: τυχαίος περίπατος

PageRank: τυχαίος περίπατος Για τα loops (spider traps);

5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 ) ( 2 2 3 3 3 5 5 5 5 5 2 2 ' P' Προσθέτουμε ένα τυχαίο άλμα σε ένα διάνυσμα v με πιθανότητα -β συνήθως, το ομοιόμορφο διάνυσμα β dumping factor Ο τυχαίος περίπατος ξαναρχίζει μετά από /(-β) βήματα in expectation Εξασφαλίζει irreducibility P = βp + (-β)uv T, όπου u διάνυσμα με όλα PageRank: τυχαίος περίπατος

Κεφ. 2.2 PageRank: τυχαίος περίπατος Ονομάζεται και τυχαίος περίπατος με επανεκκίνηση (random walk with restart) Με τα random jumps, τα μικρότερα μονοπάτια, είναι πιο σημαντικά Αν το διάνυσμα v που γίνεται το jump δεν είναι uniform, τότε μια προτίμηση σε συγκεκριμένους κόμβους (κόμβοι σε «μικρή» απόσταση από τους «restart» κόμβους) 65

Κεφ. 2.2 PageRank: Παράδειγμα 66

Κεφ. 2.2 Θεματικό PageRank Η σημασία μιας σελίδας μόνο με βάση το δίκτυο ανεξάρτητη από την ερώτηση (ή, το θέμα) Πως μπορούμε να υπολογίσουμε «θεματικό» ή personalized PageRank; 67

Κεφ. 2.2 Θεματικό PageRank Έστω S ένα σύνολο από σελίδες «συναφείς» με το θέμα Προσθέτουμε συνδέσεις teleports σε αυτές αντί σε τυχαίους κόμβους Γειτνίαση με τις σελίδες στο σύνολο S 68

Κεφ. 2.2 PageRank Link Farms: δίκτυα από εκατομμύρια σελίδες που δείχνουν η μία στην άλλη με στόχο την αύξηση του PageRank κάποιων σελίδων 69

Κεφ. 2.2 PageRank: χρήση στην ανάκτηση Σελίδες με μεγάλο PageRank υψηλότερα στη διάταξη Τελικός βαθμός συνδυασμός πολλών χαρακτηριστικών (features) 7

Κεφ 2 HITS 7

Κεφ. 2.3 Hyperlink-Induced Topic Search (HITS) Την ίδια εποχή με το PageRank Δύο βασικές διαφορές. Κάθε σελίδα έχει δύο βαθμούς: ένα βαθμό κύρους (authority rank) και ένα κομβικό βαθμό (hub rank) 2. Οι βαθμοί είναι θεματικοί 72

Κεφ. 2.3 HITS Authorities (σελίδες κύρους): σελίδες που περιέχουν χρήσιμη πληροφορία (οι εξέχουσες, έγκριτες απαντήσεις στις ερωτήσεις) Σελίδες εφημερίδων Σελίδες μαθημάτων Σελίδες κατασκευαστών αυτοκινήτων Hubs (κομβικές σελίδες): σελίδες που δείχνουν σε αυθεντίες (λίστες μεγάλης αξίας) Λίστες από εφημερίδες Πρόγραμμα μαθημάτων Λίστες από κατασκευαστές Άλλη εφαρμογή: βιβλιογραφικές αναφορές 73

Κεφ. 2.3 HITS Ένα hub είναι τόσο καλό όσο καλά είναι τα authorities στα οποία δείχνει (εξερχόμενες ακμές σε πολλά καλά authorities) Ένα authority είναι τόσο καλό όσο τα hubs που δείχνουν σε αυτό (εισερχόμενες ακμές από πολλά καλά hubs) 74

Κεφ. 2.3 HITS: Ορισμοί Κάθε σελίδα p, έχει δύο σκορ hub score (h) ως ειδικός Άθροισμα των authority σκορ των σελίδων στις οποίες δείχνει authority score (a) ποιότητα περιεχομένου Άθροισμα των hub σκορ των σελίδων που δείχνουν σε αυτήν

Κεφ. 2.3 Χρήση στη αναζήτηση Στην αρχική του μορφή, ο αλγόριθμος εφαρμόζεται σε υποσύνολο του web (query dependent input). Βρες από το web ένα σύνολο βάσης (base set) από σελίδες που θα μπορούσαν να είναι καλά hubs ή authorities. 2. Χρησιμοποίησε αυτό το σύνολο για να υπολογίζεις τα scores και να βρεις ένα μικρό σύνολο από κορυφαίες hub και authority σελίδες (επαναληπτικό αλγόριθμο)

Κεφ. 2.3 Σύνολο βάσης Δοθείσας μια ερώτησης (πχ Macron), χρησιμοποίησε ένα ευρετήριο κειμένου και ανέκτησε όλες τις σελίδες που περιέχουν τον όρο Macron. Ας ονομάσουμε αυτό το σύνολο, σύνολο ρίζα (root set) Πρόσθεσε οποιαδήποτε σελίδα: είτε δείχνει σε μια σελίδα στο σύνολο ρίζα, είτε μια σελίδα στο σύνολο ρίζα δείχνει σε αυτήν Και τις μεταξύ τους συνδέσεις Ονομάζουμε το σύνολο που προκύπτει σύνολο βάσης

Σύνολο βάσης Σύνολο ρίζα που προκύπτει από μια μηχανή αναζήτησης που χρησιμοποιεί μόνο το κείμενο Root Set

Σύνολο βάσης IN Root Set OUT

Σύνολο βάσης IN Root Set OUT

Σύνολο βάσης Base Set IN Root Set OUT

Κεφ. 2.3 Υπολογισμός Υπολόγισε για κάθε σελίδα x στο σύνολο βάσης ένα hub score h(x) και ένα authority score a(x). Initialize: for all x, h(x); a(x) ; Iteratively update all h(x), a(x);

Κεφ. 2.3 Επαναληπτικός υπολογισμός Επανέλαβε τις παρακάτω ενημερώσεις για κάθε κόμβο x: I operation h( x) O operation a( xy y) x a( x) h( yx y) x Normalize

Κεφ. 2.3 Κανονικοποίηση Για να αποφύγουμε οι τιμές h() and a() να γίνουν πολύ μεγάλες τις κλιμακώνουμε (scale down) μετά από κάθε επανάληψη Πως; Δεν έχει σημασία γιατί αυτό που πραγματικά μας ενδιαφέρει είναι οι σχετικές τιμές τους Διαίρεσε όλα τα hub scores με το άθροισμα των hub scores και όλα τα authority scores με το άθροισμα των authority scores

Παράδειγμα hubs authorities

Παράδειγμα Initialize hubs authorities

Παράδειγμα Step : O operation 2 3 2 hubs authorities

Παράδειγμα Step : I operation 2 3 2 hubs 6 5 5 2 authorities

Παράδειγμα Step : Normalization (Max norm) /3 2/3 3/3 2/3 /3 hubs 6/6 5/6 5/6 2/6 /6 authorities

Παράδειγμα Step 2: O step /6 6/6 7/6 /6 hubs 5/6 5/6 2/6 /6 authorities

Παράδειγμα Step 2: I step /6 6/6 7/6 /6 hubs 33/6 27/6 23/6 7/6 /6 authorities

Παράδειγμα Step 2: Normalization 6/6 /6 7/6 /6 hubs 27/33 23/33 7/33 /33 authorities

Παράδειγμα Convergence.4.75.3 hubs.8.6.4 authorities

Κεφ. 2.3 Σύγκλιση Οι σχετικές τιμές συγκλίνουν μετά από λίγες επαναλήψεις Στην πράξη, ~5 επαναλήψεις οι τιμές σχεδόν σταθεροποιούνται

Κεφ. 2.3 Japan Elementary Schools Hubs schools LINK Page-3 ú { ÌŠwZ a ŠwZƒz[ƒƒy[ƒW Schools Home Pages (English) K-2 from Japan /...rnet and Education ) http://www...iglobe.ne.jp/~ikesan l f j ŠwZ U N P g Œê ÒŠ ÒŠ Œ ŠwZ Koulutus ja oppilaitokset TOYODA HOMEPAGE Education Cay's Homepage(Japanese) y ì ŠwZ ̃z[ƒƒy[ƒW UNIVERSITY J ³ ŠwZ DRAGON97-TOP  ª ŠwZ T N P gƒz[ƒƒy[ƒw µ é¼âá á Ë å ¼ á Ë å ¼ Authorities The American School in Japan The Link Page ªès ˆä c ŠwZƒz[ƒƒy[ƒW Kids' Space ˆÀés ˆÀé¼ ŠwZ {é ³ˆç åšw ŠwZ KEIMEI GAKUEN Home Page ( Japanese ) Shiranuma Home Page fuzoku-es.fukui-u.ac.jp welcome to Miasa E&J school _ ÞìŒ E ls ì¼ ŠwZ ̃y http://www...p/~m_maru/index.html fukui haruyama-es HomePage Torisu primary school goo Yakumo Elementary,Hokkaido,Japan FUZOKU Home Page Kamishibun Elementary School...

Κεφ. 2.3 Παρατηρήσεις Συγκεντρώθηκαν καλές σελίδες ανεξάρτητα από τη γλώσσα του περιεχομένου της σελίδας Η χρήση της ανάλυσης συνδέσμων γίνεται μετά τη δημιουργία του συνόλου βάσης ο υπολογισμός των score εξαρτάται από το ερώτημα και γίνεται μετά την ανάκτηση με βάση το περιεχόμενο (σημαντική χρονική επιβάρυνση)

Κεφ. 2.3 Θέματα Topic Drift Σελίδες εκτός θέματος (off-topic) μπορεί να οδηγήσουν στο να επιστραφούν εκτός θέματος authorities Π.χ., οι γειτονικοί κόμβοι μπορεί να αναφέρονται σε κάποιο super topic Mutually Reinforcing Affiliates Συνεργαζόμενες σελίδες μπορεί να αυξήσουν τα σκορ τους

Κεφ. 2.3 Διανυσματική αναπαράσταση nn πίνακας γειτνίασης A: Για το σύνολο βάση A ij = αν η σελίδα page i δείχνει στο j, αλλιώς =. 2 3 2 3 2 3

Κεφ. 2.3 Διανύσματα Hub/Authority Τα hub σκορ h() και authority σκορ a() ως n- διάστατα διανύσματα Οι επαναληπτικοί υπολογισμοί: h( x) a( x) a( y) xy h( y) yx h = A a a = A Τ h, A Τ transpose (ανάστροφος)

Κεφ. 2.3 Διανυσματική αναπαράσταση h = A a. a = A Τ h. Αντικατάσταση: h = A A T h a = A T A a. h ιδιοδιάνυσμα του AA Τ α ιδιοδιάνυσμα του A Τ A Ο αλγόριθμος ανήκει στις power iteration μεθόδους υπολογισμού ιδιοδιανυσμάτων Συγκλίνει

Κεφ. 2.3 PageRank vs HITS Θα μπορούσαμε να εφαρμόσουμε το HITS σε όλο το web και το PageRank σε θεματικό υποσύνολο Στο web, Ένα καλό hub είναι συνήθως και ένα καλό authority Οι διαφορές στο rank με PageRank και HITS μικρές

Κεφ 2 Τι άλλο θα δούμε Ανάλυση Συνδέσμων SALSA (συνδυασμός Random Walk και HITS) χρήση για συστάσεις φίλων στο Twitter 2

Stochastic Approach for Link- Structure Analysis (SALSA) Τυχαίους περίπατους στο διμερή γράφο των hubs και των authorities εναλλάσσοντας ανάμεσα τους hubs authorities

Ο αλγόριθμος SALSA Ξεκινάμε από ένα authority που επιλέγουμε τυχαία (uniformly at random) Π.χ. το κόκκινο authority hubs authorities

Ο αλγόριθμος SALSA Επιλέγουμε τυχαία (uniformly at random) μια από τις εισερχόμενες ακμές του authority κόμβου και μετακινούμαστε σε ένα hub π.χ. μετακινούμαστε στο κίτρινο hub με πιθανότητα /3 hubs authorities

Ο αλγόριθμος SALSA Επιλέγουμε τυχαία (uniformly at random) μια από τις εξερχόμενες ακμές του hub κόμβου και μετακινούμαστε σε ένα authority π.χ. μετακινούμαστε στο μπλε authority με πιθανότητα /2 hubs authorities

Ο αλγόριθμος SALSA Τυπικά, έχουμε τις πιθανότητες: a i : Πιθανότητα να βρίσκεται στο authority i h j : Πιθανότητα να βρίσκεται στο hub j

Ο αλγόριθμος SALSA Η πιθανότητα να βρίσκεται στο authority i υπολογίζεται ως: a i = j N in (i) d out j h j Η πιθανότητα να βρίσκεται στο hub j υπολογίζεται ως: h j = i N out (j) d in i a i Επαναλαμβανόμενοι υπολογισμοί συγκλίνουν

Σε μορφή πινάκων A c = πίνακας A όπου οι στήλες αθροίζουν σε A r = πίνακας A όπου οι γραμμές αθροίζουν σε Ο υπολογισμός για τα hub h = A c a Ο υπολογισμός για τα authorities a = A rt h = A rt A c a Ο πίνακας μετάβασης P = A r A c T hubs authorities h 2 = /3 a + /2 a 2 a = h + /2 h 2 + /3 h 3 Διαφορά από HITS θεωρούμε τα out-degrees και in-degrees

SALSA (recommendations) Πρόβλημα: θέλουμε να προτείνουμε αντικείμενα σε χρήστες Βασική ιδέα: προτείνουμε αντικείμενα που «αρέσουν» στους φίλους των χρηστών Διμερή γράφο Users: φίλοι του χρήστη Items: αντικείμενα που τους αρέσουν users items

SALSA στο Twitter (as of 23) circle of trust : για κάθε χρήστη χρησιμοποιώντας μια μορφή personalized random walk Παραλλαγή: κάθε βήμα περιλαμβάνει διάσχιση 2 ακμών (αρχή και τέλος στην ίδια πλευρά) Hubs: 5 κορυφαίοι χρήστες στο κύκλο εμπιστοσύνης του χρήστη Authorities: χρήστες που ακολουθούν τα hubs Authority score: συστάσεις (ποιους χρήστες να ακολουθήσει) Hub score: ομοιότητα με το χρήστη (homophily)

SALSA στο Twitter (as of 23) circle of trust : κύκλο εμπιστοσύνης για κάθε χρήστη χρησιμοποιώντας μια μορφή personalized random walk Παραλλαγή: κάθε βήμα περιλαμβάνει διάσχιση 2 ακμών (αρχή και τέλος στην ίδια πλευρά) Hubs: 5 κορυφαίοι χρήστες στο κύκλο εμπιστοσύνης του χρήστη Authorities: χρήστες που ακολουθούν τα hubs Authority score: συστάσεις (ποιους χρήστες να ακολουθήσει) Hub score: ομοιότητα με το χρήστη (homophily)

SALSA στο Twitter (as of 23) Ένας χρήστης u είναι πιθανόν να ακολουθήσει χρήστες που ακολουθούν χρήστες που είναι όμοιοι με τον u. Οι χρήστες είναι όμοιοι με τον u αν ακολουθούν τους ίδιους ή παρόμοιους χρήστες με αυτούς που ακολουθεί ο u. SALSA Αριστερά: χρήστες όμοιους με τον u Δεξιά: όμοιους ακόλουθούς τους 3

Οι σύνδεσμοι είναι παντού! Πηγή πληροφορίας για το κύρος και γνησιότητα Παράδειγμα - Mail spam: ποιοι email λογαριασμοί είναι spammer Οι Καλοί, Οι Κακοί and Οι Άγνωστοι? Καλοί?? Κακοί? 4

Απλή επαναληπτική λογική Οι Καλοί, Οι Κακοί and Οι Άγνωστοι Οι Καλοί κόμβοι δεν δείχνουν σε Κακούς κόμβους Όλοι οι άλλοι συνδυασμοί επιτρέπονται? Καλοί?? Κακοί? 5

Απλή επαναληπτική λογική Οι Καλοί κόμβοι δεν δείχνουν σε Κακούς κόμβους Αν δείχνεις σε Κακό κόμβο, είσαι Κακός Αν ένας Καλός κόμβος δείχνει σε σένα, είσαι Καλός? Καλοί?? Κακοί? 6

Απλή επαναληπτική λογική Οι Καλοί κόμβοι δεν δείχνουν σε Κακούς κόμβους Αν δείχνεις σε Κακό κόμβο, είσαι Κακός Αν ένας Καλός κόμβος δείχνει σε σένα, είσαι Καλός Καλοί? Κακοί? 7

Απλή επαναληπτική λογική Οι Καλοί κόμβοι δεν δείχνουν σε Κακούς κόμβους Αν δείχνεις σε Κακό κόμβο, είσαι Κακός Αν ένας Καλός κόμβος δείχνει σε σένα, είσαι Καλός Καλοί? Κακοί 8

Πολλές εφαρμογές της ανάλυσης συνδέσμων Homophily Bibliometrics e.g., citation analysis 9

ΤΕΛΟΣ 2 ου Κεφαλαίου Ερωτήσεις? Χρησιμοποιήθηκε κάποιο υλικό από: Pandu Nayak and Prabhakar Raghavan, CS276:Information Retrieval and Web Search (Stanford) Hinrich Schütze and Christina Lioma, Stuttgart IIR class Τις αντίστοιχες διαλέξεις του μεταπτυχιακού μαθήματος «Κοινωνικά Δίκτυα και Μέσα» 2