Algorithmic Game Theory

You are here

Credits
6
Types
Specialization complementary (Advanced Computing)
Requirements
This subject has not requirements, but it has got previous capacities
Department
CS
As Computer Science struggles to understand the Internet and its capabilities, computer scientists are incorporating concepts and methodologies from Economics and Game Theory into their discipline. In the past decades, there has been a tremendous growth in research, centered around the following questions: What game-theoretic tools are applicable to computer systems? How far is the performance of a system from optimality due to the conflict of interests of its users and administrators? How can we design a system whose performance is robust with respect to the potential conflict of interests inside the system?

The course aims to tackle some of the fundamental problems at the interface of Computer Science and Game theory, with an emphasis on algorithms and computational complexity. Our main focus will be on algorithms for equilibria, the computational complexity of finding equilibria, the algorithmic tools in mechanism design for auctions, the stategic behavior models for large networks, and the price of anarchy. Incorporating also some notions from cooperative game theory.

Teachers

Person in charge

  • Maria Jose Serna Iglesias ( )

Weekly hours

Theory
2
Problems
1
Laboratory
0
Guided learning
0.4
Autonomous learning
8

Competences

Technical Competences of each Specialization

Advanced computing

  • CEE3.1 - Capability to identify computational barriers and to analyze the complexity of computational problems in different areas of science and technology as well as to represent high complexity problems in mathematical structures which can be treated effectively with algorithmic schemes.
  • CEE3.2 - Capability to use a wide and varied spectrum of algorithmic resources to solve high difficulty algorithmic problems.
  • CEE3.3 - Capability to understand the computational requirements of problems from non-informatics disciplines and to make significant contributions in multidisciplinary teams that use computing.

Generic Technical Competences

Generic

  • CG1 - Capability to apply the scientific method to study and analyse of phenomena and systems in any area of Computer Science, and in the conception, design and implementation of innovative and original solutions.
  • CG3 - Capacity for mathematical modeling, calculation and experimental designing in technology and companies engineering centers, particularly in research and innovation in all areas of Computer Science.
  • CG5 - Capability to apply innovative solutions and make progress in the knowledge to exploit the new paradigms of computing, particularly in distributed environments.

Transversal Competences

Reasoning

  • CTR6 - Capacity for critical, logical and mathematical reasoning. Capability to solve problems in their area of study. Capacity for abstraction: the capability to create and use models that reflect real situations. Capability to design and implement simple experiments, and analyze and interpret their results. Capacity for analysis, synthesis and evaluation.

Basic

  • CB6 - Ability to apply the acquired knowledge and capacity for solving problems in new or unknown environments within broader (or multidisciplinary) contexts related to their area of study.
  • CB8 - Capability to communicate their conclusions, and the knowledge and rationale underpinning these, to both skilled and unskilled public in a clear and unambiguous way.
  • CB9 - Possession of the learning skills that enable the students to continue studying in a way that will be mainly self-directed or autonomous.

Objectives

  1. Become acquainted with the main techniques and problems in the algorithmic game theory domain and identify their major properties.
    Related competences: CB8, CB9, CTR6, CEE3.1, CEE3.2, CG1,
  2. Examine conditions under which cooperation and antagonism appear. Perform an analysis and extract the fundamental properties of problems from different domains in order to assess the suitability of a game theoretical analysis and its limitations.
    Related competences: CB6, CB9, CTR6, CEE3.1, CEE3.2, CEE3.3, CG1, CG3, CG5,

Contents

  1. Introduction to Algorithmic Game Theory
    Centralized versus decentralized decisions. Games and Internet. Game types, solution concepts, strategies and equilibria. Social choice.
  2. Strategic games and computational aspects of Nash equilibria
    Strategic games, pure and mixed strategies. Solution concepts. Pure Nash equilibria and the complexity of its computation. Pure Nash equilibria versus local optima: Potential games. Mixed strategies and Nash equilibria. The complexity of computing a Nash equilibria.
  3. Price of anarchy and price of stability
    Definitions. Social cost. Best and worst Nash equilibria. Network Games: utility-based resource allocation. Selfish routing and Congestion games. Network formation games. Other examples
  4. Cooperative game theory
    Cooperative and simple games. Types of coalition. Power indices. Examples: voting games, combinatorial games and influence games on social networks.
  5. Weighted voting games
    Definitions and examples. Power and weight. Dimension and co-dimension.

Activities

Activity Evaluation act


Development of syllabus topics.

Development of syllabus topics and practice exercices.
  • Guided learning: Group consultation sessions for the preparation of the course and the resolution of the problems of the subject.
Objectives: 1 2
Contents:
Theory
28h
Problems
14h
Laboratory
0h
Guided learning
3h
Autonomous learning
51h

Final Exam

Theory questions and problem-solving exam
Objectives: 1 2
Week: 18
Theory
0h
Problems
0h
Laboratory
0h
Guided learning
0h
Autonomous learning
18h

Control 1

In class problem assignment
Objectives: 1 2
Week: 7
Theory
0h
Problems
1h
Laboratory
0h
Guided learning
0h
Autonomous learning
15h

Presentation of a research paper

Optional activity. Presentation of a scientific journal article describing a research topic in some of the topics covered in the course or in other related areas of interest to the student.
Objectives: 1 2
Week: 17
Theory
0h
Problems
0h
Laboratory
0h
Guided learning
3h
Autonomous learning
15h

Teaching methodology

There will be two kinds of classes: theoretical sessions and practical sessions. On average, two hours per week are dedicated to theory and one
hour per week to exercises. The teacher will allocate the hours in accordance to the subject matter.

The theory classes take the form of lectures in which the teacher sets out new concepts or techniques. Those are complemented with examples illustrating the introduced concepts. Sessions will consist of a presentation of the main topics of each content's item, mainly based in selected original research papers.
A high level of students' participation is expected at each session. Current lines of research in each topic will be discussed at the end of each topics' presentation.

The practical classes are used to carry out exercises in which students take an active part. Usually teachers set the exercises in advance. Students are
required to submit the exercises and then discuss the various solutions/alternatives in class.

Evaluation methodology

Mark componnents:

C = participation in class, problem solving and presentation (0-10).
A = presentation of a research article (0-10).

P1 = mid term exam (over the first part of AGT) (0-10) .
P2 = final term exam (over the second part of AGT) (0-10) .

FT = final exam (over all the contents of AGT) (0-10).

E = global examen mark

In the date assigned to the final exam you wil have the option to do the final term exam or the final exam. In the first case, E= (P1 + P2)/ 2, and in teh second, E= FT.

La nota final de l'assignatura es calcula amb la formula:

Nota = 20% C + 20% A + 60% E

Bibliography

Basic:

Complementary:

Previous capacities

Basic knowledge of algorithm analysis methods (in particular asymptotic complexity).
Basic knowledge on algorithms. Linear Programming. Maximum flow. Local search. Graph and Network algorithms.
Basic knowledge on algebraic reasoning.
Basic knowledge on computational complexity, classes and reductions.