Студопедия — Выделение задач в подсистеме лифта
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Выделение задач в подсистеме лифта






Рассмотрим архитектуру задач Подсистемы Лифта для нераспределенного случая.

На диаграмме кооперации Выбор Этажа Назначения (см. рис.5) нужно обратить внимание на объект интерфейса устройства, который получает входную информацию от актера, и затем проследить цепочку взаимодействий. Объект Интерфейс Кнопки Лифта выделяется в самостоятельную задачу Интерфейс Кно­пок Лифта с помощью критерия асинхронного интерфейса устройства ввода. Применив инверсию задач, мы проектируем одну задачу, которая будет отвечать за все кнопки лифта, вместо того чтобы иметь по одной задаче на каждую кнопку. Задача Интерфейс Кнопок Лифта активизируется прерыванием, возникающим при нажатии любой кнопки. Затем она считывает входную информацию от кноп­ки и посылает запрос Диспетчеру Лифта, а сама тем временем готовится к при­ходу следующего прерывания. Диспетчер Лифта, который является объектом-координатором, получает сообщения от Интерфейса Кнопок Лифта в данном прецеденте и от Планировщика в прецеденте Вызов Лифта (см. рис.6). Он выделяется в координирующую задачу, активизируемую приходом сообщения Запрос Планировщика или Запрос Лифта. Состояние и План Движения Лиф­та - это пассивный объект абстрагирования данных, у которого нет своего потока управления.

Рассмотрим далее прецедент Остановка Лифта на Этаже на рис.7. Объект Интерфейс Датчика Прибытия становится асинхронной задачей интерфейса устройства ввода - Интерфейс Датчиков Прибытия - по тем же причинам, что и в случае с задачей Интерфейс Кнопок Лифта. Он посылает номер этажа объек­ту Управление Лифтом, о котором речь пойдет ниже.

Разберем диаграмму состояний Управление Лифтом на рис.13. Здесь есть зависящий от состояния управляющий объект, который исполняет диаграмму состояний. На этапе анализа все аспекты физического объекта «лифт», связанные с управлением, были отображены на управляющий объект Управление Лифтом (см. рис.7 и 9). Если имеется несколько лифтов, то управляются они неза­висимо, так что в модели присутствует по одному такому объекту для каждого лифта. В ходе разбиения на задачи каждый объект Управление Лифтом отобра­жается на отдельную задачу Контроллер Лифта. Любая задача исполняет диа­грамму состояний для своего лифта, как показано на рис.13.

Задача Контроллер Лифта взаимодействует с несколькими объектами интер­фейса устройств вывода, которые работают непосредственно с внешней средой, в частности с мотором, дверью и лампочками лифта. Все эти устройства пассив­ны (то есть не генерируют прерываний), следовательно, асинхронные задачи не нужны. Каждый запрос на вывод информации выполняется по требованию, по­этому не нужны и периодические задачи. Кроме того, вызывающая задача обяза­на дожидаться завершения вывода, поэтому нет необходимости и в пассивной задаче вывода. Таким образом, объект вывода на устройство не стоит выделять в самостоятельную задачу, он объединяется с задачей Контроллер Лифта в соот­ветствии с критерием группировки задач. Например, если Контроллер Лифта инициирует действие Закрыть Дверь, он ждет ответа Дверь Закрыта, посколь­ку лифт не может начать движение, пока дверь не закроется.

Рассмотрим выполнение задачи Контроллер Лифта подробнее. Она полу­чает сообщение Приближается к Этажу, находясь в состоянии Лифт Едет (см. рис.8). Затем Контроллер Лифта посылает сообщение объекту Состоя­ние и План Движения Лифта, требуя Проверить Этот Этаж. Состояние изменя­ется только в том случае, если в соответствии с планом лифт должен остановить­ся на данном этаже. При этом объект Состояние и План Движения Лифта отправляет сообщение Приближается к Нужному Этажу, которое переводит Кон­троллер Лифта в состояние Лифт Останавливается и инициирует действие Стоп. Объекту Интерфейс Мотора передается сообщение Стоп (см. рис.7). Контроллер Лифта выходит из этого состояния только при получении ответа Лифт Остановился от Интерфейса Мотора. Таким образом, Контроллер Лиф­та и Интерфейс Мотора неспособны работать одновременно. Аналогичный ана­лиз показывает, что одновременно не могут исполняться также объекты Контрол­лер Лифта и Интерфейс Двери. Следовательно, на основе критерия группировки задач допустимо объединить объекты Интерфейс Мотора и Интерфейс Двери с задачей Контроллер Лифта.

Диспетчер Лифта (всего один экземпляр в нераспределенном решении) ре­ализуется асинхронно по отношению к задаче Контроллер Лифта, так как запрос к лифту может прийти в любой момент. Поэтому Диспетчер Лифта вычленяет­ся в отдельную задачу-координатор, которая активизируется асинхронно по со­бытию Запрос Лифта или Запрос Планировщика и обычно исполняется неза­висимо от задачи Контроллер Лифта. Единственное взаимодействие между двумя задачами возникает, когда лифт находится в состоянии Стоит и поступа­ет новый запрос. В этом случае Диспетчер Лифта активизирует задачу Кон­троллер Лифта.

Итак, в нераспределенной системе управления лифтами Подсистема Лифта разбивается на четыре задачи: Интерфейс Кнопок Лифта, Интерфейс Датчи­ков Прибытия, Диспетчер Лифта и Контроллер Лифта. Имеется по одному экземпляру первых трех задач и столько экземпляров четвертой задачи, сколько есть лифтов. Все экземпляры задачи Контроллер Лифта идентичны и исполня­ют собственную копию диаграммы состояний Управление Лифтом. Предвари­тельная архитектура задач изображена на начальной диаграмме параллельной кооперации (рис.19).

9.2. Выделение задач в подсистеме этажа

Перейдем к архитектуре задач в Подсистеме Этажа, изображенной на рис.17. Объект Интерфейс Кнопки Этажа выделяется в самостоятельную задачу Интерфейс Кнопок Этажа на основе критерия асинхронного интерфейса устройства ввода и критерия группировки задач. В случае нераспределенного ре­шения задача Интерфейс Кнопок Этажа отвечает за обработку ввода от всех кно­пок этажа. Она активизируется прерыванием, обрабатывает его и посылает За­прос на Обслуживание объекту Планировщик, после чего готова к приходу следующего прерывания.

Лампочки этажа и направления - это пассивные устройства вывода. С ними взаимодействуют объекты Интерфейс Лампочки Этажа и Интерфейс Лампоч­ки Направления. Бывает так, что различные экземпляры задачи Контроллер Лифта одновременно посылают запросы лампочкам. В таком случае необходимо иметь для каждого устройства задачу-монитор ресурса, которая сможет сериализовать обработку параллельных запросов. Итак, выявилась потребность в задачах Монитор Лампочек Этажа и Монитор Лампочек Направления. Все объекты Интерфейс Лампочки Этажа отображаются на задачу Монитор Лампочек Эта­жа. Все объекты Интерфейс Лампочки Направления отображаются на задачу Монитор Лампочек Направления. Задачи, из которых состоит Подсистема Эта­жа в нераспределенной системе управления лифтами, показаны на рис.19. Вмес­то этого допустимо завести единственный монитор ресурсов для лампочек этажа и направления, однако первоначальное решение обладает большей гибкостью.

Выделение задач в подсистеме планировщика

В случае нераспределенного решения Планировщик — это подсистема, кото­рая состоит из одного объекта-координатора, выделенного в задачу. Задача Пла­нировщик активизируется по запросу, в частности после получения Запроса на Обслуживание, и выбирает лифт, наиболее подходящий для его удовлетворения.

Поскольку речь идет о нераспределенном решении, очевидно, что Планиров­щик может напрямую читать Состояние и План Движения Лифта. Следователь­но, различные экземпляры задачи Контроллер Лифта не обязаны посылать Пла­нировщику сообщения Прибыл и Отбыл. Архитектура задач для нераспределенного случая представлена на рис.19.







Дата добавления: 2015-09-19; просмотров: 442. Нарушение авторских прав; Мы поможем в написании вашей работы!



Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...

Картограммы и картодиаграммы Картограммы и картодиаграммы применяются для изображения географической характеристики изучаемых явлений...

Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...

Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Хронометражно-табличная методика определения суточного расхода энергии студента Цель: познакомиться с хронометражно-табличным методом опреде­ления суточного расхода энергии...

ОЧАГОВЫЕ ТЕНИ В ЛЕГКОМ Очаговыми легочными инфильтратами проявляют себя различные по этиологии заболевания, в основе которых лежит бронхо-нодулярный процесс, который при рентгенологическом исследовании дает очагового характера тень, размерами не более 1 см в диаметре...

Примеры решения типовых задач. Пример 1.Степень диссоциации уксусной кислоты в 0,1 М растворе равна 1,32∙10-2   Пример 1.Степень диссоциации уксусной кислоты в 0,1 М растворе равна 1,32∙10-2. Найдите константу диссоциации кислоты и значение рК. Решение. Подставим данные задачи в уравнение закона разбавления К = a2См/(1 –a) =...

Почему важны муниципальные выборы? Туристическая фирма оставляет за собой право, в случае причин непреодолимого характера, вносить некоторые изменения в программу тура без уменьшения общего объема и качества услуг, в том числе предоставлять замену отеля на равнозначный...

Тема 2: Анатомо-топографическое строение полостей зубов верхней и нижней челюстей. Полость зуба — это сложная система разветвлений, имеющая разнообразную конфигурацию...

Виды и жанры театрализованных представлений   Проживание бронируется и оплачивается слушателями самостоятельно...

Studopedia.info - Студопедия - 2014-2024 год . (0.012 сек.) русская версия | украинская версия