Доменно-ориентированное моделирование - Domain-specific modeling

Доменно-ориентированное моделирование (DSM) это программная инженерия методология для проектирования и разработки систем, таких как компьютерное программное обеспечение. Он предполагает систематическое использование предметно-ориентированный язык для представления различных аспектов системы.

Языки моделирования предметной области обычно поддерживают высокоуровневые абстракции чем универсальное моделирование языков, поэтому они требуют меньше усилий и меньше деталей низкого уровня для определения данной системы.

Обзор

Моделирование предметной области часто также включает идею генерация кода: автоматизация создание исполняемого файла исходный код непосредственно из предметно-ориентированных языковых моделей. Отсутствие необходимости ручного создания и сопровождения исходного кода означает, что предметно-ориентированный язык может значительно повысить производительность труда разработчиков.[1] Надежность автоматической генерации по сравнению с ручным кодированием также снизит количество дефектов в результирующих программах, что повысит качество.

Доменно-ориентированный язык отличается от предыдущих попыток генерации кода в ДЕЛО инструменты 1980-х годов или UML инструменты 1990-х годов. В обоих случаях генераторы кода и языки моделирования были созданы поставщиками инструментов.[нужна цитата ] В то время как поставщик инструментов может создать предметно-ориентированный язык и генераторы, более нормальным является наличие предметно-ориентированного языка внутри одной организации. Один или несколько опытных разработчиков создают язык моделирования и генераторы, а остальные разработчики используют их.

Наличие языка моделирования и генератора, созданного организацией, которая будет их использовать, позволяет точно соответствовать их точной области и в ответ на изменения в области.

Языки, специфичные для предметной области, обычно могут охватывать диапазон уровней абстракции для конкретной предметной области. Например, язык моделирования для мобильных телефонов может позволить пользователям указывать высокоуровневые абстракции для пользовательский интерфейс, а также абстракции нижнего уровня для хранения данных, таких как номера телефонов или настройки. Аналогичным образом, предметно-ориентированный язык моделирования финансовых услуг может позволить пользователям определять абстракции высокого уровня для клиентов, а также абстракции более низкого уровня для реализации алгоритмов торговли акциями и облигациями. Доменно-ориентированное моделирование также помогает рассуждать о низкоуровневых программных артефактах.[2]

Темы

Определение предметно-ориентированных языков

Чтобы определить язык, нужен язык, на котором будет записано определение. Язык модели часто называют метамодель, следовательно, язык для определения языка моделирования - это мета-метамодель. Мета-метамодели можно разделить на две группы: те, которые созданы на основе существующих языков или адаптированы к ним, и те, которые были разработаны специально как мета-метамодели.

Производные мета-метамодели включают диаграммы отношений сущностей, формальные языки, расширенная форма Бэкуса-Наура (EBNF), онтологические языки, Схема XML, и Мета-объектный объект (MOF). Сильные стороны этих языков обычно заключаются в знакомстве и стандартизации исходного языка.

Идея предметно-ориентированного моделирования способствует созданию нового языка для конкретной задачи, поэтому неудивительно, что появляются новые языки, разработанные как мета-метамодели. Наиболее широко используемым семейством таких языков является OPRR,[3][4] ГОПРР,[5] и GOPPRR, которые сосредоточены на поддержке вещей, найденных в языках моделирования, с минимальными усилиями.

Инструментальная поддержка языков, специфичных для предметной области

Много Универсальное моделирование языки уже имеют поддержку инструментов в виде ДЕЛО инструменты. Языки предметно-ориентированных языков, как правило, имеют слишком маленький размер рынка, чтобы поддерживать создание индивидуального инструмента CASE с нуля. Вместо этого, большинство инструментальных средств поддержки языков, специфичных для предметной области, построено на основе существующих предметно-ориентированных языковых структур или посредством предметно-ориентированных языковых сред.

Среда предметно-ориентированного языка может рассматриваться как инструмент метамоделирования, то есть инструмент моделирования, используемый для определения инструмента моделирования или инструмента CASE. Полученный инструмент может либо работать в языковой среде предметной области, либо, реже, создаваться как отдельная автономная программа. В более общем случае языковая среда предметной области поддерживает дополнительный уровень абстракция по сравнению с традиционным инструментом CASE.

Использование предметно-ориентированной языковой среды может значительно снизить затраты на получение инструментальной поддержки для предметно-ориентированного языка, поскольку хорошо спроектированная предметно-ориентированная языковая среда автоматизирует создание программных частей, создание которых с нуля требует больших затрат, таких как редакторы, браузеры и компоненты для конкретной предметной области. Специалисту в предметной области нужно только указать конструкции и правила, специфичные для предметной области, а языковая среда для предметной области предоставляет инструмент моделирования, адаптированный для целевой области.

Большинство существующих предметно-ориентированных языков имеют место с предметно-ориентированными языковыми средами, либо коммерческими, такими как MetaEdit + или же Actifsource, с открытым исходным кодом, например Драгоценные камни, или академические, такие как GME. Растущая популярность предметно-ориентированного языка привела к добавлению предметно-ориентированных языковых фреймворков к существующим IDE, например Проект моделирования Eclipse (EMP) с ЭДС и GMF, или в Microsoft Инструменты DSL за Фабрики программного обеспечения.

Доменно-ориентированный язык и UML

В Единый язык моделирования (UML) - это универсальное моделирование язык для систем с интенсивным использованием программного обеспечения, который предназначен для поддержки в основном объектно-ориентированного программирования. Следовательно, в отличие от языков, зависящих от предметной области, UML используется для самых разных целей в широком диапазоне предметных областей. UML предлагает примитивы объектно-ориентированного программирования, тогда как предметно-ориентированные языки предлагают примитивы, семантика знакомы всем практикующим в этой области. Например, в домене автомобилестроение, будут модели программного обеспечения для представления свойств антиблокировочная система, или руль, так далее.

UML включает в себя механизм профилей, который позволяет ограничивать и настраивать его для определенных доменов и платформ. Профили UML используют стереотипы, атрибуты стереотипов (известные как значения с тегами до UML 2.0) и ограничения для ограничения и расширения области применения UML до определенного домена. Возможно, наиболее известным примером настройки UML для определенного домена является SysML, язык домена для системная инженерия.

Смотрите также

Рекомендации

  1. ^ Келли, С. и Толванен, Ж.-П., (2008) Доменно-ориентированное моделирование: включение полной генерации кода, John Wiley & Sons, Нью-Джерси. ISBN  978-0-470-03666-2 [1]
  2. ^ Эйхберг, Майкл; Монперрус, Мартин; Клоппенбург, Свен; Мезини, Мира (2010), «Модельно-ориентированная разработка машинно-исполняемого кода» (PDF), Основы моделирования и приложения, 6138, стр. 104–115, Дои:10.1007/978-3-642-13595-8_10, получено 2019-03-06
  3. ^ Р.Дж. Welke. Репозиторий CASE: больше, чем другое приложение для баз данных. В W.W. Коттерман и Дж. Сенн, редакторы, Труды симпозиума INTEC 1988 г. Системный анализ и дизайн: стратегия исследования, Атланта, Джорджия, 1988 г. Государственный университет Джорджии. [2]
  4. ^ Смоландер, К., (1992) OPRR - Модель для моделирования методов разработки систем. В: Инструменты CASE нового поколения (ред. К. Лютинен, В.-П. Тахванайнен) IOS Press, Амстердам, Нидерланды, стр. 224-239.[3]
  5. ^ Келли, С., Литинен, К., Росси, М., «MetaEdit +: полностью настраиваемая многопользовательская и мультиинструментальная среда CASE», Труды CAiSE'96, 8th Intl. Conference on Advanced Information System Engineering, Lecture Notes in Computer Science 1080, Springer-Verlag, pp. 1-21, 1996. (in Кандидат наук. диплом как 3metools.pdf)

внешняя ссылка