Формирование модели гибкого процесса разработки программного обеспечения средствами processmining как задача удовлетворения ограничений
Адаптация гибких методологий управления программными проектами (методология Scrum) с использованием процесса ретроспективы. Проведение ретроспективы с использованием модели процесса разработки, полученной методами интеллектуального анализа processmining.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | статья |
Язык | русский |
Дата добавления | 19.06.2018 |
Размер файла | 237,7 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
УДК 519.68
Формирование модели гибкого процесса разработки программного обеспечения средствами processmining как задача удовлетворения ограничений
С.Ф. Чалый,
И.Б. Буцукина,
И.А. Криворотенко
Рассмотрена проблема адаптации гибких методологий управления программными проектами, в частности методологии Scrum, с использованием процесса ретроспективы. Предложен подход к проведению ретроспективы с использованием модели процесса разработки, полученной методами processmining.Задача формирования модели гибкого процесса разработки программного обеспечения средствами интеллектуального анализа процессов представлена как задача удовлетворения ограничений. Ограничения для рассматриваемой задачи определяются с учетом отношения, задающего допустимые сочетания значений дискретных переменных: продолжительности базового цикла разработки, допустимого набора задач цикла разработки, требований к исполнителям, а также их подмножества, на котором определено данное соотношение. Предложен обобщенный алгоритм решения данной задачи с учетом ограничений по исполнителям, задачам и по времени.
Ключевые слова: гибкие методологии разработки, Scrum, ретроспектива, processmining, задача удовлетворения ограничений.
Розглянуто проблему адаптації гнучких методологій управління програмними проектами, зокрема методології Scrum, з використанням процесу ретроспективи. Запропоновано підхід до проведення ретроспективи з використанням моделі процесу розробки, отриманої методами інтелектуального аналізу процесів. Задача формування моделі гнучкого процесу розробки програмного забезпечення засобами інтелектуального аналізу процесів представлена як задача задоволення обмежень. Обмеження для розглянутої задачі визначаються з урахуванням відносин, що задають допустимі поєднання значень дискретних змінних: тривалості базового циклу розробки, допустимого набору завдань для циклу розробки, вимог до виконавців, а також їх підмножини, на якій визначено дане співвідношення. Запропоновано узагальнений алгоритм вирішення даного завдання з урахуванням обмежень за виконавцями, завданнями і за часом.
This paper presents the basic principles of using agile methodologies. Were analyzed, in which it was discovered their advantages and disadvantages. The analysis examined the problem of adapting agile methodologies managing software projects, including the methodology Scrum. As part of the analysis the Scrum methodology it was investigated the retrospective process problems and have been proposed solutions using process mining. The task of forming a flexible model of the software development process mining tools represented as constraint satisfaction problems/ Restrictions for the problem are determined by the relationship defining the permissible combinations of discrete values of a few variables.To solve this problem have been investigated data mining methods and developed the algorithm of data mining usage to improve the retrospective process.
В настоящее время на разработку программного обеспечения затрачивается большая часть средств, выделенных на проектирование информационной системы в целом. В течение всего жизненного цикла разработки программного продукта необходимо осуществлять контроль своевременности и качества разработки. Эффективное построение процесса разработки программного продукта позволит снизить риски к минимуму, а также максимально учесть требования заказчика. В связи с этим актуальность использования эффективных методологий разработки программного продукта является несомненной.
Современные методологии разработки обеспечивают широкий диапазон подходов к созданию программных систем - от традиционной, водопадной модели до гибких, адаптируемых методологий.
Традиционный подход к управлению проектами направлен на последовательную, линейную разработку. Формируются требования, разрабатывается проект, выполняется кодирование и тестирование. По результатам выполнения всех этапов жизненного цикла проект сдается заказчику целиком. Существенным недостатком данного подхода является необходимость детального описания требований до начала разработки. В то же время на практике, в процессе разработки продукта могут возникать новые требования, уточняться уже существующие. Однако при традиционном подходе требования и сроки должны быть зафиксированы до начала разработки.
Альтернативой традиционному подходу являются гибкие методологии, при использовании которых на каждом этапе планируется разработка лишь ограниченной функциональности программного продукта. После завершения очередного этапа разработки заказчик может видеть работающую версию программного продукта, а также оценить ее соответствие сформулированным ранее требованиям. Это позволяет заказчику определить новые либо переопределить существующие требования.
Указанный подход к разработке предусматривает возможные изменения в требованиях заказчика и позволяет адаптировать методологию во время разработки проекта с учетом изменяющихся требований [1].
Процесс разработки программного обеспечения в соответствии с гибкой методологией целесообразно рассматривать как процесс преобразования ресурсов. Построение и уточнение моделей таких реально выполняющихся процессов связано с решением задач processmining. Формализация гибких методологий разработки путем построения модели процесса методами processminingс учетом имеющихся ограничений позволяет своевременно и эффективно вносить изменения в проект в соответствии с новыми требованиями (ограничениями). Также это дает возможность выявить и устранить отклонения от желаемого результата на ранних этапах разработки продукта и откорректировать ограничения за счет постоянной верификации продукта заказчиком.
Вышеизложенное и определяет актуальность рассматриваемой в статье проблематики.
Анализ литературы
Сущность гибких(Agile) методологий разработки программного обеспечения была представлена в документе «Манифест гибкой методологии разработки программного обеспечения» в виде 4 основных идей и 12 принципов [2]. Гибкие методологии использовалась многими компаниями и до принятия манифеста, однако именно после этого события Agile подход стал активно использоваться при разработке программного обеспечения.
Гибкий, эволюционный процесс разработки программного обеспечения в общем случае представляет собой задачу удовлетворения ограничений[3,4]. Целью последней является нахождение таких значений переменных, которые бы удовлетворяли заданным ограничениям. Рассматриваемая парадигма основана на декларативном описании системы ограничений и используется, в частности, для решения задач распределения ресурсов и планирования[5].Agile- процесс в общем случае включает себя итеративно выполняющуюся задачу планирования на ближайший цикл разработки.
Наиболее популярной методологией Agile - разработки является Scrum. В основе методологии Scrum лежит разбиение процесса разработки на короткие этапы, именуемые спринтами. По окончании каждого спринта программное обеспечение с разработанной на данном этапе функциональностью предоставляется заказчику. Также по завершению спринта может выполняться ретроспектива.
Ретроспектива предназначена для совместного обсуждения членами команды прошедшей итерации, выявления узких мест и усовершенствования процесса разработки. В целом ретроспектива является одним из ключевых элементов методологии Scrum, поскольку именно она позволяет адаптировать Scrum, делая из него по-настоящему гибкий подход к управления проектами[6].
В то же время, существующие подходы к выявлению узких мест в процессе разработки являются скорее искусством, они не формализованы и связаны с выделением ограничений человеком, что приводит к значительному влиянию человеческого фактора при решении поставленной задачи. Все это и определяет важность формализованного выявления процесса разработки на основе описания ограничений по наборам задачам и характеристикам исполнителей.
Цель и задачи исследования
В процессе разработки программного обеспечения и последующей ретроспективы могут возникать следующие проблемы, снижающие производительность команды разработчиков:
– размер спринта может быть переоценен/недооценен;
– производительность команды/отдельных членов команды может быть ниже/выше ожидаемой;
– конкретные задачи спринта могут быть переоценены или недооценены.
Все эти проблемы в первую очередь возникают у молодых команд, которые еще не сработались и только начинают формироваться либо же на первых спринтах, когда еще не определена средняя производительность команд[6].
В связи с этим основной целью при адаптации гибких методологий является построение модели динамически изменяющегося процесса разработки с учетом ограничений по размеру спринта, производительности членов команды, уровню сложности разрабатываемых во время спринта задач. Применение данной модели создает условия для автоматизации выявления причин проблем и узких мест процесса разработки при проведении ретроспективы.
Задача удовлетворения ограничений при построении модели процесса разработки программного обеспечения средствами processmining
Processmining (интеллектуальный анализ процессов, ИАП) - это процесс извлечения знаний о бизнес-процессах из журналов событий (логов).ИАП позволяет в автоматизированном режиме построить модель процесса, использовав журнальные данные. Следует отметить, что указанная технология базируется на технологии интеллектуального анализа данных (Datamining).[7]
Методы интеллектуального анализа процессов (processmining) используют в качестве исходных данных наборы последовательностей событий, отражающих выполнение процесса. Предполагается, что можно последовательно записывать события, и каждое из таких событий относится к некоторой активности (т.е. к четко определенному шагу в процессе) и связано с экземпляром процесса. Такие записи, составляющие исходные данные для анализа содержатся в журнале регистрации событий (логе).
Результатом использования методов processmining является модель исходного(выполнявшегося) процесса.
Такой процесс является дискретным (изменения состояний происходят только в дискретные моменты времени), который на входе получают ресурсы (финансовые, человеческие, материальные), во время своего выполнения преобразуют ресурсы в выходные программные продукты. Траектория (путь) выполнения рассматриваемых процессов отображается в виде дискретной последовательности событий. Каждое из этих событий фиксирует выполнение соответствующего действия процесса.
Один из первых алгоритмов processmining основывался на обработке вероятностей наступления последовательностей событий. Основные шаги алгоритма состоят в следующем: создаются таблицы вероятностей для последовательностей событий путем подсчета числа появлений одинаковых последовательностей в потоке событий. После этого последовательности, вероятность и число появлений которых ниже установленного пользователем порога, отсекаются, а оставшиеся используются для создания конечного автомата[8].
Ведущий ученый в данной области Ван дер Аалст разработал наиболее часто используемый алгоритм processmining- б-алгоритм. Его основное отличие состоит в том, что заранее можно сказать c каким классом моделей алгоритм будет гарантированно работать. Необходимое условие для работы алгоритма - отсутствие шума в исходных данных.
В основе алгоритмов ИАП лежит допущение, что все вершины графов должны иметь уникальные метки (т. е. одному уникальному событию должна соответствовать ровно одна вершина на модели). Это затрудняет извлечение дублируемых задач.
Все типовые конструкции распознает генетический алгоритм, однако его выполнение занимает очень большое время.
В целом, б-алгоритм является наиболее подходящим для решения поставленной задачи построения модели процесса разработки программного обеспечения, поскольку класс моделей известен заранее.
Типовая структура лога исходных, которая необходима для работы методов ИАП, включает в себя следующие элементы:
событие, отражающее выполнение действия (задачи);
– временная метка;
– дополнительные параметры (например, исполнитель, объект, с которым работает процесс).
Для процессов быстрой разработки программного обеспечения файл лога включает следующие составляющие:
временная метка;
задача (идентификатор задачи);
состояние события;
пользователь (идентификатор пользователя);
дополнительные атрибуты действия (сложность, затраченное время, приоритет и др.).
Использование средств интеллектуального анализа процессов позволяет построить модель процесса разработки, которую впоследствии можно использовать для анализа при проведении ретроспективы.
Процесс описывается графом, вершины которого отражают состояния моделируемой динамической системы, дуги - переходы между этими состояниями. Переходы связаны с выполнением действий над объектами процесса.
Выполнение одного из возможных в текущем состоянии действий процесса зависит от входного состояния процесса и набора выполненных действий.
Конечным состоянием является такое, из которого отсутствуют дуги в другие состояния процесса.
Реализация каждого процесса (след, трасса процесса) представляет собой последовательность действий, переводящих процесс из начального состояния в конечное. В общем случае каждый процесс обладает множеством трасс. След процесса отражается в рассмотренном выше файле лога.
Исходя из рассмотренных особенностей задачи построения модели процесса гибкой разработки программного обеспечения, можно сделать вывод о том, что данная задача определяется набором дискретных переменных , которые соответствуют продолжительности спринта, набору задач спринта и исполнителям (членам команды). Множества значений для каждой из переменных определяются соответственно требованиями заказчика к срокам сдачи проекта, к функциональности разрабатываемого программного обеспечения, а также составом и квалификацией команды разработчиков. Для задания ограничений определим на множестве значений отношение
,
задающее допустимые сочетания значений рассмотренных переменных. Тогда множество переменных , на котором определено отношение , задает возможный диапазон отношений, а пара определяет набор ограничений рассматриваемой задач. Тогда задача построения модели гибкого процесса разработки программного обеспечения средствами processmining представляет собой задачу удовлетворения ограничений, которая имеет следующий вид:
,
где - набор ограничений по срокам, задачам на один спринт и возможностям исполнителей.
Для решения задачи необходимо найти такие значения переменных , которые бы удовлетворяли ограничениям .
При решении данной задачи необходимо учитывать, что отношение является пересечением отношений для сроков, исполнителей, задач:
.
Технология анализа процесса разработки заключается в предварительном анализе лога событий, структурировании/фильтрации данных, построение графиков, на основе полученных данных. Предварительный анализ процесса разработки позволяет формализовать/визуализировать процесс разработки с различных сторон:
1. Формализация/визуализация процесса выполнения конкретной задачи. Сравнение реального времени выполнения с оцененным;
2. Формализация/визуализация процесса выполнения задач конкретным членом команды. Сравнение производительности члена команды с ожидаемыми оценками.
3. Формализация/визуализация процесса выполнения спринта в целом.
Таким образом, применение методов анализа процессов позволит обеспечить эффективное проведение ретроспектив с выявлением проблемных мест в процессе разработки.
Для решения рассмотренной задачи удовлетворения ограничений по длительности цикла разработки на каждой итерации, исполнителям, функциональности, необходимо выполнить следящие шаги:
1. Трансформация исходных данных для построения модели процесса разработки методами processmining в требуемый формат.
2. Модификация названий задач с учетом их статуса и исполнителя
3. Формирование ограничений по размеру спринта, исполнителям, функциональности.
4. Формирование исходных данных для построения модели с учетом имеющихся ограничений.
5. Построение модели процесса разработки на основе выделенных исходных данных.
6. Анализ модели и, при необходимости уточнение ограничений.
Алгоритм решения задачи формирования модели гибкого процесса разработки программного обеспечения средствами processmining представлен на рисунке 1.
Задача формирования модели гибкого процесса разработки программного обеспечения средствами интеллектуального анализа процессов представлена как задача удовлетворения ограничений. Данная задача определяется следующим набором дискретных переменных: продолжительность спринта (базового цикла разработки), допустимый набор задач спринта, требуемый уровень квалификации исполнителей (членов команды разработчиков).
Множества значений для каждой из переменных задачи определяются уровнем требований заказчика (владельца проекта) к срокам его разработки, к его функциональным возможностям, а также к и квалификации разработчиков.
Ограничения для рассматриваемой задачи определяются с учетом отношения, задающего допустимые сочетания значений указанных переменных, а также их подмножества, на котором определено данное соотношение.
Рисунок 1 - Алгоритм решения задачи построения модели процесса разработки программного обеспечения с учетом ограничений по исполнителям, задачам и по времени
Выделена базовая последовательность этапов метода построения этапа разработки, и разработан обобщенный алгоритм решения данной задачи с учетом ограничений по исполнителям, задачам и по времени.
В практическом плане полученные результаты дают возможность выполнять усовершенствование гибкой методологии разработки программных проектов Scrum, путем построения модели разработки средствами интеллектуального анализа процессов и использования этой модели в процессе ретроспективы. Применение модели дает возможность автоматизировать выявление причин проблем, возникших во время проведения спринта. Поэтому применение методов processmining позволяет увеличить эффективность ретроспективы, и вследствие улучшить процесс разработки программного продукта в целом.
гибкий программный ретроспектива processmining
Литература
1. Мартин, Р. Быстрая разработка программ. Принципы, примеры, практика.Tennessy, 2011. 264 с.
2. Книберг, Х. Scrum и XP для тренеров. Вильямс, 2010.268 с.
3. Apt K. R. Principles of Constraint Programming. New York: Cambridge University Press, 2003. 407 p.
4.Rossi F., van Beek P., Walsh T. (eds.) Handbook Of Constraint Programming. Elsevier, 2006.978 p.
5. Kautz H., Selman B. Planning as Satisfiability // Proceedings of European Conference on Artificial Intelligence ECAI-92 (Vienna, 1992). Chichester: John Wiley and Sons, 1992. P. 359-363.
6. Мартин,Р. Чистыйкод. Висконсин, 2010. 201 с.
7.Van der Aalst W. Process Mining: Discovery, Conformance and Enhancement of Business Processes Y.: Springer Verlag, 2011. 370 с.
8. Барсегян А. Анализ данных и процессов 3-е издание. Спб: БХВ-Петербург, 2009. 513 c.
Размещено на Allbest.ru
...Подобные документы
Понятие программной инженерии как применения определенного систематического измеримого подхода при разработке, эксплуатации и поддержке программного обеспечения. Модели процесса разработки программного обеспечения. Управление программными проектами.
презентация [870,6 K], добавлен 12.11.2014Проектирование корпоративных информационных систем. Автоматизация процесса выполнения лабораторных работ по дисциплине "Управление программными проектами". Построение модели ИС учебного процесса: архитектура, формализация пользовательских требований.
дипломная работа [1,1 M], добавлен 20.08.2017Использование моделирования в программной инженерии в процессе разработки программного обеспечения. Основные этапы процесса разработки программного обеспечения, их характеристика. Моделирование процессов, их определение фазами и видами деятельности.
реферат [2,2 M], добавлен 25.12.2017Построение схемы модели процесса и разработка анимации; определение характеристики модели с использованием AnyLogic. Сеть Петри для процесса работы порта. Описание программного продукта. Объекты библиотеки Enterprise Library. Результаты работы модели.
курсовая работа [334,1 K], добавлен 25.04.2015Понятие программного обеспечения, вопросы его разработки и использования. Общая характеристика системного программного обеспечения и работа операционной системы. Специфика процесса управления разработкой программного обеспечения и его особенности.
курсовая работа [636,2 K], добавлен 23.08.2011Проблема надежности программного обеспечения, ее показатели и факторы обеспечения. Методы контроля процесса разработки программ и документации, предупреждение ошибок. Этапы процесса отладки ПО, приемы структурного программирования и принцип модульности.
презентация [379,5 K], добавлен 30.04.2014Выбор, обоснование и особенности языка программирования. Вербальное и графическое описание функционального назначения системы. Разработка диаграммы классов, описывающей логическую модель системы. Проектирование физической структуры программного средства.
курсовая работа [2,4 M], добавлен 26.05.2014Современные методологические проблемы разработки и внедрения программного обеспечения ERP систем. Основные концептуальные подходы к методологии разработки и внедрения программного обеспечения. Исследование методологии ASAP: ее сильные и слабые стороны.
дипломная работа [4,3 M], добавлен 29.04.2011Базовые приемы работы при создании трехмерной модели в пакете Компас. Абсолютная система координат, координатные плоскости. Управление изображением, цветом и свойствами поверхности объектов. Этапы процесса разработки трехмерной модели "Форма для льда".
курсовая работа [963,3 K], добавлен 11.06.2012Общая характеристика основных моделей жизненного цикла: каскадная, инкрементная, спиральная. Стадия как часть процесса создания программного обеспечения, ограниченная определенными временными рамками и заканчивающаяся выпуском конкретного продукта.
презентация [159,1 K], добавлен 27.12.2013Анализ этапов и особенностей разработки оптимальной и функциональной ARIS-модели - программного продукта компании IDS Scheer для моделирования бизнес-процессов компании. Изучение основных концепций, методологий и подходов экстремального программирования.
контрольная работа [119,9 K], добавлен 04.06.2011Анализ и разработка информационной системы, структура сети предприятия. Описание процесса разработки конфигураций и выявление потребностей в автоматизации функций. Средства разработки проектирования и архитектура базы данных. Разработка модели угроз.
дипломная работа [1,4 M], добавлен 13.07.2011Разработка граф-схемы имитационной модели финансовых потоков предприятия и реализация модели программными средствами Pilgrim. Алгоритм моделирования с постоянным шагом. Выполнение моделирования на полученной программе, разработка программного кода.
курсовая работа [1,8 M], добавлен 22.11.2013Применение промышленных технологий создания программного продукта. Описания принципов, методов, применяемых процессов и операций. Общие понятия методологии разработки программного обеспечения (ПО). Сравнение современных методологий проектных групп.
курсовая работа [1,6 M], добавлен 04.12.2009Разработка системы управления проектами для компании ЗАО "Диакон". Экономические параметры разработки и внедрения электронной информационной системы. Технология разработки программного обеспечения. Выбор типа графического интерфейса, его составляющие.
дипломная работа [1,4 M], добавлен 10.06.2014Оценка финансовой, стратегической ценности и уровня рисков проекта. Классификация проектов: "свой" заказчик, продукт под заказ, тиражируемый продукт, аутсорсинг. Организация процесса разработки программного обеспечения, методологии его проектирования.
презентация [82,8 K], добавлен 07.12.2013Общий календарный план выполнения этапов проекта программного обеспечения. Последовательность разработки согласно классической каскадной модели. Изображение хода работ по спиральной модели согласно Боему. Технические требования на продукт, WBS-структура.
лабораторная работа [614,1 K], добавлен 17.01.2014Алгоритм симплекс-метода. Задача на определение числа и состава базисных и свободных переменных, построение математической модели. Каноническая задача линейного программирования. Графический метод решения задачи. Разработки математической модели в Excel.
курсовая работа [1,1 M], добавлен 18.05.2013Сущность логистического бизнес-процесса. Функциональная, инфологическая и даталогическая модели предметной области. Выбор языка и средства программирования. Разработка и описание программного обеспечения для автоматизации закупок на предприятии.
дипломная работа [4,8 M], добавлен 29.06.2012Развитие аппаратных компьютерных средств - задача первых трех десятилетий компьютерной эры. Процесс тестирования как составляющая процесса обеспечения качества разработки ПО. Принципы и критерии, предъявляемые к тестированию программного обеспечения.
курсовая работа [319,5 K], добавлен 25.05.2009