Тип требования в системной инженерии
В системной инженерии и инженерии требований нефункциональное требование ( NFR ) — это требование , которое определяет критерии, которые могут быть использованы для оценки работы системы, а не конкретные поведения. Они противопоставляются функциональным требованиям , которые определяют конкретное поведение или функции. План реализации функциональных требований подробно описан в проекте системы . План реализации нефункциональных требований подробно описан в архитектуре системы , поскольку они обычно являются архитектурно значимыми требованиями . [1]
В архитектуре программного обеспечения нефункциональные требования известны как «архитектурные характеристики». Обратите внимание, что синхронная связь между компонентами архитектуры программного обеспечения запутывает их, и они должны иметь одни и те же архитектурные характеристики. [2]
Определение
В широком смысле функциональные требования определяют, что система должна делать , а нефункциональные требования определяют, как система должна быть . Функциональные требования обычно имеют форму «система должна делать <требование>», отдельное действие или часть системы, возможно, явно в смысле математической функции , черного ящика , описания ввода, вывода, процесса и управления функциональной модели или модели IPO . Напротив, нефункциональные требования имеют форму «система должна быть <требование>», общее свойство системы в целом или конкретного аспекта, а не конкретная функция. Общие свойства системы обычно отмечают разницу между тем, был ли проект разработки успешным или неудачным.
Нефункциональные требования часто называют « атрибутами качества » системы. Другие термины для нефункциональных требований — «качества», «цели качества», «требования к качеству обслуживания», «ограничения», «неповеденческие требования» [3] или «технические требования». [4] Неформально их иногда называют «илитиями» от таких атрибутов, как стабильность и переносимость. Качества — то есть нефункциональные требования — можно разделить на две основные категории:
- Качества исполнения, такие как безопасность, надежность и удобство использования, которые можно наблюдать в процессе эксплуатации (во время выполнения).
- Качества эволюции, такие как тестируемость , поддерживаемость, расширяемость и масштабируемость, воплощенные в статической структуре системы. [5] [6]
Важно указать нефункциональные требования конкретным и измеримым образом. [7] [8]
Примеры
Система может быть обязана предоставить пользователю отображение количества записей в базе данных. Это функциональное требование. Насколько актуальным должно быть это число, является нефункциональным требованием. Если число должно обновляться в режиме реального времени , системные архитекторы должны гарантировать, что система способна отображать количество записей в течение приемлемо короткого интервала изменения количества записей.
Достаточная пропускная способность сети может быть нефункциональным требованием системы. Другие примеры включают:
- Доступность
- Приспособляемость
- Проверяемость и контроль
- Доступность (см. соглашение об уровне обслуживания )
- Резервное копирование
- Время загрузки
- Мощность , текущая и прогнозируемая
- Сертификация
- Согласие
- Управление конфигурацией
- Соответствие
- Стоимость, первоначальная и стоимость жизненного цикла
- Целостность данных
- Хранение данных
- Зависимость от других сторон
- Развертывание
- Среда разработки
- Восстановление после аварии
- Документация
- Прочность
- Эффективность (потребление ресурсов при заданной нагрузке)
- Эффективность (результирующая производительность по отношению к затраченным усилиям)
- Эластичность
- Эмоциональные факторы (например, веселье, увлекательность или наличие фактора «Ух ты!»)
- Охрана окружающей среды
- Условное депонирование
- Этика
- Эксплуатируемость
- Расширяемость (добавление функций и перенос настроек при следующем обновлении основной версии)
- Управление отказами
- Отказоустойчивость (например, мониторинг, измерение и управление операционной системой)
- Гибкость (например, для учета будущих изменений требований)
- Уменьшение размера — уменьшение размера исполняемых файлов.
- Интегрируемость (например, способность интегрировать компоненты)
- Интернационализация и локализация
- Взаимодействие
- Правовые и лицензионные вопросы или возможность предотвращения нарушения патентных прав
- Ремонтопригодность (например, среднее время ремонта – MTTR)
- Управление
- Оптимизация памяти
- Модифицируемость
- Топология сети
- С открытым исходным кодом
- Работоспособность
- Производительность /время отклика ( инжиниринг производительности )
- Совместимость платформ
- Конфиденциальность (соблюдение законов о конфиденциальности )
- Портативность
- Качество (например, обнаруженные неисправности, устраненные неисправности, эффективность устранения неисправностей )
- Удобочитаемость
- Надежность (например, среднее время между отказами/до отказа – MTBF/MTTF)
- Отчетность
- Устойчивость
- Ограничения ресурсов (скорость процессора, память, дисковое пространство, пропускная способность сети и т. д.)
- Время отклика
- Возможность повторного использования
- Надежность
- Безопасность или фактор безопасности
- Масштабируемость (горизонтальная, вертикальная)
- Безопасность (кибер и физическая)
- Программное обеспечение, инструменты, стандарты и т.д. Совместимость
- Стабильность
- Поддерживаемость
- Тестируемость
- Пропускная способность
- Прозрачность
- Удобство использования (человеческий фактор) целевым сообществом пользователей
- Тестирование объема
Смотрите также
Ссылки
- ^ Чен, Ляньпин; Али Бабар, Мухаммад; Нусейбех, Башар (2013). «Характеристика архитектурно значимых требований». IEEE Software . 30 (2): 38–45. doi :10.1109/MS.2012.174. hdl : 10344/3061 . S2CID 17399565.
- ^ Ричардс, Марк; Форд, Нил (2020). Основы архитектуры программного обеспечения: инженерный подход . O'Reilly Media, Incorporated. ISBN 978-1492043454.
- ^ Стеллман, Эндрю; Грин, Дженнифер (2005). Управление проектами прикладного программного обеспечения. O'Reilly Media . стр. 113. ISBN 978-0-596-00948-9. Архивировано из оригинала 2015-02-09.
- ^ Эмблер, Скотт. «Технические (нефункциональные) требования: введение в Agile». Agile Modeling . Ambysoft Inc . Получено 5 октября 2018 г. .
- ^ Вигерс, Карл; Битти, Джой (2013). Требования к программному обеспечению, третье издание . Microsoft Press. ISBN 978-0-7356-7966-5.
- ^ Янг, Ральф Р. (2001). Эффективные требования практики . Addison-Wesley. ISBN 978-0-201-70912-4.
- ^ Циммерманн, Олаф; Стокер, Мирко (2021). Репозиторий практики проектирования. LeanPub.
- ^ Глинц, Мартин (2008). «Подход к требованиям к качеству, основанный на оценке рисков и ценностно-ориентированный» (PDF) . IEEE Software . 25 (2): 34–41. doi :10.1109/MS.2008.31. S2CID 19015424.
Внешние ссылки
- Petter LH Eide (2005). «Квантификация и прослеживаемость требований». CiteSeerX 10.1.1.95.6464 .
- Dalbey, John. "Нефункциональные требования". Csc.calpoly.edu . Получено 3 октября 2017 г. .
- "Моделирование нефункциональных аспектов в сервисно-ориентированной архитектуре" (PDF) . Cs.umb.edu . Архивировано из оригинала (PDF) 24 июля 2011 г. . Получено 3 октября 2017 г. .
- «Нефункциональные требования: действительно ли помогают пользовательские истории?». Methodsandtools.com . Получено 3 октября 2017 г. .
- «Нефункциональные требования здесь — CISQ — Консорциум по качеству ИТ-ПО». it-cisq.org . Получено 3 октября 2017 г. .
- ««Соответствуют ли архитектуры программного обеспечения дополнительным функциональным или нефункциональным требованиям?»». 19 ноября 2020 г.