Architecture description language: Difference between revisions

Content deleted Content added
m sp
History: new citation and reference
 
(221 intermediate revisions by more than 100 users not shown)
Line 1:
{{Short description|Standardized language on architecture description}}
'''Architecture Description Languages''' ('''ADLs''') are used to describe [[software architecture]]s. 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.
{{External links|date=August 2020}}
 
'''Architecture description languages''' ('''ADLs''') are used in several disciplines: [[system engineering]], [[software engineering]], and [[enterprise modelling]] and engineering.
There are several ADLs, such as [[Wright]] (developed by [[Carnegie Mellon University|CMU]]), [[Acme]] (developed by CMU), [[C2]] (developed by [[UCI]]), and [[Darwin]] (developed by [[Imperial College London]]).
 
The system engineering community uses an architecture description language as a language and/or a [[conceptual model]] to describe and represent [[system architecture]]s.
==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
 
The software engineering community uses an architecture description language as a [[computer language]] to create a [[Software architecture description|description]] of a [[software architecture]]. In the case of a so-called [[technical architecture]], the architecture must be communicated to software developers; a [[functional architecture (computer science)|functional architecture]] is communicated to various stakeholders and users. Some ADLs that have been developed are: [[Acme (ADL)|Acme]] (developed by [[Carnegie Mellon University|CMU]]), [[Architecture Analysis and Design Language|AADL]] (standardized by the [[Society of Automotive Engineers|SAE]]), [[C2 (ADL)|C2]] (developed by [[University of California, Irvine|UCI]]), SBC-ADL (developed by [[National Sun Yat-Sen University]]), [[Darwin (ADL)|Darwin]] (developed by [[Imperial College London]]), and [[Wright (ADL)|Wright]] (developed by [[Carnegie Mellon University|CMU]]).
Architectures in the past where largely represented by box-and-line drawing. The following things are usually defined in such a drawing:
 
*Nature of the component
==Overview==
*Component properties
The [[ISO/IEC 42010|ISO/IEC/IEEE 42010]]<ref>{{Cite web |url=http://www.iso-architecture.org/42010/docs/ISO-IEC-IEEE-latest-draft-42010.pdf |author=ISO/IECJTC 1/SC 7 Committee |title=ISO/IEC FDIS42010 |date=2011-03-01 |access-date=2011-12-05 |archive-url=https://web.archive.org/web/20120426010747/http://www.iso-architecture.org/42010/docs/ISO-IEC-IEEE-latest-draft-42010.pdf |archive-date=2012-04-26 |url-status=dead }}</ref> document, ''Systems and software engineering—Architecture description'', defines an architecture description language as "any form of expression for use in architecture descriptions" and specifies [[ISO/IEC 42010#Architecture Description Language|minimum requirements on ADLs]].
*Semantics of connections
 
*Behavior of a system as a whole
The enterprise modelling and engineering community have also developed architecture description languages catered for at the enterprise level. Examples include [[ArchiMate]] (now a standard of [[The Open Group]]), [[Jan Dietz#DEMO|DEMO]], ABACUS (developed by the [[University of Technology, Sydney]]). These languages do not necessarily refer to software components, etc. Most of them, however, refer to an application architecture as the architecture that is communicated to the software engineers.
ADLs 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.
 
Most of the writing below refers primarily to the perspective of the software engineering community.
 
A standard notation (ADL) for representing architectures helps promote mutual communication, the embodiment of early design decisions, and the creation of a transferable abstraction of a system. Architectures in the past were largely represented by box-and-line drawing annotated with such things as the nature of the component, properties, semantics of connections, and overall system behavior. ADLs 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.
 
==History==
ADLs have been classified into three broad categories: box-and-line informal drawings, formal architecture description language, and UML ([[unified modeling language]])-based notations.
 
Box-and-line have been for a long time the most predominant means for describing software architectures. While providing useful documentation, the level of informality limited the usefulness of the architecture description. A more rigorous way for describing software architectures was required. Quoting Allen and Garlan (1997),<ref name="Allen1997">{{Cite journal | last1 = Allen | first1 = R. | last2 = Garlan | first2 = D. | doi = 10.1145/258077.258078 | title = A formal basis for architectural connection | journal = ACM Transactions on Software Engineering and Methodology | volume = 6 | issue = 3 | pages = 213 | year = 1997 | citeseerx = 10.1.1.40.66 | s2cid = 326385 }}</ref> "while these [box-and-line] descriptions may provide useful documentation, the current level of informality limits their usefulness. Since it is generally imprecise what is meant by such architectural descriptions, it may be impossible to analyze an architecture for consistency or determine non-trivial properties of it. Moreover, there is no way to check that a system implementation is faithful to its architectural design." A similar conclusion is drawn in Perry and Wolf (1992),<ref name="PERRY1992">{{Cite journal | last1 = Perry | first1 = D. E. | last2 = Wolf | first2 = A. L. | author-link2 = Alexander L. Wolf| doi = 10.1145/141874.141884 | title = Foundations for the study of software architecture | journal = [[ACM SIGSOFT Software Engineering Notes]]| volume = 17 | issue = 4 | pages = 40 | year = 1992 | url = http://users.ece.utexas.edu/~perry/work/papers/swa-sen.pdf| citeseerx = 10.1.1.40.5174 | s2cid = 628695 }}</ref> which reports that: "Aside from providing clear and precise documentation, the primary purpose of specifications is to provide automated analysis of the documents and to expose various kinds of problems that would otherwise go undetected."
 
Since then, a thread of research on formal languages for software architecture description has been carried out. Tens of formal ADLs have been proposed, each characterized by different conceptual architectural elements, different syntax or semantics, focusing on a specific operational ___domain, or only suitable for different analysis techniques. For example, ___domain-specific ADLs have been presented to deal with embedded and real-time systems (such as AADL,<ref name=AADL>{{cite web |title= AADL — Architecture Analysis and Design Language |publisher=Software Engineering Institute, Carnegie Mellon University |date=July 2019 |url= http://www.aadl.info}}</ref> EAST-ADL,<ref>{{cite web|title= EAST-ADL |url= http://www.east-adl.info/}}</ref> and EADL<ref name="EADL">{{Cite journal | last1 = Li | first1 = J. | last2 = Pilkington | first2 = N. T. | last3 = Xie | first3 = F. | last4 = Liu | first4 = Q. | title = Embedded architecture description language | doi = 10.1016/j.jss.2009.09.043 | journal = Journal of Systems and Software | volume = 83 | issue = 2 | pages = 235 | year = 2010 | citeseerx = 10.1.1.134.8898 | s2cid = 8075069 }}</ref>), control-loop applications (DiaSpec<ref>{{cite web |title= AADL |url= http://www.diaspec.com/ |access-date= 2012-12-10 |archive-url= https://web.archive.org/web/20130601210552/http://diaspec.com/ |archive-date= 2013-06-01 |url-status= dead }}</ref>), product line architectures (Koala<ref name="KOALA">{{Cite journal | last1 = Van Ommering | first1 = R. | last2 = Van Der Linden | first2 = F. | last3 = Kramer | first3 = J. | last4 = Magee | first4 = J. | title = The Koala component model for consumer electronics software | doi = 10.1109/2.825699 | journal = Computer | volume = 33 | issue = 3 | pages = 78 | year = 2000 | citeseerx = 10.1.1.469.8243 }}</ref>), and dynamic systems (Π-ADL<ref name="Oquendo2004">{{cite journal|last1=Oquendo|first1=Flavio|title=π-ADL|journal=ACM SIGSOFT Software Engineering Notes|volume=29|issue=3|year=2004|pages=1–14|issn=0163-5948|doi=10.1145/986710.986728|s2cid=10781129}}</ref>)). Analysis-specific ADLs have been proposed to deal with availability, reliability, security, resource consumption, data quality and real-time performance analysis (AADL, behavioral analysis (Fractal<ref name="FRACTAL">{{Cite journal | doi = 10.1002/spe.767| title = The FRACTAL component model and its support in Java| journal = Software: Practice and Experience| volume = 36| issue = 11–12| pages = 1257| year = 2006| last1 = Bruneton | first1 = E. | last2 = Coupaye | first2 = T. | last3 = Leclercq | first3 = M. | last4 = Quéma | first4 = V. | last5 = Stefani | first5 = J. B. | citeseerx = 10.1.1.471.4374| s2cid = 12541723}}</ref>)), and trustworthiness analysis (TADL<ref>{{cite thesis|title= TADL|url= http://spectrum.library.concordia.ca/7057/|date= 2009-04-29|publisher= Concordia University|type= phd|last1= Mohammad|first1= Mubarak Sami}}</ref>).
 
However, these efforts have not seen the desired adoption by industrial practice. Some reasons for this lack of industry adoption have been analyzed by Woods and Hilliard,<ref name="Woods2005">{{Cite book | last1 = Woods | first1 = E. | last2 = Hilliard | first2 = R. | doi = 10.1109/WICSA.2005.15 | chapter = Architecture Description Languages in Practice Session Report | title = 5th Working IEEE/IFIP Conference on Software Architecture (WICSA'05) | pages = 243 | year = 2005 | isbn = 978-0-7695-2548-8 | s2cid = 18175375 }}</ref> Pandey,<ref name="Pandey2010">{{Cite journal | last1 = Pandey | first1 = R. K. | title = Architectural description languages (ADLs) vs UML | doi = 10.1145/1764810.1764828 | journal = ACM SIGSOFT Software Engineering Notes | volume = 35 | issue = 3 | pages = 1–5 | year = 2010 | s2cid = 18848376 }}</ref> Clements,<ref name="ClementsSurvey">{{Cite book | last1 = Clements | first1 = P. C. | chapter = A survey of architecture description languages | doi = 10.1109/IWSSD.1996.501143 | title = Proceedings of the 8th International Workshop on Software Specification and Design | pages = 16–00 | year = 1996 | isbn = 978-0-8186-7361-0 | citeseerx = 10.1.1.208.3401 | s2cid = 7307554 }}</ref> and others: formal ADLs have been rarely integrated in the software life-cycle, they are seldom supported by mature tools, scarcely documented, focusing on very specific needs, and leaving no space for extensions enabling the addition of new features.
 
As a way to overcome some of those limitations, [[Unified Modeling Language|UML]] has been indicated as a possible successor of existing ADLs. Many proposals have been presented to use or extend the UML to more properly model software architectures.<ref>{{cite web|title= Garlan_TR |date= 31 March 2004|url= http://www.sei.cmu.edu/library/abstracts/reports/04tr008.cfm}}</ref><ref>{{Cite book | last1 = Pérez-Martínez | first1 = J. E. | last2 = Sierra-Alonso | first2 = A. | chapter = UML 1.4 versus UML 2.0 as Languages to Describe Software Architectures | doi = 10.1007/978-3-540-24769-2_7 | title = Software Architecture | series = Lecture Notes in Computer Science | volume = 3047 | pages = 88 | year = 2004 | isbn = 978-3-540-22000-8 | chapter-url = http://oa.upm.es/33081/ }}</ref><ref name="SysADL">{{Cite book | last1 = Oquendo| first1 = F. | last2 = Leite | first2 = J.C. | last3 = Batista| first3 = T.B. | title = Software Architecture in Action: : Designing and Executing Architectural Models with SysADL. | year = 2016 | isbn = 978-3319443379 }}</ref>
 
A 2013 study<ref name="IndustrySurvey">{{cite journal| first1 = Ivano| last1 = Malavolta| first2 = Patricia| last2 = Lago| first3 = Henry| last3 = Muccini| first4 = Patrizio| last4 = Pelliccione| first5 = Antony| last5 = Tang | year = 2013 | title = What Industry Needs from Architectural Languages: A Survey | journal = IEEE Transactions on Software Engineering | volume = 39 | issue = 6 | pages = 869–891| doi = 10.1109/TSE.2012.74| s2cid = 6383726}}</ref> found that practitioners were generally satisfied with the design capabilities of the ADLS they used, but had several major concerns with them: they lacked analysis features and the ability to define extra-functional properties; those used in practice mostly originated from industrial development rather than academic research; they needed more formality and better usability.
 
==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. They differ from programming languages, because ADLs don't bind architectural abstractions to specific point solutions. Modeling languages represent behaviors, where ADLs focus on representation of components. However, there are ___domain-specific modeling languages (DSMLs) that focus on representation of components.
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.
 
'''Minimal requirements'''
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 implementations
ADLs 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
 
''The language must:''
ADLs differ in their ability to:
* Be suitable for communicating an architecture to all interested parties
*Handle real-time constructs, such as deadlines and task priorities, at the architectural level
* Support the tasks of architecture creation, refinement and validation
*Support the specification of different architectural styles. Few handle object oriented class inheritance or dynamic architectures
* 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
*Support analysis
* Provide the ability to represent most of the common architectural styles
*Handle different instantiations of the same architecture, in relation to product line architectures
* Support analytical capabilities or provide quick generating prototype implementations
'''ADLs 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:'''
Positive elements of ADL
* Handle real-time constructs, such as deadlines and task priorities, at the architectural level
*ADLs represent a formal way of representing architecture
* Support the specification of different architectural styles. Few handle object oriented class inheritance or dynamic architectures
*ADLs are intended to be both human and machine readable
* Support the analysis of the architecture
*ADLs support describing a system at a higher level than previously possible
* Handle different instantiations of the same architecture, in relation to product line architectures
*ADLs permit analysis of architectures – completeness, consistency, ambiguity, and performance
*ADLs can support automatic generation of software systems
 
Negative===Positive elements of ADL ===
*There is not universal agreement on what ADLs shouldare represent,a particularlyformal as regards the behaviorway of therepresenting architecture
* ADLs are intended to be both human and machine-readable
*Representations currently in use are relatively difficult to parse and are not supported by commercial tools
* ADLs support describing a system at a higher level than previously possible
*Most ADL work today has been undertaken with academic rather than commercial goals in mind
* ADLs permit analysis and assessment of architectures, for completeness, consistency, ambiguity, and performance
*Most ADLs tend to be very vertically optimized toward a particular kind of analysis
* ADLs can support automatic generation of software systems
Common concepts of architecture
 
===Negative elements of ADL===
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 :
* There is no 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 ADLs tend to be very vertically optimized toward a particular kind of analysis
 
==Common concepts of architecture==
Object Connection 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
* 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
* Interfaces specify the features that must be provided by modules conforming to an interface
*Connections represented by interfaces together with call graph
* Connections represented by interfaces together with [[call graph]]
*Conformance usually enforced by the programming language
* Conformance usually enforced by the programming language
**Decomposition - associating interfaces with unique modules
** Decomposition&nbsp;— associating interfaces with unique modules
**Interface conformance - static checking of syntactic rules
** Interface conformance&nbsp;— static checking of syntactic rules
**Communication integrity - visibility between modules
** Communication integrity&nbsp;— visibility between modules
 
===Interface Connection Architectureconnection architecture===
* Expands the role of interfaces and connections
** Interfaces specify both "required" and "provided" features
*Expands the role of interfaces and connections
** Connections are defined between "required" features and "provided" features
**Interfaces specify both “required” and “provided” features
* Consists of interfaces, connections and constraints
**Connections are defined between “required” features and “provided” features
*Consists* Constraints restrict behavior of interfaces, and connections andin constraintsan architecture
** Constraints restrictin behavioran ofarchitecture interfacesmap andto connectionsrequirements infor an architecturea system
**Constraints in an architecture map to requirements for a system
 
Most ADLs implement an interface connection architecture.
 
==Architecture vs. design==
Architecture, in the context of software systems, is roughly divided into categories, primarily software architecture, network architecture, and systems architecture. Within each of these categories, there is a tangible but fuzzy distinction between architecture and design. To draw this distinction as universally and clearly as possible, it is best to consider design as a noun rather than as a verb, so that the comparison is between two nouns.
 
Design is the abstraction and specification of patterns and organs of functionality that have been or will be implemented. Architecture is both a degree higher in abstraction and coarser in granularity. Consequentially, architecture is also more topological (i.e. overall structure and relationship between components) in nature than design (i.e. specific details and implementation), in that it specifies where major components meet and how they relate to one another. Architecture focuses on the partitioning of major regions of functionality into high level components, where they will physically or virtually reside, what off-the-shelf components may be employed effectively, in general what interfaces each component will expose, what protocols will be employed between them, and what practices and high level patterns may best meet [[extensibility]], [[maintainability]], reliability, durability, [[scalability]], and other non-functional objectives. Design is a detailing of these choices and a more concrete clarification of how functional requirements will be met through the delegation of pieces of that functionality to more granular components and how these smaller components will be organized within the larger ones.
So what is the difference between architecture and design? Architecture casts non-functional decisions and partition functional requirements where 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
 
Oftentimes, a portion of architecture is done during the conceptualization of an application, system, or network, and may appear in the non-functional sections of requirement documentation. Canonically, design is not specified in requirements, but is rather driven by them.
 
The process of defining an architecture may involve heuristics, acquired by the architect or architectural team through experience within the ___domain. As with design, architecture often evolves through a series of iterations, and just as the wisdom of a high level design is often tested when low level design and implementation occurs, the wisdom of an architecture is tested during the specification of a high level design. In both cases, if the wisdom of the specification is called into question during detailing, another iteration of either architecture or design, as the case may be, may become necessary.
 
In summary, the primary differences between architecture and design are ones of granularity and abstraction, and (consequentially) chronology. (Architecture generally precedes design, although overlap and circular iteration is a common reality.)
 
==Examples==
* [[ArchiMate]]
Below the list gives the candidates for being the best ADL until now
* [[Architecture Analysis & Design Language]]
* [[C4 model (software)]]
* [[Darwin (ADL)]]
* [[EAST-ADL]]
* [[Wright (ADL)]]
* [https://sysadl.imd.ufrn.br SysADL]
 
==Approaches to system architecture==
{{expand section|citations, an introduction, and context|date=September 2022}}
* 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
 
==See also==
*Primary candidates
* [[Architecture Analysis and Design Language|AADL]]
**[http://www-2.cs.cmu.edu/~acme/ ACME / ADML (CMU/USC)]
* [[Darwin (ADL)|Darwin]]
**[http://http://pavg.stanford.edu/rapide/ Rapide (Stanford)]
* [[Scripting language]]
**[http://www-2.cs.cmu.edu/afs/cs/project/able/www/wright/index.html Wright (CMU)]
* [https://sysadl.imd.ufrn.br SysADL]
**Unicon (CMU)
* [[Hardware description language]]
*Secondary candidates
**Aesop (CMU)
**MetaH (Honeywell)
**C2 SADL (UCI)
**SADL (SRI)
*Others
**Lileanna
**UML
**Modechart
 
==References==
==Approaches to architecture==
{{Reflist}}
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
 
==ConclusionExternal links==
{{Commonscat}}
There is a rich body of research to draw upon
* {{cite journal |first1=N. |last1=Medvidovic |first2=R.N. |last2=Taylor |doi=10.1109/32.825767 | title = A Classification and Comparison Framework for Software Architecture Description Languages | journal = IEEE Transactions on Software Engineering | volume = 26 | issue = 1 | date = January 2000 |pages=70–93}}
Much has been learned about representing and analyzing architectures
* {{cite journal |doi=10.1109/TSE.2012.74 | title = What Industry Needs from Architectural Languages: A Survey | journal = IEEE Transactions on Software Engineering | volume = 39 | issue = 6 | pages = 869–891 | year = 2013 | last1 = Malavolta | first1 = Ivano | last2 = Lago | first2 = Patricia | last3 = Muccini | first3 = Henry | last4 = Pelliccione | first4 = Patrizio | last5 = Tang | first5 = Antony | s2cid = 6383726 }}
Effort is needed now to bring together the common knowledge and put it into practice
* [https://web.archive.org/web/20150909170715/http://www.mrtc.mdh.se/han/FoPlan/ass2-bjornander.pdf Architecture Description Languages] // Mälardalen University
* {{cite book |first=P.C. |last=Clements |chapter=A survey of architecture description languages |chapter-url=http://splc.sei.cmu.edu/library/assets/Survey_of_ADLs.pdf |title=Proceedings of the 8th International Workshop on Software Specification and Design |year=1996 |isbn=0-8186-7361-3 |pages=16–25 |doi=10.1109/IWSSD.1996.501143 |s2cid=7307554 |archive-url=https://web.archive.org/web/20131224115957/http://splc.sei.cmu.edu/library/assets/Survey_of_ADLs.pdf |archive-date=2013-12-24 }}
* [http://www.avolution.com.au ABACUS]
* [https://www.cs.cmu.edu/~acme ACME]
* [http://www.mcc.com/projects/ssepp/adml ADML]
* [https://www.cs.cmu.edu/afs/cs/project/able/www/aesop/aesop_home.html Aesop]
* [http://caosd.lcc.uma.es/AO-ADL.htm AO-ADL]
* [https://web.archive.org/web/20080821101652/http://www.archimate.org/ ArchiMate] An example of an ADL for enterprise architecture
* [http://byadl.di.univaq.it ByADL (Build Your ADL) - University of L'Aquila]
* [https://web.archive.org/web/20010813004108/http://www.ics.uci.edu/pub/arch/ C2 SADL]
* [https://web.archive.org/web/20070702200852/http://caosd.lcc.uma.es/CAM-DAOP/DAOP-ADL.htm DAOP-ADL]
* [https://www.amazon.com/dp/3540291695 DEMO] Another example of an enterprise architecture ADL
* [https://web.archive.org/web/20130823003552/http://diaspec.bordeaux.inria.fr/ DiaSpec] an approach and tool to generate a distributed framework from a software architecture
* {{cite journal |first1=I. |last1=Malavolta |first2=H. |last2=Muccini |first3=P. |last3=Pelliccione |first4=D. |last4=Tamburri |title=Providing Architectural Languages and Tools Interoperability through Model Transformation Technologies |journal=IEEE Transactions on Software Engineering |volume=36 |issue=1 |pages=119–140 |date=January–February 2010 |doi=10.1109/TSE.2009.51 |s2cid=6825192 }} [http://dually.di.univaq.it DUALLy]
* [http://complexevents.com/stanford/rapide/ Rapide]
* [http://www.mcc.com/projects/ssepp SSEP]
* [https://www.cs.cmu.edu/afs/cs/project/vit/www/unicon/index.html Unicon]
* [https://www.cs.cmu.edu/afs/cs/project/able/www/wright/index.html Wright]
 
{{Computer language}}
==See also==
*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
 
{{DEFAULTSORT:Architecture Description Language}}
[[Category:Architecture description language| ]]
[[Category:Computer languages]]
[[Category:Systems architecture]]
[[Category:Software architecture]]
[[Category:Programming language classification]]
[[Category:Modeling languages]]