Алгоритмы автоматизированного выявления связей между элементами проекта разработки программного обеспечения
Методика определения связей между элементами проекта разработки программного обеспечения, реализуемого с помощью трассировки требований на основе данных из систем контроля версий исходного программного кода. Характеристика известных методов трассировки.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | статья |
Язык | русский |
Дата добавления | 07.03.2019 |
Размер файла | 519,1 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Алгоритмы автоматизированного выявления связей между элементами проекта разработки программного обеспечения
Голосовский Михаил Сергеевич
научный сотрудник, Государственный
научно-исследовательский испытательный
институт военной медицины Министерства
обороны Российской Федерации
Аннотация
обеспечение программный трассировка
Предметом исследования является определение связей между элементами проекта разработки программного обеспечения, реализуемое с помощью трассировки требований на основе данных из систем контроля версий исходного программного кода. Многие известные методы трассировки являются зависимыми от языка программирования, что ограничивает их использование в проектах, разрабатываемых с использованием нескольких языков программирования. Поэтому цель исследования заключалась в формировании набора алгоритмов, позволяющих выстраивать связи между сущностями процесса разработки программного обеспечения (артефактами) на основе исходного кода, и анализировать эти связи (при этом код должен быть независимым от языка программирования и простым в реализации). Методология исследования объединяет методы системного анализа, программной инженерии, разработки программного обеспечения, теории надежности, информатики и математической квалиметрии. Основными выводами проведенного исследования являются алгоритмы автоматизированного определения связей между элементами проекта разработки программного обеспечения, позволяющие решать поставленные задачи выполнения импакт-анализа. Высокую вычислительную сложность разработанных алгоритмов можно снизить путем постепенного формирования глобальной матрицы связности по мере развития проекта. Точность разработанных алгоритмов можно повысить, если в качестве элемента связи брать не файл, а функцию или метод класса.
Ключевые слова: программная инженерия, разработка программного обеспечения, требования к программам, трассировка требований, система контроля версий, программный код, версии программного кода, архитектура программного приложения, контроль целостности архитектуры, связи элементов проекта
Abstract
The subject of the study is to determine the links between elements of software development projects implemented with the help of tracing requirements on the basis of data from the monitoring systems of versions of the source code. Many well-known tracing techniques are dependent on the programming language, which limits their use in projects developed using multiple programming languages. Therefore, the research goal was to form a set of algorithms to build relationships between the entities the software development process (artifacts) on the basis of the source code and analyze these connections (the code should be independent of the programming language and easy to implement). The research methodology combines methods of system analysis, software engineering, software development, reliability theory, computer science and mathematical qualimetry. The main conclusions of the study are the algorithms for the automated determination of relations between the elements of a software development project, allowing to solve tasks perform impact analysis. High computational complexity of the algorithms developed can be reduced by the gradual formation of a global connectivity matrix as the project progresses. The accuracy of the developed algorithms can be improved, if the coupling element does not take the file, and the function or class method.
Keywords: software application architecture, version the program code, program code, version control system, tracing requirements, program requirements, software development, program engineering, integrity control architecture, communication project elements
Введение
Трассировке требований уделено большое внимание в современной программной инженерии. В работе К. Вигерса [1]дано определение трассируемости требований как документирование зависимостей и логических связей отдельных требований и других элементов системы. Наиболее востребованными задачами, решаемыми применением трассировки являются:
1. Получение актуального статуса системы по требованиям;
2. Анализ влияния изменения;
Вигерс рассматривал полную трассировку от требования до исходного кода (функции) программы, но большинство систем управления требованиями поддерживает трассировку до уровня тест кейса или до уровня задачи разработчику на реализацию соответствующего требования. Подобная трассировка позволяет достаточно эффективно решать задачу 1, посредством связей отвечая на вопросы какие требования реализованы и какие требования протестированы, но не всегда эффективно позволяет решать задачу 2, в связи с тем, что между двумя требованиями может существовать связь на уровне программного кода, которая не проставлена на уровне требований, задач или тестовых сценариев. Подробный обзор работ, затрагивающих тему измерения силы влияния изменения проведён в работе [2], на основании которого выделены четыре класса анализа влияния изменений:
1. Использование статического анализа программ основанного на структуре программы и отношении между элементами программы;
2. Использование динамического анализа программ основанного на сборе данных во время выполнения программы;
3. Использование анализа на основе обработки исторических данных, получаемых из систем контроля версий программного кода;
Большая часть рассмотренных методов является зависимой от языка программирования, что ограничивает их использование в проектах, разрабатываемых с использованием нескольких языков программирования [3-6]. Цель этой статьи заключается в формировании набора алгоритмов, позволяющих выстраивать связи между сущностями процесса разработки программного обеспечения (артефактами) на основе исходного кода, и анализировать эти связи. При этом он должен быть независимым от языка программирования и простым в реализации.
Исходные данные для выполнения трассировки
Рассмотрим модель, описывающую взаимосвязь элементов процесса разработки программного обеспечения, в дальнейшем будем называть их артефактами (рис. 1).
Рисунок 1 - Схема модели взаимосвязи артефактов процесса разработки
Основу модели составляют требования, которые могут выстраиваться в иерархическую структуру с декомпозицией более общих требований более детальными требованиями. При этом ассоциативная связь может возникать между разными требованиями, не находящимися в иерархических отношениях друга другом. В работе под понятием требование будет использоваться общее определение требования, данное в своде знаний по программной инженерии третьей версии [7] как свойство, представленное чем-либо, для решения некоторой проблемы реального мира. Более детально, в зависимости от методологии проектирования и обработки требований в организации, возможно деление требований на различные типы (как пример [2]: функциональные требования, не функциональные требования, атрибуты качества, ограничения, бизнес требования и бизнес правила), но в общем случае допускается, что зависимости могут возникать между требованиями разных типов. Задачи так же могут выстраивать иерархию посредством декомпозиции более крупных задач на более мелкие [8-14]. При этом каждое требование должно быть ассоциировано как минимум с одной задачей, реализующей это требование. В процессе работы, каждому артефакту процесса разработки присваивается уникальный идентификатор. При написании кода в рамках задачи каждому блоку кода, добавляемому в репозиторий, разработчик проставляет комментарий с явным указанием номера задачи или дефекта, в рамках которого было проведено изменение. Дефекты заводятся по итогам выполнения тестовых сценариев, проверяющих полноту реализации требования. Одно требование может быть проверено несколькими тестовыми сценариями, так и один сценарий может проверять несколько требований (сквозные сценарии). Уровни трассировки и роли участников проекта за ведение связей представлены в табл. 1.
Таблица 1 - Распределение ответственности за уровни трассировки по ролям участников проекта
Уровень трассировки |
Роль участника проекта, ответственного за ведение трассировки |
|
Требование - Требование |
Аналитик, Архитектор |
|
Требование-Компонента |
Архитектор |
|
Требование - Задача |
Ведущий разработчик |
|
Задача-Задача |
Ведущий разработчик |
|
Задача - Код |
Разработчик |
|
Требование - Тестовый сценарий |
Ведущий тестировщик |
|
Тестовый сценарий- Дефект |
Тестировщик |
Помимо явных связей между требованиями, формируемыми аналитиками, в рамках предложенного алгоритма формируются не явные связи, посредством трассировки по путям требование-задача-код и требование-тестовый сценарий-дефект-код. Основная идея метода заключается в том, что в современных языках программирования как правило отдельные классы и методы реализуются в отдельных файлах. И в случае, если две разные задачи имеют общий код в рамках одного файла, то велика вероятность, что между этими задачами есть логическая связь. В рассматриваемой модели непосредственно с участками кода соединяются задачи и дефекты, и в этом случае, возможны следующие комбинации связей через общий код:
1. Задача, задача - один файл
2. Задача, дефект - один файл
3. Дефект, дефект - один файл
В связи с тем, что с одной задачей или дефектом может быть ассоциировано большое количество файлов, тестовые сценарии могут быть сквозными и покрывать несколько и с учетом иерархической структуры требований и задач, необходимо разработать алгоритм вычисления силы связей между требованиями. В качестве основы для вычисления возьмём силу связи файл-задача или файл-дефект Sf, которая будет измеряться в отношении строк кода k ассоциированных с задачей или дефектом к общему числу строк кода N (формула 1). В расчёте принимают участие только строки, содержащие операторы языка программирования.
Sf = k / N. (1)
Сила связи St между разными задачами/дефектами ассоциированными с одним файлом будет определяться наименьшим значением силы связи между парой ассоциированных с файлом артефактов, рассчитанной по формуле 2.
St = min(sf1, sf2) (2)
Значение силы связи может принимать значения от 0 до 1. В случае значения 0 - связь отсутствует, в случае 1 - связь максимальная. Так как между одними и теми же артефактами может осуществляться связь через несколько файлов, определим требования к функции F, вычисляющей результирующее значение силы связи:
В предельном случае, число аргументов функции равно двум и область определения входных аргументов принадлежит интервалу [0…1];
F(x1,x2) = F(x2,x1) - коммутативность, порядок следования аргументов в операции не имеет значения.
F(x,0) = x; - в случае, если связь между артефактами через некоторый файл отсутствует, то существующая связь недолжна измениться;
F(x,1) = 1 - если уже достигнута максимальная связь между артефактами, она не должна быть уменьшена;
F(x1,F(x2,x3)) = F(F(x1,x2), x3) - ассоциативность, при выполнении алгоритма, должна быть возможность вычислять силу связи попарно, при этом не имеет значения порядок вычисления;
F(x1,x2) ? max(x1,x2) - в идеале, значение силы связи должно быть больше значения максимального элемента, при двух аргументах отличных от нуля. В этом случае, при наличии связей через большое число файлов, результирующая сила связи будет стремиться к максимальному значению.
Указанным условиям удовлетворяет следующая функция (3):
F(x1,x2) = x1 + x2 - x1 x2 . (3)
Алгоритм определения силы связей между артефактами системы
Подготовительная часть алгоритма, заключается в приведении графа иерархической связанности артефактов к виду леса деревьев и нормализации высоты деревьев. Приведение к виду леса деревьев осуществляется следующим образом:
1. Отбираются вершины, не имеющие родителей.
2. Для каждой вершины не имеющий родителя осуществляется поиск в глубину вершин, имеющих 2 и более родителя.
3. Если такая вершина находится, исследуются дочерние вершины на предмет наличия вершин, имеющих несколько родителей.
4. Если среди дочерних вершин, вершин имеющих более одного родителя не найдено, выполняется копирование вершины, и её поддерева для каждого родителя (рис. 2), при этом связи у скопированной вершины и её родителя проставляется значение мощности s, вычисляемое по формуле 4.
s = 1/m (4)
Рисунок 2 - Графическая иллюстрация преобразования связей между артефактами
Вычисление связи возможно между артефактами одного уровня. В связи с тем, что требования, как правило, формируют иерархическую структуру, выполним приведение деревьев в части только требований к максимальной высоте (рис. 3). Для этого:
1. Находится высота самого высокого дерева hmax.
2. Если эта высота равна 1, то приведение к максимальной высоте не требуется.
3. В случае, если hmax>2, для каждого дерева с минимальной высотой h?2 фиксируется первый уровень, уровень дерева h переносится на hmax, на уровнях c h-1 по hmax формируются виртуальные вершины, копирующие уровень h-1 (рисунок 3). Приведение к уровню hmax производится для каждого поддерева, не достигающего уровня hmax.
4. В случае, если h=1, то выполняется создание виртуальных вершин, копирующих вершину 1 до уровня hmax.
Рисунок 3 - Приведение деревьев к максимальной высоте
После выравнивания деревьев на уровне требований, по тому же алгоритму выполняется приведение для поддеревьев на уровне задач.
Приведём алгоритм определения силы связи между артефактами системы. В процессе вычисления принимают участия только связи через общий код и связи типа декомпозиция. Остальные явно проставленные ассоциативные и прочие связи не учитываются.
Алгоритм вычисления связей между требованиями для текущей ревизии (версии) и ветки репозитория:
1. Отбирается список файлов в проекте
2. В текущей ревизии для каждого файла отбираются задачи/дефекты ассоциированные с выбранным файлом средствами системы контроля версий, (как пример, команда hg annotate для CVS Mercurial) и вычисляется сила связи по формуле 1 для каждой пары дефект-файл или задача-файл.
3. Формируется матрица связи между задачами/дефектами, непосредственно ассоциированными с исходным кодом. Для этого, если артефакты связаны через несколько файлов, сначала применяется формула 2, определяющая связь через каждый файл в отдельности, после чего применяется формула 3, последовательно к каждой паре значений, проводя свёртку и вычисление единого значения силы связи.
3. На основании полученных на шаге 3 значений, формируется квадратная матрица связности между сущностями разработки - задачами и дефектами, непосредственно ассоциированными с исходным кодом, симметричная относительно главной диагонали.
4. Для каждой отличной от нуля записи в таблице формируем связь между элементами, стоящими выше по уровню иерархии. При этом выполняются следующие правила:
- Если для каждого элемента верхнего уровня иерархии связь осуществляется только через один элемент нижнего уровня иерархии, то значение связи передаётся выше по уровню иерархии без изменений.
- Если для элемента верхнего уровня иерархии связь осуществляется через несколько элементов нижнего уровня, то для свёртки применяется формула 3, последовательно к каждой паре значений. При операции на матрице, алгоритм выглядит следующим образом. Фиксируются строки для двух элементов, для которых произойдёт свёртка на верхнем уровне. Создаётся матрица, в которой две свёртываемые строки и два свёртываемых соответственно столбца, заменены одной строкой и столбцом. Для столбцов, номера которых не равны выбранным строкам по исходной матрице, производится операция свёртки по формуле 3 результат копируется в новую матрицу. Операция производится попарно до тех пор, пока все дочерние элементы не будут свёрнуты.
- Если иерархическая связь содержит понижающий коэффициент, полученный на подготовительном этапе при формировании дерева, то он применяется к результатам предыдущих двух операций с использованием формулы 4.
Итогом выполнения алгоритма является набор по уровневой связности артефактов системы посредством программного кода. С использованием полученной матрицы возможно выполнение следующих видов анализа:
1. Определение требований, которые необходимо повторно протестировать при изменении кода в выбранном файле (файлах);
2. Определение величины изменения системы, при изменении того или иного требования.
3. Определение нарушений архитектурной целостности посредством выявления связей между компонентами системы, которые изначально не были запланированы к реализации архитектором.
Определение требований, которые необходимо повторно протестировать при изменении кода в выбранном файле осуществляется следующим образом:
1. Отбираются требования нижнего уровня, ассоциированные с выбранными файлами (файлами).
2. Для выбранных требований, отбираются требований с силой связи, превышающей пороговое.
3. Шаг 2 повторяется до тех пор, пока новые требования перестанут добавляться. Возможно явно ограничить уровень отбора.
4. Требования сортируются по силе связи с непосредственно отобранным файлом. И отбираются связанные с ними тестовые сценарии.
Для определения величины изменения системы, выбирается требование, которые необходимо изменить и отбираются требования непосредственно связанные с ним. Проводится трассировка до уровня исходного кода, после чего вычисляется число файлов, затронутых этими требованиями, и процент кода в этих файлах, ассоциированных с этими требованиями. Итоговая величина изменения R рассчитывается по формуле 5.
R = Na/N, (5)
где Na - число строк кода, связанных с выбранными требованиями. N - общее число строк кода в проекте.
Пример выполнения алгоритма
Выполнение алгоритма рассмотрим на структуре артефактов, представленной на рис. 4, где R - требование, Тс - тестовый сценарий, Т - задача, D - дефект. Исходные данные в виде числа строк в файлах и их ассоциация с артефактами приведена в таблице 2.
Таблица 2 - Число строк, ассоциированных с каждым артефактом
Названия файлов |
Всего строк |
Число ассоциированных строк с задачей или дефектом, полученных на основе системы контроля версий |
||||||||||
T1 |
T2 |
T3 |
T5 |
T6 |
T7 |
T8 |
D1 |
D2 |
D3 |
|||
F1 |
169 |
79 |
0 |
82 |
0 |
0 |
0 |
0 |
8 |
0 |
0 |
|
F2 |
138 |
55 |
83 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
F3 |
107 |
0 |
107 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
F4 |
146 |
0 |
0 |
121 |
0 |
0 |
0 |
0 |
0 |
25 |
0 |
|
F5 |
158 |
0 |
0 |
0 |
67 |
91 |
0 |
0 |
0 |
0 |
0 |
|
F6 |
161 |
0 |
0 |
0 |
95 |
54 |
0 |
0 |
0 |
0 |
12 |
|
F7 |
92 |
0 |
0 |
0 |
0 |
0 |
85 |
0 |
0 |
0 |
7 |
|
F8 |
193 |
0 |
0 |
0 |
0 |
0 |
0 |
193 |
0 |
0 |
0 |
Рисунок 4 - Исходная структура артефактов
Для исходной структуры проведем предварительные преобразования. В результате этих преобразований тестовый сценарий Тс2 и его дочерние элементы разбиваются на две подветви с силой связи с родительскими элементами R7 и R5 по 0,5. Итоговое дерево артефактов (рис. 5) имеет высоту 9 уровней, из них 1 уровень файлов и один уровень тестовых сценариев. Тестовые сценарии непосредственно при формировании матриц связности принимать участие не будут. Нумерацию уровней будем вести от корней дерева - требования R1 и R9.
В таблице 3 представлены данные, полученные на основе связей между файлами и артефактами самого нижнего уровня. Из них, наибольшей связностью обладают задачи Т5 и Т6, для которых связь осуществляется через два файла.
Рисунок 5 - Структура артефактов после подготовительных преобразований
Таблица 3 - Сила связи между артефактами седьмого уровня
Артефакт |
T1 |
T2 |
T3 |
T5 |
T6 |
T7 |
T8 |
D1 |
D2 |
D3 |
|
T1 |
0 |
0,4 |
0,47 |
0 |
0 |
0 |
0 |
0,05 |
0 |
0 |
|
T2 |
0,4 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
T3 |
0,47 |
0 |
0 |
0 |
0 |
0 |
0 |
0,05 |
0,21 |
0 |
|
T5 |
0 |
0 |
0 |
0 |
0,62 |
0 |
0 |
0 |
0 |
0,07 |
|
T6 |
0 |
0 |
0 |
0,62 |
0 |
0 |
0 |
0 |
0 |
0,07 |
|
T7 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0,08 |
|
T8 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D1 |
0,05 |
0 |
0,05 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D2 |
0 |
0 |
0,21 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D3 |
0 |
0 |
0 |
0,07 |
0,07 |
0,08 |
0 |
0 |
0 |
0 |
Таблица 4 - Сила связи между артефактами шестого уровня
Артефакт |
T1 |
T2 |
T3 |
T4 |
T7 |
T8 |
D1 |
D2 |
D3 |
|
T1 |
0 |
0,4 |
0,47 |
0 |
0 |
0 |
0,05 |
0 |
0 |
|
T2 |
0,4 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
T3 |
0,47 |
0 |
0 |
0 |
0 |
0 |
0,05 |
0,21 |
0 |
|
T5 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0,07 |
|
T7 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0,08 |
|
T8 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D1 |
0,05 |
0 |
0,05 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D2 |
0 |
0 |
0,21 |
0 |
0 |
0 |
0 |
0 |
0 |
|
D3 |
0 |
0 |
0 |
0,07 |
0,08 |
0 |
0 |
0 |
0 |
Таблица 5 - Сила связи между артефактами четвёртого уровня
Артефакт |
R4 |
R6 |
R7 |
R3 |
R9 |
R10 |
|
R4 |
0 |
0,4 |
0,49 |
0 |
0 |
0 |
|
R6 |
0,4 |
0 |
0 |
0 |
0 |
0 |
|
R7 |
0,49 |
0 |
0 |
0,1 |
0 |
0 |
|
R3 |
0 |
0 |
0,1 |
0 |
0,07 |
0 |
|
R9 |
0 |
0 |
0 |
0,07 |
0 |
0 |
|
R10 |
0 |
0 |
0 |
0 |
0 |
0 |
Таблица 6 - Сила связи между артефактами третьего уровня
Артефакт |
R4 |
R5 |
R3 |
R9 |
R10 |
|
R4 |
0 |
0,69 |
0 |
0 |
0 |
|
R5 |
0,69 |
0 |
0,1 |
0 |
0 |
|
R3 |
0 |
0,1 |
0 |
0,07 |
0 |
|
R9 |
0 |
0 |
0,07 |
0 |
0 |
|
R10 |
0 |
0 |
0 |
0 |
0 |
Таблица 7 - Сила связи между артефактами второго уровня
Артефакт |
R2 |
R3 |
R9 |
R10 |
|
R2 |
0 |
0,1 |
0 |
0 |
|
R3 |
0,1 |
0 |
0,07 |
0 |
|
R9 |
0 |
0,07 |
0 |
0 |
|
R10 |
0 |
0 |
0 |
0 |
Таблица 8 - Сила связи между артефактами первого уровня
Артефакт |
R1 |
R8 |
|
R1 |
0 |
0,07 |
|
R8 |
0,07 |
0 |
На четвёртом уровне, табл. 5, представлена связь между требованиями самого нижнего уровня. Она уже может использоваться для проведения анализа влияний при изменении кода в определённом файле.
Пример: в рамках исправления нового дефекта D4 внесены изменения в файл F1, в этом случае нужно в первую очередь повторно протестировать требования R4 и R7, как иерархически ассоциированные с файлом F1, и требование R6, которое иерархически с кодом не связано, но имеет отличную от нуля связь с требованием R4.
Итоговая таблица 8, представляет связь между требованиями первого уровня. В случае, если требования R1 и К8 связаны с компонентами, которые не должны иметь логической связи друг с другом, то наличие связи через общий код должно послужить сигналом к расследованию корректности реализации спроектированной архитектуры.
Заключение
Предложенный алгоритм позволяет решать поставленные задачи выполнения импакт-анализа. Но его основным недостатком является высокая вычислительная сложность, с проработкой N2 элементов. В крупных программных проектах число артефактов процесса разработки ПО достигает нескольких десятков, если не сотен тысяч. Как средство решения этой проблемы возможно предложить постепенное формирование глобальной матрицы связности по мере развития проекта. Вторым основным недостатком метода является невысокая точность, которую можно повысить, если в качестве элемента связи брать не файл, а функцию или метод класса.
Библиография
1. Wiegers G K, Beatty J. Software Requirements Third Edition. Pearson Education, 2013. 672 p.
2. Li B., Sun X., Leung H., Zhang S. A survey of code-based change impact analysis techniques. Softw. Test. Verif. Reliab., p. 34, 2012.
3. Мельченко А.А. Гибкие методологии разработки программного обеспечения: экстремальное программирование управления проектами // Известия Гомельского государственного университета им. Ф. Скорины. 2015. № 2 (89). С. 146-150.
4. Богомолов А.В., Чуйков Д.С., Запорожский Ю.А. Средства обеспечения безопасности информации в современных автоматизированных системах // Информационные технологии. 2003. № 1. С. 2.
5. Марков А.С., Миронов С.В., Цирлов В.Л. Выявление уязвимостей программного обеспечения в процессе сертификации//Информационное противодействие угрозам терроризма. 2006. № 7. С. 177-186.
6. Миронов С.В., Куликов Г.В. Технологии контроля безопасности автоматизированных систем на основе структурного и поведенческого тестирования программного обеспечения // Кибернетика и программирование. 2015. № 5. С. 158-172.
7. Guide to the Software Engineering Body of Knowledge Version 3.0, IEEE Computer Society, 2013. 355 p.
8. Голосовский М.С., Есев А.А., Богомолов А.В. Комплекс автоматизированной экспертизы технического уровня сложной системы. Свидетельство о государственной регистрации программы для ЭВМ RU №2014612330, опубл. 20.03.2014, бюллетень № 3. 1 с.
9. Фёдоров М.В., Калинин К.М., Богомолов А.В., Стецюк А.Н. Математическая модель автоматизированного контроля выполнения мероприятий в органах военного управления // Информационно-измерительные и управляющие системы. 2011. Т. 9. № 5. С. 46-54.
10. Богомолов А.В. Синтез выражения для расчёта индекса соответствия объекта альтернативным классам по результатам многомерной статистической классификации // Информационные технологии. 1999. № 12. С. 45.
11. Стасенко А. Тестирование изменений в программной системе на основе покрытия исходного кода // Информатика в науке и образовании / Под ред. В.Н.Касьянова. Новосибирск, 2012. С. 106-115.
12. Миронов С.В., Куликов Г.В. Анализ потенциальных возможностей методов тестирования программного обеспечения без использования исходных текстов // Программные системы и вычислительные методы. 2015. № 2. С. 150-162.
13. Голосовский М.С. Модель оценивания погрешностей прогнозирования сроков разработки программного обеспечения // Программные системы и вычислительные методы. 2015. № 3. С. 311-322.
14. Голосовский М.С. Модель жизненного цикла разработки программного обеспечения в рамках научно-исследовательских работ // Автоматизация. Современные технологии. 2014. № 1. С. 43-46
Размещено на Allbest.ru
...Подобные документы
Исследование объектно-ориентированного подхода к проектированию программного обеспечения будильника. Модель программного обеспечения. Взаимодействие между пользователями и системой. Диаграммы и генерация программного кода при помощи средств Rational Rose.
курсовая работа [355,8 K], добавлен 26.09.2014Технологии разработки программного обеспечения. Процедура постановки задачи, определения требований. Последовательность действий логической, разветвленной и циклической структуры. Терминология программирования. Этапы создания программного продукта.
презентация [793,8 K], добавлен 15.11.2010Использование моделирования в программной инженерии в процессе разработки программного обеспечения. Основные этапы процесса разработки программного обеспечения, их характеристика. Моделирование процессов, их определение фазами и видами деятельности.
реферат [2,2 M], добавлен 25.12.2017Требования к разработке программного обеспечения. Анализ существующих уровней и классификаций требований. Предложение расширенной классификации с дополнительными атрибутами. Стадии разработки программного обеспечения. Наблюдение за бизнесом заказчика.
дипломная работа [2,4 M], добавлен 24.08.2016Модель этапа пост-архитектуры. Предварительная оценка программного проекта на основе LOC-метрик. Расчет затрат на разработку ПО. Стоимость, длительность разработки проекта на основе модели этапа пост-архитектуры конструктивной модели стоимости СОСОМО II.
курсовая работа [89,9 K], добавлен 29.09.2009Анализ существующих методов и средств выявления требований. Стадии разработки программного обеспечения. Структуризация требований в базе знаний на основе расширенной классификации. Наблюдение за бизнесом заказчика. Моделирование бизнес-процессов компании.
диссертация [2,1 M], добавлен 21.02.2016Понятие программного обеспечения, вопросы его разработки и использования. Общая характеристика системного программного обеспечения и работа операционной системы. Специфика процесса управления разработкой программного обеспечения и его особенности.
курсовая работа [636,2 K], добавлен 23.08.2011Оценка финансовой, стратегической ценности и уровня рисков проекта. Классификация проектов: "свой" заказчик, продукт под заказ, тиражируемый продукт, аутсорсинг. Организация процесса разработки программного обеспечения, методологии его проектирования.
презентация [82,8 K], добавлен 07.12.2013Понятие и ключевое отличие распределенной разработки программного обеспечения, его достоинства и недостатки. Концептуальное решение и выбор типа разработки. Особенности программного обеспечения с открытым исходным кодом. Идея и развитие Open Source.
курсовая работа [97,7 K], добавлен 14.12.2012Схемы взаимодействия между заказчиком и разработчиком программного обеспечения. Качество программного обеспечения и определение основных критериев его оценка на современном этапе, особенности управления на стадиях жизненного цикла, анализ достаточности.
презентация [114,7 K], добавлен 14.08.2013Суть и описание проекта (резюме бизнес-плана). Классификация программного обеспечения для управления проектами. Функции программного обеспечения для календарного планирования. Календарное планирование. Управление затратами.
курсовая работа [192,2 K], добавлен 18.06.2007Реализация задачи использования методики SDLC (управление жизненным циклом разработки программного обеспечения) при внедрении реальной системы информационных технологий. Описание проекта внедрения системы автоматической регистрации участников выставок.
реферат [585,1 K], добавлен 10.09.2010Разбиение данных по таблицам и создание связей между таблицами. Нормализация и проектирование сценария работы базы данных. Выбор программного обеспечения. Требования к аппаратным и программным средствам для работы созданного программного продукта.
курсовая работа [30,2 K], добавлен 23.01.2011Изучение основных видов угроз программного обеспечения. Выявление наиболее эффективных средств и методов защиты программного обеспечения. Анализ их достоинств и недостатков. Описания особенностей лицензирования и патентования программного обеспечения.
курсовая работа [67,9 K], добавлен 29.05.2013Несоответствие процессов разработки программного обеспечения международным стандартам. Фазы, развитие вычислительной инфраструктуры. История развития компьютерных систем. Этапы разработки программ и их тестирование. Ошибки в программном обеспечении.
реферат [176,2 K], добавлен 27.08.2009Реализация программного средства "Действия над матрицами". Разработка кода программного продукта на основе готовой спецификации на уровне модуля. Использование инструментальных средств на этапе отладки программного модуля. Выбор стратегии тестирования.
отчет по практике [296,1 K], добавлен 19.04.2015Обоснование необходимости систем управления базами данных на предприятиях. Особенности разработки программного обеспечения по управлению базой данных, обеспечивающего просмотр, редактирование, вставку записей базы данных, формирование запросов и отчетов.
курсовая работа [1,5 M], добавлен 23.01.2010Этапы разработки технического задания. Спецификация программного обеспечения при структурном подходе. Дерево диаграмм, базовые понятия сетевой модели данных. Разработка пользовательского интерфейса. Разработка сценария диалога на основе экранных форм.
курсовая работа [2,0 M], добавлен 24.06.2012Проектирование информационного обеспечения, систем классификации и кодирования. Технология разработки программного обеспечения. Произведение расчётов по кредитам компании и организация межтабличных связей для автоматического заполнения необходимых ячеек.
курсовая работа [1,6 M], добавлен 13.11.2011Проект системы автоматизированного аудита программного обеспечения вычислительного центра ЛГТУ; функциональное назначение, методы и средства разработки концептуальных статических и динамических моделей пользовательского интерфейса; технические средства.
курсовая работа [4,2 M], добавлен 04.01.2012