Principles of Distributed Computing | DISCO - ETH Zurich

ETH-Zurich

Explore the fundamental principles and techniques of distributed computing, essential for modern computing and communications systems.

University CoursesDistributed Systems

Introduction

Distributed computing is essential in modern computing and communications systems. This lecture collection introduces the principles of distributed computing, emphasizing the fundamental issues underlying the design of distributed systems and networks: communication, coordination, fault-tolerance, locality, parallelism, self-organization, symmetry breaking, synchronization, and uncertainty.

screenshot

Highlights

  • Explore essential algorithmic ideas and lower bound techniques, the "pearls" of distributed computing
  • Presented in an easy-to-read set of lecture notes
  • Includes complete exercises and solutions

Recommendation

This course is recommended for those interested in understanding the fundamental principles and techniques of distributed computing, which are essential in modern computing and communications systems.

How GetVM Works

Learn by Doing from Your Browser Sidebar

Access from Browser Sidebar

Access from Browser Sidebar

Simply install the browser extension and click to launch GetVM directly from your sidebar.

Select Your Playground

Select Your Playground

Choose your OS, IDE, or app from our playground library and launch it instantly.

Learn and Practice Side-by-Side

Learn and Practice Side-by-Side

Practice within the VM while following tutorials or videos side-by-side. Save your work with Pro for easy continuity.

Explore Similar Hands-on Tutorials

Algorithms | Fundamental Concepts & Techniques

19
Technical TutorialsAlgorithmData Structures
Comprehensive guide to the fundamental concepts and techniques in the field of algorithms, covering discrete mathematics, data structures, and algorithm analysis.

Algorithms and Data Structures - With Applications to Graphics and Geometry

27
Technical TutorialsAlgorithmData Structures
Explore algorithms, data structures, and their practical applications in graphics and geometry. Suitable for beginners and experienced learners.

Data Structures | Algorithms | Efficient Software Systems

16
Technical TutorialsAlgorithmData Structures
Comprehensive guide to data structures and algorithms, covering arrays, linked lists, stacks, queues, trees, and more. Ideal for students, developers, and professionals seeking to build efficient software systems.

Data Structures and Algorithm Analysis in C++

7
Technical TutorialsAlgorithmC++
Comprehensive guide to data structures, algorithms, and problem-solving using C++. Suitable for students and professionals interested in algorithmic problem-solving.

Elementary Algorithms | Fundamental Algorithms and Data Structures

27
Technical TutorialsAlgorithmData Structures
Comprehensive introduction to fundamental algorithms and data structures, including sorting, searching, and algorithm design. Suitable for beginners and professionals.

Essential Algorithms | Comprehensive Guide to Algorithms and Data Structures

25
Technical TutorialsAlgorithmData Structures
Enhance your programming and problem-solving skills with Essential Algorithms, a comprehensive guide covering essential concepts for beginners and advanced programmers.

Learning Algorithm | Algorithms, Data Structures, Problem-Solving

26
Technical TutorialsAlgorithmData Structures
Explore a wide range of algorithms, from fundamental data structures to advanced techniques like dynamic programming and graph algorithms. Gain practical knowledge for software engineering and problem-solving.

Linked List Problems | Data Structures | Programming Algorithms

8
Technical TutorialsAlgorithmData Structures
Explore a wide range of linked list problems, develop visualization skills, and enhance your problem-solving abilities for coding interviews and exams.

Matters Computational: Ideas, Algorithms, Source Code

9
Technical TutorialsAlgorithmProgramming
Comprehensive book covering computational algorithms, source code, and programming concepts. Recommended for programmers and computer scientists.