Construction and Analysis of Distributed Processes


CADP is a toolbox for the design of communication protocols and distributed systems. CADP is developed by the CONVECS team at INRIA Rhone-Alpes and connected to various complementary tools. CADP is maintained, regularly improved, and used in many industrial projects.
The purpose of the CADP toolkit is to facilitate the design of reliable systems by use of formal description techniques together with software tools for simulation, rapid application development, verification, and test generation.
CADP can be applied to any system that comprises asynchronous concurrency, i.e., any system whose behavior can be modeled as a set of parallel processes governed by interleaving semantics. Therefore, CADP can be used to design hardware architecture, distributed algorithms, telecommunications protocols, etc.
The enumerative verification techniques implemented in CADP, though less general that theorem proving, enable an automatic, cost-efficient detection of design errors in complex systems.
CADP includes tools to support use of two approaches in formal methods, both of which are needed for reliable systems design:
Work began on CADP in 1986, when the development of the first two tools, CAESAR and ALDEBARAN, was undertaken. In 1989, the CADP acronym was coined, which stood for CAESAR/ALDEBARAN Distribution Package. Over time, several tools were added, including programming interfaces that enabled tools to be contributed: the CADP acronym then became the CAESAR/ALDEBARAN Development Package. Currently CADP contains over 50 tools. While keeping the same acronym, the name of the toolbox has been changed to better indicate its purpose:
Construction and Analysis of Distributed Processes.

Major releases

The releases of CADP have been successively named with alphabetic letters, then with the names of cities hosting academic research groups actively working on the LOTOS language and, more generally, the names of cities in which major contributions to concurrency theory have been made.
Code nameDate
"A"... "Z"January 1990 - December 1996
TwenteJune 1997
LiegeJanuary 1999
OttawaJuly 2001
EdinburghDecember 2006
ZurichDecember 2013
AmsterdamDecember 2014
Stony BrookDecember 2015
OxfordDecember 2016
Sophia AntipolisDecember 2017
UppsalaDecember 2018
PisaDecember 2019

Between major releases, minor releases are often available, providing early access to new features and improvements. For more information, see the page on the CADP website.

CADP features

CADP offers a wide set of functionalities, ranging from step-by-step simulation to massively parallel model checking. It includes:
CADP is designed in a modular way and puts the emphasis on intermediate formats and programming interfaces, which allow the CADP tools to be combined with other tools and adapted to various specification languages.

Models and verification techniques

Verification is comparison of a complex system against a set of properties characterizing the intended functioning of the system.
Most of the verification algorithms in CADP are based on the labeled transition systems model, which consists of a set of states, an initial state, and a transition relation between states. This model is often generated automatically from high level descriptions of the system under study, then compared against the system properties using various decision procedures. Depending on the formalism used to express the properties, two approaches are possible:
Although these techniques are efficient and automated, their main limitation is the state explosion problem, which occurs when models are too large to fit in computer memory. CADP provides software technologies for handling models in two complementary ways:
Accurate specification of reliable, complex systems requires a language that is executable and has formal semantics. Formal semantics are also required when it is necessary to establish the correctness of an infinite system; this cannot be done using enumerative techniques because they deal only with finite abstractions, so must be done using theorem proving techniques, which only apply to languages with a formal semantics.
CADP acts on a LOTOS description of the system. LOTOS is an international standard for protocol description, which combines the concepts of process algebras, which tries to provide a greater expressiveness together with a better user friendliness.
Several tools exist to convert descriptions in other process calculi or intermediate format into LOTOS, so that the CADP tools can then be used for verification.

Licensing and installation

CADP is distributed free of charge to universities and public research centers. Users in industry can obtain an evaluation license for non-commercial use during a limited period of time, after which a full license is required. To request a copy of CADP, complete the registration form at. After the license agreement has been signed, you will receive details of how to download and install CADP.

Tools summary

The toolbox contains several tools:
A number of tools have been developed within the OPEN/CAESAR environment:
The connection between explicit models and implicit models is ensured by OPEN/CAESAR-compliant compilers including:
The CADP toolbox also includes additional tools, such as ALDEBARAN and TGV developed by the Verimag laboratory and the Vertecs project-team of INRIA Rennes.
The CADP tools are well-integrated and can be accessed easily using either the EUCALYPTUS graphical interface or the SVL scripting language. Both EUCALYPTUS and SVL provide users with an easy, uniform access to the CADP tools by performing file format conversions automatically whenever needed and by supplying appropriate command-line options as the tools are invoked.