- title:
- Theory of Practical Graph Algorithms
Algorithmes efficaces de graphes : aspects théoriques - manager:
- Mauro Sozio
- ects:
- 3
- period:
- 2
- hours:
- 24
- weeks:
- 8
- hours-per-week:
- 3
- language:
- English
- lang:
- track:
- B
- themes:
- Discrete Math/Graphs, Algorithms
- order:
- 2.29.2
- successor:
- gram
- link:
- view
- [2.29.2]
- Theory of Practical Graph Algorithms
Algorithmes efficaces de graphes : aspects théoriques
- Language:
- Period:
- 2.
- Duration:
- 24h (3h/week).
- ECTS:
- 3.
- Themes: Discrete Math/Graphs, Algorithms
- Manager:
- Mauro Sozio.
Teachers for 2024-2025
Mauro Sozio (Professor, Telecom Paris, Institut Polytechnique de Paris, LTCI) sozio at telecom dash paris dot fr
Laurent Viennot (Research Director, INRIA) laurent dot viennot at inria dot fr
Scientific and pedagogical content
Graphs provide a powerful abstraction for representing a wide variety of real-world information, such as social networks, knowledge and information networks, biological networks, etc. The course will focus on the theoretical aspects of graph algorithms that work “well” in practice. We will see how theory can lead to a better understanding of the structure of the problem at hand, which, in turn, can lead to more effective or more efficient algorithms. We will also see how real-world problems can inspire interesting theoretical problems. As a result, theory and practice can be much more intertwined than we tend to believe.
We will cover (tentatively) the following main topics:
- finding cliques and dense subgraphs (sequential, parallel/distributed, dynamic algorithms)
- graph generation models (Erdös-Rényi, preferential attachment, small world phenomenon)
- graph clustering (k-center)
- graph decompositions (k-core)
- diffusion and influence maximization
- efficient representation of distances in a graph
- temporal graphs: when edges appear at certain points in time
- computing the diameter of a graph
(Tentative) content and schedule
- 12/12/24 no class
- 19/12/24 no class
- 06/03 Exam Mauro's part
- 13/03 Exam Laurent's part
All classes take place between 12:45 and 15:45 on Thursdays in room 1004. The time for the exams will be communicated later on.
Some material from previous occurrences of the course (content or topics might change every year):
Finding Densest Subgraphs Finding Minimal Densest Subgraphs Listing k-cliques Influence Maximization Generative Models for Social Networks
Project/Reading Material
News and Announcements
09/12 The course will start in January (on 09/01/25)
Teaching language
The course will be in English.
Evaluation
During the course a few exercises related to the content of the course will be given. A subset of those exercises (or similar ones) will be asked during the final exam. Material presented during the lectures might also be asked at the final exam.
There is also the possibility of doing either a project or read a scientific article and present it. This is optional, while it gives up to 2-4 additional points on the final mark. The project typically consists of implementing efficiently a graph algorithm or a data analysis task. Students should preferably use C, Java, or Python, however, any programming language can be used. Students are not allowed to bring any notes at the final exam. [[https://drive.google.com/file/d/1lH23WoKySkyWJ8a4diSma_TJzJuUn1la/view?usp=sharing or Python are preferable but not necessary.
Related Books
Algorithm Design par J. Kleinberg et E. Tardos, Addison Welsey 2005.
D. Easley, J. Kleinberg. Networks, Crowds, and Markets: Reasoning About a Highly Connected World. Cambridge University Press, 2010.