A metamodel or surrogate model is a model of a model, and metamodeling is the process of generating such metamodels. Thus metamodeling or meta-modeling is the analysis, construction and development of the frames, rules, constraints, models and theories applicable and useful for
modeling a predefined class of problems. As its name implies, this concept applies the notions of
meta- and modeling in
software engineering
Software engineering is a systematic engineering approach to software development.
A software engineer is a person who applies the principles of software engineering to design, develop, maintain, test, and evaluate computer software. The term ' ...
and
systems engineering
Systems engineering is an interdisciplinary field of engineering and engineering management that focuses on how to design, integrate, and manage complex systems over their life cycles. At its core, systems engineering utilizes systems thinking ...
. Metamodels are of many types and have diverse applications.
Overview
A metamodel/ surrogate model is a model of the model, i.e. a simplified model of an actual model of a circuit, system, or software like entity. Metamodel can be a mathematical relation or algorithm representing input and output relations. A
model is an abstraction of phenomena in the
real world; a metamodel is yet another abstraction, highlighting properties of the model itself. A model conforms to its metamodel in the way that a computer program conforms to the grammar of the programming language in which it is written. Various types of metamodels include polynomial equations, neural network,
Kriging
In statistics, originally in geostatistics, kriging or Kriging, also known as Gaussian process regression, is a method of interpolation based on Gaussian process governed by prior covariances. Under suitable assumptions of the prior, kriging g ...
, etc. "Metamodeling" is the construction of a collection of "concepts" (things, terms, etc.) within a certain domain. Metamodeling typically involves studying the output and input relationships and then fitting right metamodels to represent that behavior.
Common uses for metamodels are:
* As a
schema
The word schema comes from the Greek word ('), which means ''shape'', or more generally, ''plan''. The plural is ('). In English, both ''schemas'' and ''schemata'' are used as plural forms.
Schema may refer to:
Science and technology
* SCHEMA ...
for
semantic
Semantics (from grc, σημαντικός ''sēmantikós'', "significant") is the study of reference, meaning, or truth. The term can be used to refer to subfields of several distinct disciplines, including philosophy, linguistics and comput ...
data that needs to be exchanged or stored
* As a language that supports a particular method or process
* As a language to express additional semantics of existing information
* As a mechanism to create tools that work with a broad class of models at run time
* As a schema for modeling and automatically exploring sentences of a language with applications to automated test synthesis
* As an approximation of a higher-fidelity model for use when reducing time, cost, or computational effort is necessary
Because of the "meta" character of metamodeling, both the
praxis
Praxis may refer to:
Philosophy and religion
* Praxis (process), the process by which a theory, lesson, or skill is enacted, practised, embodied, or realised
*Praxis model, a way of doing theology
* Praxis (Byzantine Rite), the practice of fai ...
and theory of metamodels are of relevance to
metascience
Metascience (also known as meta-research) is the use of scientific methodology to study science itself. Metascience seeks to increase the quality of scientific research while reducing inefficiency. It is also known as "''research on research''" ...
,
metaphilosophy
Metaphilosophy, sometimes called the philosophy of philosophy, is "the investigation of the nature of philosophy". Its subject matter includes the aims of philosophy, the boundaries of philosophy, and its methods. Thus, while philosophy characte ...
,
metatheories and
systemics
In the context of systems science and systems philosophy, systemics is an initiative to study systems. It is an attempt at developing logical, mathematical, engineering and philosophical paradigms and frameworks in which physical, technological ...
, and meta-consciousness. The concept can be useful in
mathematics, and has practical applications in
computer science
Computer science is the study of computation, automation, and information. Computer science spans theoretical disciplines (such as algorithms, theory of computation, information theory, and automation) to practical disciplines (includin ...
and
computer engineering
Computer engineering (CoE or CpE) is a branch of electrical engineering and computer science that integrates several fields of computer science and electronic engineering required to develop computer hardware and software. Computer enginee ...
/
software engineering
Software engineering is a systematic engineering approach to software development.
A software engineer is a person who applies the principles of software engineering to design, develop, maintain, test, and evaluate computer software. The term ' ...
. The latter are the main focus of this article.
Topics
Definition
In
software engineering
Software engineering is a systematic engineering approach to software development.
A software engineer is a person who applies the principles of software engineering to design, develop, maintain, test, and evaluate computer software. The term ' ...
, the use of
models is an alternative to more common code-based development techniques. A model always conforms to a unique metamodel. One of the currently most active branch of
Model Driven Engineering is the approach named
model-driven architecture
Model Driven Architecture (MDA) is a software design approach for the development of software systems. It provides a set of guidelines for the structuring of specifications, which are expressed as models. Model Driven Architecture is a kind of doma ...
proposed by
OMG
OMG may refer to:
* Oh my God (sometimes also Oh my Goodness or Oh my Gosh), a common abbreviation, often used in SMS messages and Internet communication
Acronyms
* OMG is the IATA code for Omega Airport, Omega, Namibia
* Operational manoeuvre ...
. This approach is based on the utilization of a language to write metamodels called the
Meta Object Facility or MOF. Typical metamodels proposed by
OMG
OMG may refer to:
* Oh my God (sometimes also Oh my Goodness or Oh my Gosh), a common abbreviation, often used in SMS messages and Internet communication
Acronyms
* OMG is the IATA code for Omega Airport, Omega, Namibia
* Operational manoeuvre ...
are
UML
The Unified Modeling Language (UML) is a general-purpose, developmental modeling language in the field of software engineering that is intended to provide a standard way to visualize the design of a system.
The creation of UML was originally ...
,
SysML, SPEM or CWM.
ISO has also published the standard metamodel
ISO/IEC 24744. All the languages presented below could be defined as MOF metamodels.
Metadata modeling
Metadata modeling is a type of metamodeling used in
software engineering
Software engineering is a systematic engineering approach to software development.
A software engineer is a person who applies the principles of software engineering to design, develop, maintain, test, and evaluate computer software. The term ' ...
and
systems engineering
Systems engineering is an interdisciplinary field of engineering and engineering management that focuses on how to design, integrate, and manage complex systems over their life cycles. At its core, systems engineering utilizes systems thinking ...
for the analysis and construction of models applicable and useful to some predefined class of problems. (see also:
data modeling
Data modeling in software engineering is the process of creating a data model for an information system by applying certain formal techniques.
Overview
Data modeling is a process used to define and analyze data requirements needed to su ...
).
Model transformations
One important move in
model-driven engineering
Model-driven engineering (MDE) is a software development methodology that focuses on creating and exploiting domain models, which are conceptual models of all the topics related to a specific problem. Hence, it highlights and aims at abstract ...
is the systematic use of
model transformation languages. The OMG has proposed a standard for this called
QVT for Queries/Views/Transformations.
QVT is based on the meta-object facility (MOF). Among many other
model transformation languages (MTLs), some examples of implementations of this standard are AndroMDA,
VIATRA,
Tefkat,
MT,
ManyDesigns Portofino.
Relationship to ontologies
Meta-models are closely related to
ontologies. Both are often used to describe and analyze the relations between concepts
* Ontologies: express something meaningful within a specified universe or
domain of discourse
In the formal sciences, the domain of discourse, also called the universe of discourse, universal set, or simply universe, is the set of entities over which certain variables of interest in some formal treatment may range.
Overview
The dom ...
by utilizing a grammar for using vocabulary. The grammar specifies what it means to be a well-formed statement, assertion, query, etc. (formal constraints) on how terms in the ontology’s controlled vocabulary can be used together.
* Meta-modeling: can be considered as an ''explicit'' description (constructs and rules) of how a domain-specific model is built. In particular, this comprises a formalized specification of the domain-specific notations. Typically, metamodels are – and always should follow - a strict rule set. "A valid metamodel is an ontology, but not all ontologies are modeled ''explicitly'' as metamodels".
[
]
Types of metamodels
For software engineering, several ''types'' of models (and their corresponding modeling activities) can be distinguished:
* Metadata modeling (MetaData model)
* Meta-process modeling (MetaProcess model)
*Executable meta-modeling (combining both of the above and much more, as in the general purpose tool Kermeta)
* Model transformation language (see below)
* Polynomial metamodels
*Neural network
A neural network is a network or neural circuit, circuit of biological neurons, or, in a modern sense, an artificial neural network, composed of artificial neurons or nodes. Thus, a neural network is either a biological neural network, made up ...
metamodels
*Kriging
In statistics, originally in geostatistics, kriging or Kriging, also known as Gaussian process regression, is a method of interpolation based on Gaussian process governed by prior covariances. Under suitable assumptions of the prior, kriging g ...
metamodels
* Piecewise polynomial (spline) metamodels
* Gradient-enhanced kriging (GEK)
Zoos of metamodels
A library of similar metamodels has been called a Zoo of metamodels.
There are several types of meta-model zoos.AtlanticZoo
. Some are expressed in ECore. Others are written in
MOF 1.4 –
XMI 1.2. The metamodels expressed in
UML
The Unified Modeling Language (UML) is a general-purpose, developmental modeling language in the field of software engineering that is intended to provide a standard way to visualize the design of a system.
The creation of UML was originally ...
-
XMI1.2 may be uploaded in Poseidon for UML, a
UML
The Unified Modeling Language (UML) is a general-purpose, developmental modeling language in the field of software engineering that is intended to provide a standard way to visualize the design of a system.
The creation of UML was originally ...
CASE
Case or CASE may refer to:
Containers
* Case (goods), a package of related merchandise
* Cartridge case or casing, a firearm cartridge component
* Bookcase, a piece of furniture used to store books
* Briefcase or attaché case, a narrow box to c ...
tool.
See also
*
Business reference model
*
Data governance
*
Model-driven engineering
Model-driven engineering (MDE) is a software development methodology that focuses on creating and exploiting domain models, which are conceptual models of all the topics related to a specific problem. Hence, it highlights and aims at abstract ...
(MDE)
*
Model-driven architecture
Model Driven Architecture (MDA) is a software design approach for the development of software systems. It provides a set of guidelines for the structuring of specifications, which are expressed as models. Model Driven Architecture is a kind of doma ...
(MDA)
*
Domain Specific Language
A domain-specific language (DSL) is a computer language specialized to a particular application domain. This is in contrast to a general-purpose language (GPL), which is broadly applicable across domains. There are a wide variety of DSLs, ranging f ...
(DSL)
*
Domain-Specific Modeling (DSM)
*
Generic Eclipse Modeling System
Generic Eclipse Modeling System (GEMS) is a configurable toolkit for creating domain-specific modeling and program synthesis environments for Eclipse. The project aims to bridge the gap between the communities experienced with visual metamodeling ...
(GEMS)
*
Kermeta (Kernel Meta-modeling)
*
Metadata
*
MetaCASE tool (tools for creating tools for
computer-aided software engineering tools)
*
Method engineering
*
MODAF Meta-Model
The British Ministry of Defence Architecture Framework (MODAF) was an architecture framework which defined a standardised way of conducting enterprise architecture, originally developed by the UK Ministry of Defence. It has since been replaced ...
*
MOF Queries/Views/Transformations (MOF QVT)
*
Object Process Methodology
Object Process Methodology (OPM) is a conceptual modeling language and methodology for capturing knowledge and designing systems, specified as ISO/ PAS 19450. Based on a minimal universal ontology of stateful objects and processes tha ...
*
Requirements analysis
In systems engineering and software engineering, requirements analysis focuses on the tasks that determine the needs or conditions to meet the new or altered product or project, taking account of the possibly conflicting requirements of the ...
*
Space mapping
*
Surrogate model A surrogate model is an engineering method used when an outcome of interest cannot be easily measured or computed, so a model of the outcome is used instead. Most engineering design problems require experiments and/or simulations to evaluate design ...
*
Transformation language
*
VIATRA (Viatra)
*
XML transformation language (XML TL)
References
Further reading
*
* Booch, G., Rumbaugh, J., Jacobson, I. (1999), ''The Unified Modeling Language User Guide'', Redwood City, CA: Addison Wesley Longman Publishing Co., Inc.
*
J. P. van Gigch, ''System Design Modeling and Metamodeling'', Plenum Press, New York, 1991
* Gopi Bulusu, hamara.in, 200
''Model Driven Transformation''* P. C. Smolik
''Mambo Metamodeling Environment'' Doctoral Thesis, Brno University of Technology. 2006
* Gonzalez-Perez, C. and B. Henderson-Sellers, 2008. Metamodelling for Software Engineering. Chichester (UK): Wiley. 210 p.
* M.A. Jeusfeld, M. Jarke, and
J. Mylopoulos, 2009. Metamodeling for Method Engineering. Cambridge (USA): The MIT Press. 424 p. , Open access via http://conceptbase.sourceforge.net/2021_Metamodeling_for_Method_Engineering.pdf
* G. Caplat ''Modèles & Métamodèles'', 2008 -
* Fill, H.-G., Karagiannis, D., 2013
''On the Conceptualisation of Modelling Methods Using the ADOxx Meta Modelling Platform'' Enterprise Modelling and Information Systems Architectures, Vol. 8, Issue 1, 4-25.
{{Meta-prefix
Software design
Scientific modelling