Перейти на главную страницу
Если рассмотреть также и случай различных вероятностей для каждого набора данных, то оценка (13.5) изменится следующим образом.
что позволяет записать следующее выражение для вероятности успешного прогона:
Тогда вероятность успешного выполнения m прогонов, при условии, что набор входных данных для каждого прогона выбирается независимо и в соответствии с распределением, заданным формулой (14.1), будет равна:
Модель (14.2) позволяет дать следующее определение надежности ПО: надежность ПО – это вероятность его m безотказных прогонов.
Следующим шагом в развитии этой модели будет признать, что, как правило, предположение о том, что выбор входных данных происходит независимо для каждого прогона, на практике неверно. Исключение могут составлять только последовательности прогонов с постепенным увеличением значения входной переменной, или с использованием определенной последовательности процедур (как в системах реального времени).
Принимая во внимание эти обстоятельства, необходимо переопределить распределение (14.1) в терминах вероятностей pij выбора набора данных Ei для j-того прогона программы из некоторой последовательности прогонов. Тогда вероятность отказа на j-том прогоне будет
Соответственно, вероятность безотказного выполнения m прогонов можно оценить следующим выражением:
Это выражение можно записать в виде
и если Qi<<1, тогда
Обозначим - время выполнения j-того прогона программы, и
- суммарное время, потраченное на выполнение j прогонов, и будем использовать следующее выражение для функции риска
тогда мы имеем
Если , то сумма превращается в интеграл, и формула (14.3) превращается в фундаментальное отношение (13.2):
основного правила надежности.
При использовании модели Нельсона на практике встречаются две категории трудностей. Первая связана с нахождением - параметров распределения входных данных. Вторая связана с необходимостью выполнения значительного количества прогонов программы (десятки и сотни тысяч) для получения приемлемой точности для соответствующих оценок вероятности (отказа или безотказной работы). Последняя проблема решается применением хорошо известного в статистике метода последовательного анализа, предложенного Вальдом.
Модель, разработанная специалистами компании IBM.
В течение сопровождения в ПО вносится значительное количество новых ошибок в каждой новой версии, вместе с доработками, изменениями и исправлениями, что требует исправлений также и в следующей версии. Разработчики известной компании IBM попытались предсказать количество подобных исправлений от версии к версии, основываясь на большом количестве экспериментальных данных, собранных в ходе сопровождения операционной системы OS/360. Модель, предложенная специалистами IBM, основана на наблюдении за ходом разработки этого программного продукта, и на гипотезе о статистической стабильности зависимости между параметрами, характеризующими различные версии системы. В качестве основной единицы измерения сложности ПО был выбран программный модуль. Были стандартизованы правила создания модулей.
Объем i-той версии выражается количеством модулей Mi, входящих в данную версию. При выпуске i –той версии системы изменялся параметра СИМi (количества старых исправляемых модулей), и добавление некоторого числа новых модулей НМi , так что
При доработке i-й версии (в период подготовки (i+1)-й) происходит дальнейшая коррекция модулей. Эти исправленные модули делятся на две группы: первая группа характеризуется параметром MИMi – многократно изменяемые модули (10 или более исправлений на модуль), и вторая группа – ИMi, модули с числом исправлений меньше 10. Эта классификация необходима для упрощения вычислений, а также из-за того факта, что небольшое число исправлений характерно для большинства модулей.
Также необходимо отметить, что группа ИM не требуют особых средств отладки, в то время как группа MИM может потребовать некоторых дополнительных усилий при отладке.
В ходе анализа истории сопровождения OS/360 фирмы IBM было установлено, что существует значительная зависимость между параметрами, характеризующими масштабы изменений и (соответственно) уровень содержания ошибок (в группах ИM и MCM), и параметрами, характеризующими сложность и объем следующей версии (СИМ, НМ). В применении к OS/VS1 это соотношение выглядело следующим образом.
где ИЗМi - общее количество исправлений, внесенное в модули (или, другими словами, общее количество ожидаемых ошибок), а коэффициенты 23 и 2 – среднее количество исправлений на модуль для групп MИM и ИM, соответственно.
Прогноз основывается на запланированном количестве исправлений в старых модулях и на количестве добавляемых модулей (СИМi, НМi) для реализации новых требуемых функций ПО. Если количество действительно внесенных исправлений меньше, чем предсказанное количество исправлений, то можно сделать вывод, что в ПО существует еще некое количество необнаруженных ошибок. Модель фирмы IBM позволяет сделать следующие выводы:
Идея заключается в том, что если мы будем включать в программы средства по самостоятельному восстановлению, они будут корректно работать даже после сбоев. Хотим сводить любые аномалии, возникающие в процессе работы программы, к приемлемому уровню. Решение задачи – использование избыточности.
Так как в программах нет необходимости “ремонта” компонент с участием человека то можно добиваться высокой автоматизации программного восстановления Главной задачей становится восстановление за время, не превышающее порогового значения между сбоем и отказом Автоматизируя процесс и сокращая время восстановления можно преобразовать отказы в сбои и тем самым улучшить показатели надежности функционирования системы
Комплексы программ в процессе функционирования находятся под воздействием шумов-возмущений различных типов Для снижения их влияния на результаты следует применять фильтры позволяющие обнаруживать искажения устранять или уменьшать их вредные последствия Разнообразие видов искажений приводит к необходимости построения систем фильтров каждый из которых способен селектировать некоторые виды искажений
Для реализации фильтров обеспечивающих повышение надежности функционирования программ и защиту вычислительного процесса и информации программно-алгоритмическими методами используется программная информационная и временная избыточность Основная задача ввода избыточности состоит в исключении возможности аварийных последствий от возмущений соответствующих отказу системы Любые аномалии при исполнении программ необходимо сводить до уровня сбоя путем быстрого восстановления
Надежность функционирования комплексов программ зависит от многих факторов которые можно объединить в три группы (табл. 12)
Факторы непосредственно определяющие надежность программ |
Методы проектирования корректных программ |
Методы контроля и обеспечения надежности программ |
Особенности внешних абонентов и пользователей результатов программ |
Структурное проектирование программ и данных |
Методы использования избыточности |
Требования к показателям надежности |
Структурное проектирование программных модулей |
Временной Информационной Программной
|
Инерционность внешних абонентов |
Структурное проектирование взаимодействия модулей |
Методы контроля программ данных и вычислительного процесса |
Необходимое время отклика на входные данные |
Структурирование данных |
Предпусковой контроль Оперативный контроль |
Искажения исходных данных |
Тестирование программ |
Методы программного восстановления |
Искажения данных поступающих от человека |
Детерминированное тестирование |
Восстановление текстов программ Исправление данных |
Искажения данных поступающих по телекодовым каналам связи |
Статистическое тестирование |
Корректировка вычислительного процесса |
Искажения данных в процессе накопления и хранения в ЭВМ |
Динамическое тестирование и контроль пропускной способности в реальном времени |
Методы испытаний на надежность Форсированные испытания |
Ошибки в программах и их проявление |
|
Испытания в нормальных условиях эксплуатации |
Статистические характеристики ошибок и искажений |
|
Расчетно-экспериментальные методы определения надежности |
Программ |
|
Методы обеспечения надежности при сопровождении |
массивов данных |
|
Обеспечение сохранности программ эталонных версий |
Вычислительного процесса |
|
Обеспечение корректности внесения изменений и развития версий |
Ситуации проявления ошибок при исполнении программ можно разделить на три группы
В теории надежности разработан ряд методов позволяющих определить характеристики надежности сложных систем Эти методы можно свести к трем основным группам
Особым видом форсированных испытаний является проверка эффективности средств контроля и восстановления программ данных и вычислительного процесса Для этого имитируются запланированные экстремальные условия функционирования программ при которых в наибольшей степени стимулируется работа испытываемого средства программного контроля или восстановления
Назначение метрического анализа программ. Понятие метрики. Типы метрик и шкал. Понятие критерия оценки качества. Функциональные и конструктивные критерии оценки качества программ
15 12 2014
9 стр.
Дать первые основные понятия программного обеспечения,познакомить с историей развития, классификацией программного обеспечения
11 09 2014
1 стр.
Целью изучения дисциплины является получение студентами теоретических знаний по основам обеспечения качества программного обеспечения (ПО), методам его измерения и оценки, повышени
15 12 2014
1 стр.
Целью Конкурса является повышение качества содержания программного обеспечения по организации детского отдыха и оздоровления в летний каникулярный период, а также в периоды между л
26 09 2014
1 стр.
Сведения о лекарственных средствах, направленных на дополнительные испытания качества по результатам выборочной экспертизы
08 10 2014
1 стр.
В качестве инструментального средства разработчика программного обеспечения для digital signal processor (dsp), фирма ti предлагает integrated development environment
01 10 2014
1 стр.
Сведения о лекарственных средствах, не соответствующих требованиям нормативной документации, по результатам выборочной экспертизы и требующих подтверждения качества в испытательной
08 10 2014
1 стр.
Почему это происходит? Во многих случаях потому, что спор идет именно на тему «что лучше», хотя правильней было бы совместно с оппонентом искать те области, в которых выигрывает та
15 10 2014
1 стр.