About
What is Harmony?
Concurrent programming is hard to get right. A deadlock might occur only once in a million executions, caused by the most esoteric of circumstances. Harmony makes finding those bugs easy.
- Checks every possible interleaving of processes
- Detects non-compilance with invariants
- Provides the shortest path to a failing execution
Learning programming in Harmony should be straightforward to those familiar with Python or similar languages. In addition to our online documentation, we provide a free textbook with many programming examples including Peterson's Algorithm, Dining Philosophers, Producer/Consumer queues, and barrier synchronization.
Online textbook PDF textbook Language Reference Module Reference Educator ResourcesDownloads
Harmony on Command Line
- Standalone model checking
- State machine output
- Interactive HTML output
- Installation using pip
HarmonyLang for VSCode
- Syntax Highlighting
- Intelligent Code Completion
- In-editor Visualizer
- Automatic Installation
Examples
Try out Harmony
Dining Philosophers
Formulated in 1965 by Edsger Dijkstra as a student exam exercise, presented in terms of computers competing for access to tape drive peripherals.
Peterson's Algorithm
An algorithm for mutual exclusion that allows two or more processes to share a single-use resource without conflict, using only shared memory for communication.
Reader/Writer Problem
We want to prevent more than one thread modifying the shared resource simultaneously and allow for two or more readers to access the shared resource for reading at the same time.
Educators
Educator Resources
Harmony has been used to teach concurrent programming at Cornell since 2020 by Robbert van Renesse and by Lorenzo Alvisi. Harmony comes with educational materials, including a free textbook (both online and PDF) with exercises, a slide set, example homework assignments, and example exam questions (answers available upon request). Also, the Harmony model checker makes it relatively easy to auto-grade student programs.
- Learning curve appropriate for undergraduate level
- Requires no background in formal methods
- Extensive educational materials
- Supports autograding
Harmony allows both specification and implementation of concurrent programs, and checks implementations automatically against specifications. Harmony runs on Linux, Mac OS X, and Windows. Harmony can be used on the command line (simplifying autograding) or within VSCode.
Team
Our Primary Contributors
data:image/s3,"s3://crabby-images/03fbf/03fbf79271d03d7752a4741489ae312c964c2d90" alt=""
Robbert van Renesse
Creator of the Harmony Projectdata:image/s3,"s3://crabby-images/41271/41271dd56ac44b69ca6c42757c6449f02862cb07" alt=""
Anthony Yang
Compilers & Data Outputdata:image/s3,"s3://crabby-images/51ee3/51ee334ac71c4cd9d0297bd4c637ca7dd72b6ac8" alt=""
Kevin Sun
Design & Documentationdata:image/s3,"s3://crabby-images/b6767/b676733cb411ba8023f5e6be5a065157bc594be5" alt=""
Haobin Ni
Designdata:image/s3,"s3://crabby-images/787b9/787b9d6f46787ab9872483c9169e3de236bdd03c" alt=""
William Ma
Compilers & Visualizationdata:image/s3,"s3://crabby-images/32cdd/32cddd0a19a84080e395d46fcec771e0283b0917" alt=""
Renyu Li
Graphical User InterfaceContact
Contact Us
Email:
rvr@cs.cornell.edu