Основы программирования

Основы технологии - Примеры элементов данных
Индекс материала
Основы технологии
Организация процесса конструирования
Классический жизненный цикл
Макетирование
Быстрая разработка приложений
Спиральная модель
Тяжеловесные и облегченные процессы
Модели качества процессов конструирования
Контрольные вопросы
Руководство программным проектом
Начало проекта
Трассировка и контроль
Достоинства размерно-ориентированных метрик:
Примеры элементов данных
Достоинства функционально-ориентированных метрик:
Конструктивная модель стоимости
Модель композиции приложения
Модель раннего этапа проектирования
Модель этапа постархитектуры
Факторы продукта:
ПРИМЕЧАНИЕ
Предварительная оценка программного проекта
Анализ чувствительности программного проекта
Сценарий понижения зарплаты
Сценарий уменьшения средств на завершение проекта
Выводы.
Классические методы анализа
Все страницы

В этой таблице 10 элементов данных: День, Хиты, % от Сумма хитов, Сеансы пользователя, Сумма хитов (по рабочим дням), % от Сумма хитов (по рабочим дням), Сумма сеансов пользователя (по рабочим дням), Сумма хитов (по выходным дням), % от Сумма хитов (по выходным дням), Сумма сеансов пользователя (по выходным дням). Отметим, что поля День, Хиты, % от Сумма хитов, Сеансы пользователя имеют рекурсивные данные, которые в расчете не учитываются.

 

Таблица 2.2. Пример для расчета элементов данных

Уровень активности дня недели

День

Хиты

% от Сумма хитов

Сеансы пользователя

Понедельник

1887

16,41

201

Вторник

1547

13,45

177

Среда

1975

17,17

195

Четверг

1591

13,83

191

Пятница

2209

19,21

200

Суббота

1286

11,18

121

Воскресенье

1004

8,73

111

Сумма по рабочим дням

9209

80,08

964

Сумма по выходным дням

2290

19,91

232

 

Примеры элементов данных для различных характеристик приведены в табл. 2.3, а табл. 2.4 содержит правила учета элементов данных из графического интерфейса пользователя (GUI).

Таблица 2.3. Примеры элементов данных

Информационная характеристика

Элементы данных

Внешние Вводы

Внешние Выводы

 

Внешние Запросы

Поля ввода данных, сообщения об ошибках, вычисляемые значения, кнопки

Поля данных в отчетах, вычисляемые значения, сообщения об ошибках, заголовки столбцов, которые читаются из внутреннего файла

Вводимые элементы: поле, используемое для поиска, щелчок мыши. Выводимые элементы — отображаемые на экране поля

Таблица 2.4. Правила учета элементов данных из графического интерфейса пользователя

 

Элемент данных

Правило учета

Группа радиокнопок

 

Группа флажков (переключателей)

Командные кнопки

 

 

 

Списки

Так как в группе пользователь выбирает только одну радиокнопку, все радиокнопки группы считаются одним элементом данных

Так как в группе пользователь может выбрать несколько флажков, каждый флажок считают элементом данных

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

Список может быть внешним запросом, но результат запроса может быть элементом данных внешнего ввода

Например, GUI для обслуживания клиентов может иметь поля Имя, Адрес, Город, Страна, Почтовый Индекс, Телефон, Email. Таким образом, имеется 7 полей или семь элементов данных. Восьмым элементом данных может быть командная кнопка (добавить, изменить, удалить). В этом случае каждый из внешних вводов Добавить, Изменить, Удалить будет состоять из 8 элементов данных (7 полей плюс командная кнопка).

Обычно одному экрану GUI соответствует несколько транзакций. Типичный экран включает несколько внешних запросов, сопровождающих внешний ввод.

Обсудим порядок учета сообщений. В приложении с GUI генерируются 3 типа сообщений: сообщения об ошибке, сообщения подтверждения и сообщения уведомления. Сообщения об ошибке (например, Требуется пароль) и сообщения подтверждения (например, Вы действительно хотите удалить клиента?) указывают, что произошла ошибка или что процесс может быть завершен. Эти сообщения не образуют самостоятельного процесса, они являются частью другого процесса, то есть считаются элементом данных соответствующей транзакции.

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

Данные для определения ранга и оценки сложности транзакций и файлов приведены в табл. 2.5-2.9 (числовая оценка указана в круглых скобках). Использовать их очень просто. Например, внешнему вводу, который ссылается на 2 файла и имеет 7 элементов данных, по табл. 2.5 назначается средний ранг и оценка сложности 4.

Таблица 2.5. Ранг и оценка сложности внешних вводов

 

Ссылки на файлы

Элементы данных

1-4

5-15

>15

0-1

2

>2

Низкий (3)

Низкий (3)

Средний (4)

Низкий (3)

Средний (4)

Высокий (6)

Средний (4)

Высокий (6)

Высокий (6)

Таблица 2.6. Ранг и оценка сложности внешних выводов

 

Ссылки на файлы

Элементы данных

1-4

5-19

>19

0-1

2-3

>3

Низкий (4)

Низкий (4)

Средний (5)

Низкий (4)

Средний (5)

Высокий (7)

Средний (5)

Высокий (7)

Высокий (7)

Таблица 2.7. Ранг и оценка сложности внешних запросов

 

Ссылки на файлы

Элементы данных

1-4

5-19

>19

0-1

2-3

>3

Низкий (3)

Низкий (3)

Средний (4)

Низкий (3)

Средний (4)

Высокий (6)

Средний (4)

Высокий (6)

Высокий (6)

Таблица 2.8. Ранг и оценка сложности внутренних логических файлов

 

Типы элементов-записей

Элементы данных

1-19

20-50

>50

1

2-5

>5

Низкий (7)

Низкий (7)

Средний (10)

Низкий (7)

Средний (10)

Высокий (15)

Средний (10)

Высокий (15)

Высокий (15)

Таблица 2.9. Ранг и оценка сложности внешних интерфейсных файлов

Типы элементов-записей

Элементы данных

1-19

20-50

>50

1

2-5

>5

Низкий (5)

Низкий (5)

Средний (7)

Низкий (5)

Средний (7)

Высокий (10)

Средний (7)

Высокий (10)

Высокий (10)

Отметим, что если во внешнем запросе ссылка на файл используется как на этапе ввода, так и на этапе вывода, она учитывается только один раз. Такое же правило распространяется и на элемент данных (однократный учет).

После сбора всей необходимой информации приступают к расчету метрики — количества функциональных указателей FP (Function Points). Автором этой метрики является А. Албрехт (1979) [7].

Исходные данные для расчета сводятся в табл. 2.10.

 

Таблица 2.10. Исходные данные для расчета FP-метрик

 

Имя характеристики

Ранг, сложность, количество

Низкий

Средний

Высокий

Итого

Внешние вводы

0x3 = __

0x4 = __

0x6 = __

= 0

Внешние выводы

0x4 = __

0x5 = __

0x7 = __

= 0

Внешние запросы

0х3 = __

0x4 = __

0x6 = __

= 0

Внутренние логические файлы

Внешние интерфейсные файлы

0x7 = __

0x5 = __

0x 10= __

0x7 = __

0x15 = __

0x10 = __

= 0

= 0

Общее количество

= 0

 

В таблицу заносится количественное значение характеристики каждого вида (по всем уровням сложности). Места подстановки значений отмечены прямоугольниками (прямоугольник играет роль метки-заполнителя). Количественные значения характеристик умножаются на числовые оценки сложности. Полученные в каждой строке значения суммируются, давая полное значение для данной характеристики. Эти полные значения затем суммируются по вертикали, формируя общее количество.

Количество функциональных указателей вычисляется по формуле

FP = Общее количество х (0,65+ 0,01 x), (2.1)

где Fi — коэффициенты регулировки сложности.

Каждый коэффициент может принимать следующие значения: 0 — нет влияния, 1 — случайное, 2 — небольшое, 3 — среднее, 4 — важное, 5 — основное.

Значения выбираются эмпирически в результате ответа на 14 вопросов, которые характеризуют системные параметры приложения (табл. 2.11).

Таблица 2.11. Определение системных параметров приложения

 

Системный параметр

Описание

1

Передачи данных

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

2

Распределенная обработка данных

Как обрабатываются распределенные данные и функции обработки?

3

Производительность

Нуждается ли пользователь в фиксации времени ответа или производительности?.

4

Распространенность используемой конфигурации

Насколько распространена текущая аппаратная платформа, на которой будет выполняться приложение?

5

Скорость транзакций

Как часто выполняются транзакции? (каждый день, каждую неделю, каждый месяц)

6

Оперативный ввод данных

Какой процент информации надо вводить в режиме онлайн?

7

Эффективность работы конечного пользователя

Приложение проектировалось для обеспечения эффективной работы конечного пользователя?

8

Оперативное обновление

Как много внутренних файлов обновляется в онлайновой транзакции?

9

Сложность обработки

Выполняет ли приложение интенсивную логическую или математическую обработку?

10

Повторная используемость

Приложение разрабатывалось для удовлетворения требований одного или многих пользователей?

11

Легкость инсталляции

Насколько трудны преобразование и инсталляция приложения?

12

Легкость эксплуатации

Насколько эффективны и/или автоматизированы процедуры запуска, резервирования и восстановления?

13

Разнообразные условия размещения

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

14

Простота изменений

Была ли спроектирована, разработана и поддержана в приложении простота изменений?

 

После вычисления FP на его основе формируются метрики производительности, качества и т. д.:

;

;

;

.

 

Область применения метода функциональных указателей — коммерческие информационные системы. Для продуктов с высокой алгоритмической сложностью используются метрики указателей свойств (Features Points). Они применимы к системному и инженерному ПО, ПО реального времени и встроенному ПО.

Для вычисления указателя свойств добавляется одна характеристика — количество алгоритмов. Алгоритм здесь определяется как ограниченная подпрограмма вычислений, которая включается в общую компьютерную программу. Примеры алгоритмов: обработка прерываний, инвертирование матрицы, расшифровка битовой строки. Для формирования указателя свойств составляется табл. 2.12.

Таблица 2.12. Исходные данные для расчета указателя свойств

Характеристика

Количество

Сложность

Итого

1

Вводы

0

х4

= 0

2

Выводы

0

х5

= 0

3

Запросы

0

х4

= 0

4

Логические файлы

0

х7

= 0

5

Интерфейсные файлы

0

х7

= 0

6

Количество алгоритмов

0

х3

= 0

Общее количество

= 0

 

После заполнения таблицы по формуле (2.1) вычисляется значение указателя свойств. Для сложных систем реального времени это значение на 25-30% больше значения, вычисляемого по таблице для количества функциональных указателей.



 
заказ такси в Москве