Architecture description language


Architecture description language

An Architecture Description Language (ADL) is a computer language used to describe software and/or system architectures. This means in case of technical architecture, the architecture must be communicated to software developers. With functional architecture, the architecture is communicated to stakeholders and enterprise engineers.

There are several ADLs, such as Acme (developed by CMU), AADL (standardized by SAE), C2 (developed by UCI), Darwin (developed by Imperial College London), and Wright (developed by CMU).

Introduction

The following reasons would be better served if there were a standard notation (ADL) for representing architectures:
*Mutual communication
*Embodiment of early design decisions
*Transferable abstraction of a system

Architectures in the past were largely represented by box-and-line drawing. The following things are usually defined in such a drawing:
*Nature of the component
*Component properties
*Semantics of connections
*Behavior of a system as a wholeADLs result from a linguistic approach to the formal representation of architectures, and as such they address its shortcomings. Also important, sophisticated ADLs allow for early analysis and feasibility testing of architectural design decisions.

Characteristics

There is a large variety in ADLs developed by either academic or industrial groups. Many languages were not intended to be an ADL, but they turn out to be suitable for representing and analyzing an architecture. In principle ADLs differ from:
*Requirements languages, because ADLs are rooted in the solution space, whereas requirements describe problem spaces.
*Programming languages, because ADLs do not bind architectural abstractions to specific point solutions
*Modeling languages, because ADLs tend to focus on representation of components rather than the behavior of the whole. Although, there are domain specific modeling languages (DSMLs) that focus on representation of components.

The following list is a minimal set of requirements for a language to be an ADL. The languages must :
*Be suitable for communicating an architecture to all interested parties
*Support the tasks of architecture creation, refinement and validation
*Provide a basis for further implementation, so it must be able to add information to the ADL specification to enable the final system specification to be derived from the ADL
*Provide the ability to represent most of the common architectural styles
*Support analytical capabilities or provide quick generating prototype implementationsADLs have in common:
*Graphical syntax with often a textual form and a formally defined syntax and semantics
*Features for modeling distributed systems
*Little support for capturing design information, except through general purpose annotation mechanisms
*Ability to represent hierarchical levels of detail including the creation of substructures by instantiating templates

ADLs differ in their ability to:
*Handle real-time constructs, such as deadlines and task priorities, at the architectural level
*Support the specification of different architectural styles. Few handle object oriented class inheritance or dynamic architectures
*Support analysis
*Handle different instantiations of the same architecture, in relation to product line architectures

Positive elements of ADL
*ADLs represent a formal way of representing architecture
*ADLs are intended to be both human and machine readable
*ADLs support describing a system at a higher level than previously possible
*ADLs permit analysis of architectures – completeness, consistency, ambiguity, and performance
*ADLs can support automatic generation of software systems

Negative elements of ADL
*There is not universal agreement on what ADLs should represent, particularly as regards the behavior of the architecture
*Representations currently in use are relatively difficult to parse and are not supported by commercial tools
*Most ADL work today has been undertaken with academic rather than commercial goals in mind
*Most ADLs tend to be very vertically optimized toward a particular kind of analysis Common concepts of architecture

The ADL community generally agrees that Software Architecture is a set of components and the connections among them. But there are different kind of architectures like :

Object Connection Architecture

*Configuration consists of the interfaces and connections of an object-oriented system
*Interfaces specify the features that must be provided by modules conforming to an interface
*Connections represented by interfaces together with call graph
*Conformance usually enforced by the programming language
**Decomposition - associating interfaces with unique modules
**Interface conformance - static checking of syntactic rules
**Communication integrity - visibility between modules

Interface Connection Architecture
*Expands the role of interfaces and connections
**Interfaces specify both “required” and “provided” features
**Connections are defined between “required” features and “provided” features
*Consists of interfaces, connections and constraints
**Constraints restrict behavior of interfaces and connections in an architecture
**Constraints in an architecture map to requirements for a system

Most ADLs implement an interface connection architecture.

Architecture vs. design

So what is the difference between architecture and design? Architecture casts non-functional decisions and partition functional requirements, whereas design is a principle through which functional requirements are accomplished. Architectural heuristic means that it is necessary to go one level deeper to validate choices, so the architect has to do a high-level design to validate the partitioning.

Examples

Below the list gives the candidates for being the best ADL until now

*Primary candidates
** [http://www-2.cs.cmu.edu/~acme/ ACME / ADML (CMU/USC)]
** [http://pavg.stanford.edu/rapide/ Rapide (Stanford)]
** [http://www-2.cs.cmu.edu/afs/cs/project/able/www/wright/index.html Wright (CMU)]
**Unicon (CMU)
** [http://lepus.org.uk/ LePUS3 and Class-Z (University of Essex)]
*Secondary candidates
** [http://www.cs.cmu.edu/afs/cs/project/able/www/aesop/aesop_home.html Aesop (CMU)]
**MetaH (Honeywell)
**AADL (SAE) - Architecture Analysis & Design Language
**C2 SADL (UCI)
**SADL (SRI) - System Architecture Description Language
*Others
**Lileanna - Library Interconnect Language Extended with Annotated Ada
**UML - Unified Modeling Language

Approaches to architecture

Approaches to Architecture
*Academic Approach
**focus on analytic evaluation of architectural models
**individual models
**rigorous modeling notations
**powerful analysis techniques
**depth over breadth
**special-purpose solutions
*Industrial Approach
**focus on wide range of development issues
**families of models
**practicality over rigor
**architecture as the big picture in development
**breadth over depth
**general-purpose solutions

Conclusion

*There is a rich body of research to draw upon
*Much has been learned about representing and analyzing architectures
*Effort is needed now to bring together the common knowledge and put it into practice

ee also

* AADL
* Darwin

References and External links

*ArchiMate: http://www.archimate.org An example of an ADL for enterprise architecture
*DEMO: http://www.amazon.com/Enterprise-Ontology-Jan-L-G-Dietz/dp/3540291695/ref=pd_bbs_sr_1?ie=UTF8&s=books&qid=1217311286&sr=8-1 Another example of en enterprise architecture ADL
* [http://citeseer.ist.psu.edu/163640.html A Classification and Comparison Framework for Software Architecture Description Languages] - 1997 research paper.
*ACME: http://www.cs.cmu.edu/~acme
*Rapide: http://pavg.stanford.edu/rapide/
*Wright: http://www.cs.cmu.edu/afs/cs/project/able/www/wright/index.html
*Aesop: http://www.cs.cmu.edu/afs/cs/project/able/www/aesop/aesop_home.html
*Unicon: http://www.cs.cmu.edu/afs/cs/project/vit/www/unicon/index.html
*C2 SADL: http://www.ics.uci.edu/pub/arch/
*SSEP: http://www.mcc.com/projects/ssepp
*ADML: http://www.mcc.com/projects/ssepp/adml
*DAOP-ADL: http://caosd.lcc.uma.es/CAM-DAOP/DAOP-ADL.htm
*AO-ADL: http://caosd.lcc.uma.es/AO-ADL.htm


Wikimedia Foundation. 2010.

Look at other dictionaries:

  • Architecture Description Language — Eine Architecture Description Language (kurz ADL) hat den Anspruch, Software Architekturen zu beschreiben. Dies geschieht meist sowohl in grafischer als auch in textueller Form. Viele ADLs haben den Anspruch Software Architekturen so zu… …   Deutsch Wikipedia

  • Description language — may refer to: Interface description language aka interface definition language (IDL) Regular Language description for XML (RELAX) Web Services Description Language (WSDL) Page description language (PDL) Binary Format Description language… …   Wikipedia

  • Hardware description language — In electronics, a hardware description language or HDL is any language from a class of computer languages and/or programming languages for formal description of electronic circuits. It can describe the circuit s operation, its design and… …   Wikipedia

  • Compiler Description Language — Compiler Description Language, or CDL, is a Computer language based on affix grammars. It is very similar to Backus–Naur form(BNF) notation. It was designed for the development of compilers. It is very limited in its capabilities and control… …   Wikipedia

  • Geometric Description Language — (GDL) est un langage propriétaire de Graphisoft, s apparentant au BASIC, permet de développer les objets 2D/3D du logiciel ArchiCAD pour architectes. Ces objets de bibliothèques sont des éléments de fenêtre, de porte, de mobilier, de structure ou …   Wikipédia en Français

  • VHSIC Hardware Description Language — VHDL VHDL est un langage de description matériel destiné à représenter le comportement ainsi que l architecture d’un système électronique numérique. Son nom complet est VHSIC[1] Hardware Description Language. L intérêt d une telle description… …   Wikipédia en Français

  • Very High Speed Integrated Circuit Hardware Description Language — VHDL VHDL est un langage de description matériel destiné à représenter le comportement ainsi que l architecture d’un système électronique numérique. Son nom complet est VHSIC[1] Hardware Description Language. L intérêt d une telle description… …   Wikipédia en Français

  • VHSIC Hardware Description Language — Very High Speed Integrated Circuit Hardware Description Language (auch VHSIC Hardware Description Language), kurz VHDL, ist eine Hardwarebeschreibungssprache, vergleichbar mit einer Programmiersprache, mit der es einfach möglich ist, komplizierte …   Deutsch Wikipedia

  • Very High Speed Integrated Circuit Hardware Description Language — Very High Speed Integrated Circuit Hardware Description Language, kurz VHDL (oder auch VHSIC Hardware Description Language), ist eine Hardwarebeschreibungssprache, vergleichbar mit einer Programmiersprache, mit der es möglich ist, digitale… …   Deutsch Wikipedia

  • Specification and description language — Pour les articles homonymes, voir SDL et LDS. Le Specification and Description Language (SDL) ou Langage de description et de spécification (LDS) est un standard de l Union internationale des télécommunications (ITU T) sous la référence Z.100. Ce …   Wikipédia en Français


We are using cookies for the best presentation of our site. Continuing to use this site, you agree with this.