Leveraging software architectures to guide and verify the development of sense/compute/control applications

  • Authors:
  • Damien Cassou;Emilie Balland;Charles Consel;Julia Lawall

  • Affiliations:
  • University of Bordeaux, Bordeaux, France;University of Bordeaux, Bordeaux, France;University of Bordeaux, Bordeaux, France;DIKU/INRIA/LIP6, Bordeaux, France

  • Venue:
  • Proceedings of the 33rd International Conference on Software Engineering
  • Year:
  • 2011

Quantified Score

Hi-index 0.00

Visualization

Abstract

A software architecture describes the structure of a computing system by specifying software components and their interactions. Mapping a software architecture to an implementation is a well known challenge. A key element of this mapping is the architecture's description of the data and control-flow interactions between components. The characterization of these interactions can be rather abstract or very concrete, providing more or less implementation guidance, programming support, and static verification. In this paper, we explore one point in the design space between abstract and concrete component interaction specifications. We introduce a notion of interaction contract that expresses allowed interactions between components, describing both data and control-flow constraints. This declaration is part of the architecture description, allows generation of extensive programming support, and enables various verifications. We instantiate our approach in an architecture description language for Sense/Compute/Control applications, and describe associated compilation and verification strategies