1. Выявление классов и объектов.

Цель: Выявления классов и объектов состоит в том, чтобы найти границы предметной области. Кроме того, эта деятельность является первым шагом в продумывании объектно-ориентированной декомпозиции разрабатываемой системы. Этот шаг в анализе применяется тогда, когда обнаруживаются абстракции, составляющие словарь предметной области и, тем самым, ограничивая задачу, решая, что важно, а что - нет. Такие действия необходимы при проектировании, когда мы изобретаем новые абстракции, которые являются составными частями решения. Переходя к программной реализации, мы применяем процедуру выявления, чтобы изобрести более простые абстракции, из которых строятся более сложные, и обнаружить общие черты существующих абстракций, дабы упростить архитектуру системы.

Результаты: Главным результатом этого шага является обновляющийся по мере развития проекта словарь данных.

2. Идентификация семантики классов и объектов.

Цель: Определить поведение и атрибуты каждой абстракции, выявленной на предыдущем шаге. При этом мы уточняем намеченные абстракции, продуманно и измеримо распределяя между ними обязанности.

Результаты: Во-первых, уточняется словарь данных, с помощью которого мы изначально присвоили обязанности абстракциям. В ходе проектирования можно выработать спецификации к каждой абстракции, перечисляя имена операций в протоколе каждого класса. Затем, необходимо выразить интерфейсы этих классов на языке реализации. Например, для C++ это означает создание. h-файлов, в Ada - спецификаций пакетов, в CLOS - обобщенных функций для каждого класса, в Smalltalk - это объявление, но не реализация методов каждого класса. В добавление к этим, по сути тактическим решениям, мы составляем диаграммы объектов и диаграммы взаимодействий, передающие семантику сценариев, создаваемых в ходе макропроцесса. Эти диаграммы формально отражают раскадровку каждого сценария и, таким образом, описывают явное распределение обязанностей среди взаимодействующих объектов. На этом шаге впервые появляются конечные автоматы для представления некоторых абстракций.

3. Выявление связей между классами и объектами.

Цель: Уточнить границы каждой обнаруженной ранее в микропроцессе абстракции и опознать все сущности, с которыми она взаимодействует. Это действие формализует концептуальное и физическое размежевание между абстракциями, начатое на предыдущем шаге.

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

4. Реализация классов и объектов.

Цель: На этапе анализа реализация классов и объектов нужна, чтобы довести существующие абстракции до уровня, достаточного для обнаружения новых классов и объектов на следующем уровне абстракции; они сами будут в дальнейшем поданы на новую итерацию микропроцесса. Этот шаг намеренно выполняется позже всех, так как микропроцесс концентрирует внимание на поведении и откладывает насколько возможно решения о представлении. Такая стратегия оберегает разработчика от недозрелых решений, которые могут не оставить шансов на облегчение и упрощение архитектуры, и оставляет свободу выбора реализации (например, из соображений эффективности), гарантируя сохранение существующей архитектуры.

Результаты: Чтобы раскрыть связи между логическим и физическим в нашей реализации системы, вводятся диаграммы модулей, которые можно затем использовать, чтобы наглядно показать отображение архитектуры в ее программную реализацию. Далее можно применить специфические инструментальные средства (например CASE-средства), которые позволяют либо генерировать код из диаграмм, либо восстанавливать диаграммы по реализации. В этот шаг входит и обновление словаря данных, включая новые классы и объекты, которые были выявлены или изобретены при реализации существующих абстракций. Эти новые абстракции являются частью исходной информации для следующего цикла микропроцесса.

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

4.6 Эволюция

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

добавление нового класса или нового взаимодействия между классами;

изменение реализации класса;

изменение представления класса;

реорганизация структуры классов;

изменение интерфейса класса.

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

4.7 Сопровождение

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

Типичный порядок действий на этом этапе таков:

упорядочивают по приоритетам предложения о крупных изменениях и сообщения об ошибках, связанных с системными проблемами;

составляют список этих изменений и принять их за функциональные точки в дальнейшей эволюции;

если позволяют ресурсы, планируют в следующем релизе менее интенсивные, более локализованные улучшения;

приступают к разработке следующего эволюционного релиза программы.

4.8 Заключение

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

Необходимо подчеркнуть, что каждый проект уникален, и, следовательно, разработчик, если он придерживается объектно-ориентированной методикой разработки, сам должен поддерживать баланс между неформальностью микропроцесса и формальностью макропроцесса, описанных выше.


5. Методика отладки и результаты работы программы

 

5.1 Особенности тестирования программных продуктов

Программы как объекты тестирования имеют ряд особенностей, которые отличают процесс тестирования от традиционного, применяемого для проверки аппаратуры и других технических изделий. С этой позиции основными особенностями программ являются:

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

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

невысокая степень формализации критериев качества процесса тестирования и достигаемого при этом качества программного обеспечения как объекта тестирования;

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

Неоднократно экспериментально установлено, что в любом сложном программном обеспечении в процессе эксплуатации обнаруживаются ошибки, даже если проведено самое тщательное тестирование. Тем самым объективно утверждается, что невозможно формализовать и обеспечить абсолютную полноту всех эталонных значений, а также провести всеобъемлющее исчерпывающее тестирование и гарантированно устранить все ошибки в сложных программных продуктах. Поэтому тестирование проводится в объемах, минимально необходимых для проверки программ в некоторых ограниченных пределах изменения параметров и условий функционирования. Ограниченность ресурсов тестирования привела к необходимости тщательного упорядочения методов и конкретных значений параметров с целью получения при тестировании наибольшей глубины проверок программ. Анализ многих проектов показывает, что до начала тестирования число ошибок в сложных программах составляет порядка 1-2% от общего числа объектных команд в программе, т.е. в программном обеспечении объемом 100 тысяч команд в процессе тестирования обычно выявляется 1-2 тысячи ошибок. При тщательном системном проектировании и программировании на языках высокого уровня начальное число ошибок в несколько раз меньше. Таким образом самое тщательное тестирование сложных программных комплексов позволяет получить программы с вероятностью ошибки в каждой команде порядка 10-4-10-5, т.е. несколько ошибок может остаться не выявленными.

 

5.2 Типичный процесс тестирования программного обеспечения

Процесс тестирования программ обычно включает:

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

статическое тестирование текстов разработанных программ и данных на выполнение всех заданных правил построения и описания без исполнения объектного кода;

тестирование программы с её исполнением в объектном коде и с разными уровнями детализации: детерминированное, стохастическое, и тестирование в реальном масштабе времени;

диагностику и локализацию причин отклонения результатов тестирования от заданных эталонных значений и правил;

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

реализацию корректировки программы, обеспечивающую соответствие программы заданному эталону.

Статическое тестирование является наиболее формализованным и автоматизируемым методом проверки корректности программ. В качестве эталонов применяются правила структурного построения программных модулей и обработки данных, конкретизированные для проекта в целом. Кроме того, могут использоваться некоторые частные правила обработки данных, зафиксированные в спецификациях на отдельные компоненты программ. Проверка степени выполнения этих правил проводится без исполнения объектного кода программы путём формального анализа текста программы на языке программирования. Операторы и операнды текста программ при этом анализируются в символьном виде, поэтому такой метод называют также символическим тестированием. Развитие и углубление символического тестирования может доводиться до уровня формальной верификации программы на соответствие её текста детальной спецификации совокупности утверждений, полностью определяющей связи между входными и выходными данными этой программы.

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

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

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

5.3 Особенности задачи в приложении к тестированию программ

 

5.3.1 Особенности среды программирования

Среда программирования Microsoft Visual Studio 6.0 и язык программирования в ней Microsoft Visual C++ имеют ряд особенностей, влияющих на тестирование программ:

Visual C++ является языком программирования высокого уровня, что сильно увеличивает значимость статического (символьного) тестирования;

среда программирования разработана для поддержки высокой степени использования стандартных поставляемых в модулях процедур. Эти модули являются уже оттестированными и испытанными. Считается, что вызываемые процедуры обладают высокой надёжностью и не содержат ошибок;

Visual Studio имеет развитую систему автоматической символьной проверки. Она на этапе написания программы следит за корректностью вводимого текста и обнаруживает все синтаксические ошибки;

в комплект Visual Studio входит множество утилит для отладки, значительно облегчающих процесс тестирования программного обеспечения;

большую часть структуры программы в Visual C++ with Microsoft Foundation Classes занимают стандартные, автоматически создаваемые объекты, управляющие работой программы в ответ на действия пользователя. Поэтому ошибки в основном содержатся в алгоритмах процедур, написанных программистом.

 

5.3.2 Основные факторы, влияющие на надежность разрабатываемой системы

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

корректность структуры программы;

корректность обработки данных;

устойчивость к ошибочному вводу данных пользователем.

Устойчивость к ошибочному вводу данных пользователем осуществлена при помощи стандартных программных средств, реализованных в библиотеке MFC. Вводятся следующие ограничения на поля данных:

недопустимо непустое значение поля данных;

недопустимо значение поля данных, не входящее в заданный интервал допустимых значений.

В случае ввода неверных данных пользователю выводится на экран соответствующее сообщение.

 

5.3.2.1 Контроль структуры программы

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

Суть критерия состоит в выборе и анализе базовых маршрутов в программе, формируемых и оцениваемых на основе определения цикломатического числа исходного графа, определяющего структуру программы или ее фрагмента. Критерий наиболее широко применяется для оценки сложности и корректности тестирования программных модулей. Для определения цикломатического числа Z исходного графа фрагмента программы используется полное число его вершин Nп, связывающих их дуг Y и связных компонент L: Z = Y - Nп + L. Вычисление цикломатического числа осуществляется по величинам, определяемым по максимально связному графу, который получается из исходного путем замыкания дуги из конечной вершины в начальную. В результате в максимально связном графе появляются маршруты между любыми двумя вершинами. При этом предполагается, что исходный граф корректен, т.е. не содержит "висячих" и "тупиковых" вершин. В таком графе цикломатическое число равно максимальному количеству его линейно-независимых маршрутов. Величина L соответствует количеству связных компонент всего исходного графа, и обычно для графов не содержащих полностью независимых частей L=1. Иначе говоря, L измеряется количеством замыкающих дуг, необходимых для преобразования исходного графа в максимально сильно связный граф.

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

Подпись: 1) qtyCompl=operations.Qty();
2) if (!flags) {
3) while (counter<qtyCompl)
{  4) routes.status[counter]=1;
5) counter++; }
}
6) operations.AddOp();


Рис.16. Фрагмент исходного текста программы

Рассмотрим на примере фрагмента кода разрабатываемого программного обеспечения тестирование корректности структуры этого фрагмента (см. рис.16). На основе данного фрагмента кода выделим операторы управления и построим графовую модель программы по управлению. Цифрами на рис.16 условно обозначены вершины графа. Рис.17 отображает схему этого графа.


Рис.17. Граф программы по управлению

Далее определим цикломатическое число графа по исходным данным:

Nп = 6

Y = 8

L = 1

Z = Y - Nп + L = 3

В данном случае для максимально связного графа количество линейно-независимых маршрутов для которых следует подготовить тесты равно цикломатическому числу графа. Эти маршруты показаны на рис.18.

Подпись: 1 - 2 - 3 - 6
1 - 2 - 3 - 4 - 5 - 3 - 6
1 - 2 - 6


Рис.18. Линейно-независимые маршруты

В итоге для проверки корректности структуры данного фрагмента кода необходимо провести статическое и динамическое тестирование четырех полученных маршрутов.

  5.3.2.2 Контроль чтения и записи переменных

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

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

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

существует ли запись этой величины вообще;

на всех ли путях, ведущих ко входам, есть запись соответствующей величины перед считыванием с той же области памяти;

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


Рис. 19. Схема контроля чтения и записи переменных

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

предварительная запись в область памяти перед считыванием из нее информации;

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

В итоге все обнаруженные ошибки и сомнительные сочетания операций фиксируются и исправляются в тексте программы.

  5.4 Результаты работы программы

Ниже приведены результаты работы программы.

На рис.20 показано главное меню программы, содержащее помимо стандартных элементов управления (File, Windows, Help) специальные. Существенные объекты выделены в отдельное выпадающее меню Objects.

Рис. 20. Главное меню программы

На рис.21. показано окно вывода информации о процессе обработки, выполняемой над партией полупроводниковых пластин с заданным номером в пределах заданного изделия. При этом выводится вся необходимая информация о маршруте, параметрах и режимах технологической операции, рассчитывается время окончания технологической операции.

Рис.21. Окно вывода результатов выполнения технологической операции

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

Рис.22. Окно вывода информации о технологических операциях, произведенных над партией полупроводниковых пластин


6. Организационно-экономическая часть 6.1 Введение

Особенности процесса создания и освоения новой техники, в том числе постановки сложной современной продукции в производстве, связаны с чрезвычайно большим количеством разнообразных операций и действий, выполняемых различными подразделениями и коллективами. Во многих случаях эта коллективы не соподчинены, имеют противоречивые интересы и не управляются из единого центра. В то же время все работы и процессы должны выполняться слаженно, согласованно и по возможности в кратчайшие сроки. Именно этого требуют задачи научно-технического прогресса, успешное решение которых чрезвычайно актуально для нашей отечественной промышленности.

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

Работы по развитию и использованию СПУ получили большое распространение за рубежом. В нашей стране многими организациями и предприятиями также накоплен опыт применения систем СПУ. Они эффективно используются в разных отраслях при создании и освоении новой техники, при строительстве и пуске крупных объектов, ремонте уникальных агрегатов, координации крупных научно-исследовательских работ, реализации межотраслевых проектов. Следует в то же время отметить, что большим достижением использования СПУ в нашей стране является то, что с самого начала ее внедрения были приняты меры по обеспечению единообразия терминов, обозначений, методов расчетов, - словом, по максимальной унификации системы.

Система СПУ создана в первую очередь для планирования комплекса работ, носящих характер неопределенности. С помощью сетевых графиков и методов их расчета (рассмотренных ниже) успешно преодолеваются осложнения, связанные о неопределенностью в оценках времени, необходимого для выполнения отдельных работ, в сроках достижения промежуточных и конечного результатов, в потребных ресурсах.

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

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

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

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

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

Основным элементом системы является сетевой график. Это плановая модель процесса, на которой можно провести эксперименты и выявить, к каким результатам приведет то или иное изменение сроков выполнения отдельных работ.

В системе используется графическое отражение логической последовательности, взаимосвязи и продолжительности работ.

Сетевые графики можно классифицировать по объему и степени детализации, по степени определенности, по числу достигаемых целей (результатов), по вероятности сроков выполнения отдельных приемов и работ.

По объему и степени детализации различают:

первичные,

частные,

комплексные сети.

По степени определенности:

детерминированные сети, когда известна конкретная цель разработки и основные процессы, ведущие к ее достижению,

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

По числу конечных целей модели подразделяются на:

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

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

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

СПУ состоит из следующих стадий:

предпроектной, включающей выбор объекта планирования;

создания сетевой модели, основанного на перечне всех работ и событий (промежуточных результатов);

оптимизации модели по установленным критериям (например, срокам или затратам);

управления с помощью сетевого графика на основе поступающей информации о ходе выполнения работ на данный период.

В данной работе рассматривается детерминированная одноцелевая модель. При исследовании рассматриваемой модели будут пройдены все стадии сетевого планирования и управления, включая выбор объекта планирования, создание сетевой модели, анализ и оптимизация.

 

6.2 Сетевая модель, ее основные элементы, правила построения

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

Математическая теория графов оперирует понятием пути, под которым понимается такая последовательность ребер, когда конец каждого предыдущего ребра совпадает о началом последующего.

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

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

Работами называются любые процессы, действия, приводящие к достижению определенных результатов (событий).

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

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

Событиями называются результаты производственных работ. Каждое событие может быть отправным моментом для начала последующих работ. В отличие от работы, имеющей обычно протяженность во времени, событие представляет собой только момент свершения работы (или работ).

Первоначальное событие в сети, не имеющее предшествующих событий и отражающее начало выполнения всего комплекса работ, включенных в данную сеть, называется исходным и обозначается символом J. Событие, которое не имеет последующих событий и отражает конечную цель комплекса работ, включенных в данную сеть, называется завершающим и обозначается символом C.

Любая последовательность работ в сетевом графике, в которой конечное событие одной работы совладает с начальным событием следующей за ней работы, называется путем.

В сетевом графике следует различать несколько видов путей:

от исходного события до завершающего события - полный путь, или просто путь;

от исходного события до данного - путь, предшествующий данному событию;

от данного события до завершающего - путь, последующий за данным событием;

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

Все события и работы, которые необходимо выполнить для peaлизации проекта, необходимо систематизировать при составлении перечня событий и работ.

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


Таблица 1. Перечень событий

Номер Событие
0 Решение о начале работ принято
1 Рабочая документация проанализирована
2 Опрос работников предприятия произведен
3 Существующие решения проанализированы
4 Полученная ннформация систематизирована
5 Аппарат имитационного моделирования создан
6 Разработаны возможные варианты дисциплины очереди
7 База данных разработана
8 Имитационная модель написана
9 Варианты протестированы
10 Имитационная модель сопряжена с базой данных
11 Пользовательский интерфейс разработан
12 Оптимальный вариант дисциплины очереди выбран
13 Имитационная модель цеха разработана
14 Имеющиеся ресурсы проанализированы
15 Аппаратная часть системы выбрана
16 Программные технологии системы выбраны
17 Система разбита на взаимосвязанные блоки
18 Разработка компьютерной системы завершена

Рис.23. Сетевой график разработки автоматизированной системы управления производственным процессом на предприятии электронной промышленности


Таблица 2 Перечень работ

Номер Содержание работы
0-1 Анализ рабочей документации
1-3 Анализ существующих решений в управлении
3-4 Систематизация полученной информации
0-2 Опрос работников предприятия
2-3 Передача информации
3-7 Разработка базы данных
7-8 Передача информации
4-6 Разработка возможных вариантов дисциплины очереди
6-9 Тестирование вариантов дисциплины очереди
9-12 Выбор оптимального варианта
12-13 Разработка имитационной модели
4-5 Создание аппарата имитационного моделирования
5-8 Написание имитационной модели
8-10 Сопряжение имитационной модели с базой данных
10-12 Передача информации
4-11 Разработка пользовательского интерфейса
11-12 Передача информации
13-14 Анализ имеющихся программных и аппаратных ресурсов
14-17 Разбиение проектируемой системы на взаимосвязанные блоки
17-18 Разработка компьютерной системы
14-15 Выбор аппаратной части системы
15-17 Передача информации
14-16 Выбор программных технологий компьютерной системы
16-17 Передача информации

 

6.3 Расчет параметров сетевой модели

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

Расчет параметров сети имеет целью определение их численных величин: продолжительности критического пути, размеров резервов времени событий и работ и др. Этот расчет приводится далее.

В результате расчета параметров и анализа их величин появляется возможность оптимизации сетевого графика по выбранным или назначенным критериям. Расчет параметров и нахождение их определенных величин возможны для детерминированных и условно-детерминированных моделей.

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

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

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

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

Ненапряженные пути обладают важным свойством: на участках, не совпадающих с критической последовательностью работ, они имеют резервы времени.

Кроме критического пути, другими основными параметрами сетевой модели являются резервы времени наступления события и разновидности резервов времени работ. Резервы времени существуют в сетевом графике во всех случаях, когда имеются два или более путей разной продолжительности. Резерв времени события - это такой промежуток времени, на который может быть отсрочено наступление данного события без нарушения сроков завершения разработки в целом. Резерв времени события определяется как разность между поздним Тп и ранним Тр сроками наступления события:

R = Т п - Т р.

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

Ранний срок наступления события Тр - минимальный срок, необходимый для выполнения всех работ, предшествующих данному событию. Это время находится путем выбора максимального значения из продолжительностей всех путей, ведущих в данному событию.

Если обозначить предшествующее событие i, а последующее j, то ранний и поздний сроки свершения событий будут обозначаться соответственно Трi, Тпi, Трj, Тпj, т.е. рядом с индексом, определяющим характер срока свершения события (ранний срок - р, поздний - п), пишется номер события.

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

Зная ранние и поздние сроки наступления событий, можно для любой работы (i,j) определить также ранние и поздние сроки начала и окончания работы.

Ранний срок начала работы:

Т рн ij = Т р i

поздний срок ее начала:

Т пн ij = Т п j - t ij

ранний срок окончания работы:

Т ро ij = Т р i + t ij

поздний срок окончания работы:

Т по ij = Т п j.

Все названные сроки можно определять как календарные (задаваемые от начального момента календарной датой).


Рис.24. Параметры сети, отмеченные непосредственно на графе: продолжительность работ, количество исполнителей, ранние и поздние сроки наступления событий, резервы времени событий.


Резервами времени располагают не только события, но и пути (кроме критического), а также работы, лежащие на некритических путях. Для определения полного резерва времени пути R (Li) следует опять вернуться в тому условию, что длина критического пути в сетевом графике больше, чем длина любого другого полного пути. Разница между длиной критического пути t (Lкр) и длиной любого другого пути t (Li) называется полным резервом времени пути:

R (Li) = t (Lкр) - t (Li)

Полный резерв пути показывает, насколько могут быть увеличены продолжительности всех работ, принадлежащих пути Li, в сумме или, иными словами, каково предельно допустимое увеличение продолжительности этого пути.

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

Полный резерв времени работы - это максимальное количество времени, на которое можно увеличить продолжительность данной работы, не изменяя при этом продолжительности критического пути. Полный резерв времени работы:

R п ij = Т п j - Т р i - t ij

где i - начальное событие данной работы; j - конечное событие этой работы; Тпj и Трi - соответственно поздний и ранний срок свершения событий i и j.

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

У отдельных работ помимо полного резерва времени имеется свободный резерв времени Rс, который равен разности между ранними сроками наступления начального i и конечного j событий за вычетом продолжительности работы t ij:


R с ij = Т р j - Т р i - t ij

Свободный резерв времени - это максимальное количество времени, на которое можно увеличить продолжительность работы или отсрочить ее начало, не изменяя при этом ранних сроков начала последующих работ, при условии, что начальное событие этой работы наступило в свой ранний срок.

Если начальное событие i наступает не в свой ранний срок, а в какой-то фактический Тф, то работа (i,j) будет располагать свободным фактическим резервом времени:

R сф ij = Т р j - Т ф i - t ij

Используя свободный резерв времени, ответственные исполнители могут беспрепятственно маневрировать в его пределах сроком начала данной работы или ее продолжительностью. Это важное свойство свободного резерва времени должно учитываться исполнителями при независимом выполнении отдельно взятых работ, располагающих этим резервом.

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

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

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

Свободный резерв - это независимый резерв. Его использование на какой-либо работе не меняет величины свободных резервов остальных работ сети, так как при его исчислении в качестве плановых сроков начала выполнения всех работ приняты ранние сроки наступления событий.

Таблица 3. Параметры сетевой модели

i j Трi Тпi Трj Тпj Tij Трнij Тпнij Троij Тпоij Rпij Rсij
0 1 0 0 4 4 4 0 0 4 4 0 0
1 3 4 4 9 9 5 4 4 9 9 0 0
3 4 9 9 17 17 8 9 9 17 17 0 0
0 2 0 0 4 9 4 0 5 4 9 5 0
2 3 4 9 9 9 0 4 9 4 9 5 5
3 7 9 9 28 40 17 9 21 28 40 12 0
7 8 28 40 38 40 0 28 40 28 40 12 10
4 6 17 17 25 25 8 17 17 25 25 0 0
6 9 25 25 40 40 15 25 25 40 40 0 0
9 12 40 40 45 45 5 40 40 45 45 0 0
12 13 45 45 55 55 10 45 45 55 55 0 0
4 5 17 17 24 26 7 17 19 24 26 2 0
5 8 24 26 38 40 14 24 26 38 40 2 0
8 10 38 40 43 45 5 38 40 43 45 2 0
10 12 43 45 45 45 0 43 45 43 45 2 2
4 11 17 17 19 45 2 17 43 19 45 26 0
11 12 19 45 45 45 0 19 45 19 45 26 26
13 14 55 55 57 57 2 55 55 57 57 0 0
14 17 57 57 67 67 10 57 57 67 67 0 0
17 18 67 67 82 82 15 67 67 82 82 0 0
14 15 57 57 61 67 4 57 63 61 67 6 0
15 17 61 67 67 67 0 61 67 61 67 6 6
14 16 57 57 61 67 4 57 63 61 67 6 0
16 17 61 67 67 67 0 61 67 61 67 6 6
  6.4 Основы оптимизации сетевого графика

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

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

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

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

Если совпадающую с критическим путем величину отрезка пути обозначить t' (Lкр), длину критического пути - t (Lкр), а протяженность максимального из некритических путей, проходящих через данную работу, - t (Lmax), то коэффициент напряженности Kнij будет равен:


Используя зависимость, по которой определяется полный резерв времени пути, формулу можно привести к виду:

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

Чем выше коэффициент напряженности, тем сложнее выполнить данную работу в установленные сроки. И наоборот, чем меньше коэффициент напряженности, тем большими относительными резервами обладает данный путь в сети.

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

  6.5 Анализ и оптимизация сетевой модели

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

перераспределения ресурсов - временных (использование резервов времени), материальных, финансовых, а также ресурсов рабочей силы;

интенсификации выполнения работ критического пути (дополнительное количество исполнителей и оборудования, материальное стимулирование, сверхурочные работы);

параллельного выполнения работ критического пути;

изменения в характере комплекса работ.

Оптимизация сетевого графика в зависимости от полноты решаемых задач может быть условно разделена на частную и комплексную. Видами частной оптимизации сетевого графика является минимизация:

времени выполнения разработки при заданной ее стоимости;

потребляемых (используемых одновременно) ресурсов;

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

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

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

Сокращение продолжительности критического пути может быть достигнуто ответственными исполнителями критических работ за счет внутренних резервов, а также путем привлечения дополнительных ресурсов. Внутренние резервы работ, подчиненных одному ответственному исполнителю, заключаются в интенсификации выполняемых действий в лучшей организации работ, повышении уровня их автоматизации. Напримар, системы автоматического проектирования (САПР) позволяют во много раз ускорить процессы расчетов, отбора лучших вариантов из большого числа просчитанных, быстро найти наилучшее решение. Во многих случаях интенсификация приводит к повышению затрат.

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

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

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

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

Пунктирные линии играют вспомогательную роль (соединение работы с событиями) и дают наглядное представление об имеющихся резервах времени. Если по каким-либо причинам некритическая работа начинается не сразу после наступления предшествующего события, ее обозначают пунктирной линией. Фиктивные работы вычерчиваются только пунктирными линиями. При отсутствии резерва они изображаются на карте вертикальной пунктирной линией.

Под календарным графиком изображаются диаграммы дотребнооти в работниках.

Маневрирование ресурсами работников, сокращение их числа или же уменьшение общей продолжительности комплекса работ возможно при условии двух предпосылок:

если специалисты, выполняющие параллельные работы, взаимозаменяемы;

если эти группы специалистов подчинены одному руководителю.

При отсутствии предпосылок дальнейшая (после рациональной перестройки сети) оптимизация и сокращение сроков могут потребовать выделения дополнительных ресурсов - работников и средств на работы критического пути.

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

Следовательно изменяется карта проекта. Иными в этом случае стали и диаграммы потребности в исполнителях вследствие их перераспределения между работами критической и некритической зоны. Следующим этапом является минимизация потребности в исполнителях. Это достигается путем смещения сроков начала (и соответственно окончания) работ напряженных путей.

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



Рис.25. Карта проекта до оптимизации: календарный график

Рис.26. Карта проекта до оптимизации: диаграмма потребности в исполнителях

Рис.27. Карта проекта после оптимизации: диаграмма потребности в исполнителях.


6.6 Выводы

В результате рассмотрения методов сетевого планирования и управления можно сделать вывод о ряде преимуществ систем СПУ.

Внимание концентрируется на решающих работах, лежащих на критическом пути и относящихся к ограниченному числу ответственных исполнителей. Управление строится по принципу временного исключения из поля зрения руководства тех работ, которые в данный момент и в ближайшем будущем не могут влиять на общий ход разработки.

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

Система СПУ обеспечивает возможность рационального маневрирования выделенными для данной разработки ресурсами времени и средств.

Упрощается и унифицируется отчетная документация.

Обеспечивается возможность использования ЭВМ для составления анализа, расчета и корректировки графиков выполнения работ.

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

В рассмотренном сетевом графе для выполнения всего комплекса работ привлекалась только одна категория исполнителей работ - инженеры.

Анализ сетевого графика выявил работы критического пути, общая продолжительность которых составила 82 дня. Оптимизация сетевого графика ставила своей целью обеспечение равномерности загрузки исполнителей на всем протяжении критического пути. В результате были рассчитаны резервы времени событий и работ, в соответствии с которыми были изменены сроки начала некоторых работ, не принадлежащих критическому пути. Это позволило уменьшить максимальную потребность в исполнителях и сократить штатное расписание с 11 до 9 человек. В конечном счете затраты на выполнение всего комплекса работ сократились со 150150 руб. до 122850 руб. Экономия от оптимизации в абсолютном выражении составила 27300 руб., что составляет 18% от первоначальной стоимости.

Таблица 4. Результаты оптимизации

Параметры

После

оптимизации

До

оптимизации

Штатное расписание, чел. 9 11
Заработная плата инженера, руб. /мес. 5000 5000
Длительность проекта, дн. 82 82
Всего затраты на проект, руб. 122850 150150
Экономия,% 18

7. Производственная и экологическая безопасность

 

Организация рабочего места программиста и пользователя ЭВМ.

Выполнил:

Ляшко М.А.

Консультант:

Никулина И.М.

 

7.1 Введение

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

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

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

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

Инженер всегда обязан помнить, что первое условие научно-организованного труда состоит в том, чтобы обеспечить безопасность людей.

В процессе работы здоровью людей могут угрожать факторы, вызванные преимущественно неправильной организацией работы либо несоблюдением техники безопасности.

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

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

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

 

7.2 Рабочее место программиста

Стандартное автоматизированное рабочее место программиста имеет необходимые составные части:

системный блок, включающий в себя основную аппаратную логику, обеспечивающую нормальное функционирование компьютера;

монитор, являющийся основным средством вывода информации, через который выдается подавляющее количество всей выводимой информации, даже с учетом распространения мультимедиа;

клавиатуру как основное средство ввода, хотя в последнее время стремительно увеличивается значимость манипулятора типа "мышь";

вышеупомянутый манипулятор типа "мышь".

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

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


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

Даже исправный компьютер постоянно оказывает вредное воздействие на организм человека, которое может причинить большой вред организму человека, если пренебрегать эргономическими и экологическими требованиями. К вредным производственным факторам относятся побочное излучение в различных диапазонах, дополнительные шумы, возникающие при работе компьютера. Группа эргономических факторов включает в себя правильность расположения отдельных частей компьютера, цветовую гамму окружающей обстановки, правильно подобранную палитру интерфейса прикладных программ. Работа с системой связана с воздействием следующих поражающих факторов:

Поражение электрическим током питающей сети.

Пожароопасность.

Излучения экрана монитора.

Шум, возникающий при работе механических и электрических устройств системы.

Физические перегрузки (статические).

Психофизиологические перегрузки:

Утомление, связанное с монотонностью работы,

Перенапряжение зрительных анализаторов,

Умственное напряжение,

Эмоциональные перегрузки в большом коллективе.

Поражающие факторы 1 и 2 не являются источниками постоянно действующей опасности. Их безопасность гарантируется тщательным соблюдением правил техники безопасности эксплуатации системы. Каждый работающий должен ознакомиться с этими правилами, пройти соответствующий инструктаж и следить за соблюдением этих правил. Поражающие факторы 3-6 являются постоянно действующими, возникающими при каждодневной текущей работе.

 

7.4 Нерациональное освещение

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

Анализируя условия работы программиста получаем следующие требования к производственному освещению:

наименьшая допустимая освещенность от общего освещения составляет 200 лк;

при работе за компьютером желательно, чтобы освещенность рабочего места не превышала 2/3 нормальной освещенности помещения;

экран дисплея не должен быть ориентирован в сторону источников света (окон, настольных ламп и т.п.); при размещении рабочего места рядом с окном угол между экраном дисплея и плоскостью окна должен составлять не менее 90 градусов (для исключения бликов), прилегающую часть окна желательно зашторить;

не следует располагать дисплей непосредственно под источником освещения или вплотную с ним;

стена позади дисплея должна быть освещена примерно так же, как и его экран;

яркость для блестящих поверхностей более 0.2 кв. м не должна превышать 500 кд/кв. м;

показатель ослепленности не должен превышать 40 единиц;

коэффициент пульсаций 10 - 20%.

Специфика работы за ЭВМ, состоит в том, что работать приходится с так называемым самосветящимся объектом.

Свечение со стороны экрана, а также частая смена заставок на экране при большой продолжительности трудовой деятельности может отрицательно воздействовать на зрение.

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

Для обеспечения нормальной естественной освещенности, площадь оконных проемов должна быть не менее 25% площади пола.

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

Рекомендуемые перепады яркости в поле зрения оператора должны лежать в пределах 1: 5 - 1: 10.

 

7.5 Расчет общего освещения

Рассчитаем общее освещение в машинном зале ПЭВМ методом коэффициента использования светового потока по уравнению:

Выбираем рекомендованное для машинного зала люминесцентное освещение.

Располагаем светильники рядами вдоль длинной стороны помещения. Будем использовать светильники типа УСП-35 с двумя лампами типа ЛБ-40.

Для обеспечения наилучших условий освещения, расстояние между рядами светильников L должно соответствовать отношению:


где h-высота подвеса светильников,

где H = 3.2 м - высота помещения,

hc = 0.2 м - свес светильника,

hp = 0.75 м - высота рабочей поверхности от пола.

h = 3.0-0.2-0.75 = 2.25 [м]

Þ L = λ*h = 3.1…3.4 [м]

Длина помещения А = 8 м

Ширина помещения В = 6 м

Количество рядов светильников N найдем из уравнения:

L * (0.33* 2 + N-1) = B

Количество рядов светильников N = 2 ряда.

Согласно нормам, нормируемая минимальная освещенность при общем освещении: Eн = 200 лк.

Так как запыленность воздуха меньше 1 мг/м³, то коэффициент запаса:

Кз = 1.5

Площадь помещения S = A*B = 8*6 = 48 [м²].

Так как мы предполагаем создать достаточно равномерное освещение, то коэффициент неравномерности освещения: z = 1.15.

Индекс помещения:


Коэффициенты отражения светового потока принимаем:

от потолкаρп = 70%,

от стенρс = 50%,

от полаρпола = 10%.

Тогда по таблице находим коэффициент использования светового потока:

η = 0.46.

Так как затенения предполагаем не создавать, то коэффициент затенения:

γ = 1.

По таблице находим световой поток лампы ЛБ-40:

Фл = 3120 лм.

Световой поток светильника: Фсв = 2*Фл = 6240 [лм].

Количество светильников в одном ряду:

Расположение светильников:

Длина светильника lсв = 1.3 м

Количество светильников в ряду М = 3 шт

Количество рядов светильников N = 2 шт

Так как А - М*lсв = 4.1<4*L = 12.8 [м]

(где L - рассчитанное минимальное расстояние между светильниками), то расстояние между светильниками в одном ряду L2 можно сделать равным расстоянию от крайнего светильника в ряду до стены.

Тогда

Расстояние между рядами L1 при расстоянии крайнего ряда от стены 0.33*L1:

Итак, для нормального освещения машинного зала ПЭВМ используем 6 светильников типа УСП-35 с двумя лампами типа ЛБ-40.

 

7.6 Электроопасность

Помещение машинного зала ПЭВМ не должно относится к категории помещений с повышенной электроопасностью, то есть:

Относительная влажность воздуха в помещении должна быть не более 75%.

Должна отсутствовать токопроводящая пыль.

Не должно быть повышенной температуры воздуха в помещении (температура постоянно или периодически, более одних суток, превышает +35 ºС).

Должна отсутствовать возможность одновременного прикосновения человека к имеющим соединение с землей металлическим конструкциям здания, оборудованию и т.д., с одной стороны, и к металлическим корпусам аппаратуры или токоведущим частям, с другой стороны.

Не должно быть токопроводящих полов.

Основными средствами защиты от поражения электрическим током при работе на компьютере являются защитное заземление и зануление.

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

Опасность прикосновения человека к токоведущим частям электроустановки определяется величиной протекающего через тело человека тока. В общем случае величина этого тока зависит от схемы прикосновения человека к электросети, ее напряжения, схемы самой сети и рода тока, режима нейтрали сети. Для питания отдельных устройств используются однофазные сети переменного тока 220 В / 50 Гц.

Iраб. = Upaб. / R, где

Upaб. - рабочее напряжение сети;

R - электрическое сопротивление тела человека.

Iраб. = 220В / 1000Ом = 0,22А - ток, протекающий через тело человека.

Iпор. = 0,5 мА - допустимая величина тока.

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

Как показывает анализ случаев электротравматизма при эксплуатации промышленных установок, чаще всего имеет место однополюсное (однофазное) прикосновение в изолированных и глухозаземленных сетях.

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

Опасность эксплуатации таких электроустановок очевидна. Эффективной мерой защиты при питании оборудования машинного зала напряжением опасным для жизни человека является защитное заземление. Заземляющим устройством называют совокупность заземлителя (металлического проводника или группы проводников, находящихся в непосредственном соприкосновении с грунтом) и заземляющих проводников, соединяющих заземленные части электроустановки с заземлителем. Если корпус электрооборудования не имеет контакта с землей, то в случае перехода напряжения прикосновение к нему так же опасно, как и прикосновение к токоведущим частям электроустановки. Когда корпус заземляют, образуется ветвь тока, параллельная участку сети, в которую включается человек. Ток замыкания на землю перераспределяется: вследствие малого сопротивления заземляющего устройства - больший ток пойдет через заземляющую систему, и меньший - через человека. При исправном заземлении ток, проходящий через тело человека, становится неопасным.Т. к. помещение машинного зала относится к классу помещений без повышенной опасности, то для обеспечения безопасности персонала необходим обычный комплекс профилактических работ, включающий обеспечение надежного заземления всех металлических частей, причем наибольшая допустимая величина сопротивления заземления не должна превышать 4 Ом.

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

Наибольшее допустимое сопротивление заземляющих устройств и заземлителей в системе зануления при подключении ЭВМ типа IBM PC составляет 30 Ом.

Изоляция имеет важное значение в электроустановках, она защищает их от чрезмерной утечки токов, предохраняет людей от поражения током и исключает возникновение пожаров.

Правилами устройства электроустановок определено, что сопротивление изоляции сети на участке между двумя смежными предохранителями или за последними предохранителями между любыми проводами должно быть не менее 0.5 МОм.

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

 

7.7 Требования по пожарной безопасности

Помещение машинного зала ПЭВМ относится к категории В (пожароопасная) пожарной опасности помещений, так как в помещении находится электрооборудование, горючие вещества (мебель, пластиковые корпуса аппаратуры и др.). Поэтому помещение должно соответствовать нормативам по огнестойкости строительных конструкций, планировке зданий, этажности, оснащенности устройствами противопожарной защиты, установленным для этой категории помещений. Помещение машинного зала должно обладать I или II степенью огнестойкости (см. СНиП 2.01.02-85 “Противопожарные нормы”), то есть самой высокой.

 


7.8 Меры по снижению уровня шума

Шум оказывает большое влияние на человека и его работоспособность. Уже при уровнях шума в 40-70 дБ ослабляется внимание, ухудшается память, появляется быстрая утомляемость, головная боль. Наибольшей степенью воздействия на состояние человека обладают импульсные и нерегулярные шумы.

Согласно ГОСТ 12.1 003-83 ССБТ “Шум. Общие требования безопасности” допустимым значением уровня шума в помещении машинного зала ПЭВМ является 50 дБ. Основными источниками шума в помещении машинного зала являются матричные принтеры, которые могут создавать уровень шума близкий к 50 дБ. Для снижения уровня шума в помещении машинного зала рекомендуется:

Располагать помещение машинного зала вдали от внешних источников шума.

Использовать звукопоглощающие облицовочные материалы.

Использовать малошумящую вентиляцию.

Использовать струйные или лазерные принтеры вместо матричных.

 

7.9 Защита от вредных излучений

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

История исследования этого вопроса достаточно длительная и непростая, но полученные результаты носят пока еще преимущественно статистический характер и не имеют адекватного объяснения. Частотный состав (спектр) излучения монитора характеризуется наличием рентгеновских, ультрафиолетовых, инфракрасных и других электромагнитных колебаний. Опасность рентгеновского и части других излучений большинством ученых признается пренебрежимо малой, поскольку их уровень достаточно невелик и в основном поглощается покрытием экрана. Наиболее тяжелая ситуация связана, по-видимому, с полями излучений очень низких частот (ОНЧ) и крайне низких частот (КНЧ), которые, как выяснилось, способны вызывать биологические эффекты при воздействии на живые организмы. Было обнаружено, что электромагнитные поля с частотой порядка 60 Гц могут инициировать изменения в клетках животных (вплоть до нарушения синтеза ДНК). Особенно поразительным для исследователей оказался тот факт, что, в отличие, например, от рентгеновского излучения, электромагнитные волны обладают необычным свойством: опасность их воздействия при снижении интенсивности излучения не уменьшается, мало того, некоторые поля действуют на клетки тела только при малых интенсивностях или на конкретных частотах.

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

Исследователи из Macworld обнаружили, что если на расстоянии 10 см перед мониторами, обычно используемыми с компьютерами Macintosh, напряженность магнитного поля составляет примерно от 5 до 23 мГс, то на расстоянии 70 см от экрана ни у одного из обследованных мониторов напряженность поля не превышала величины 1 мГс. (Интенсивность поля вне указанных пределов составляла 0.1 - 0.5 мГс)

Как это ни странно, но до сих пор нет нормативов для излучений КНЧ-магнитных полей, хотя в некоторых странах (в том числе в Швеции и Канаде) разработаны стандарты для излучений ОНЧ-магнитных полей. Большое число поставщиков - например, фирмы IBM, DEC и Philips - продают мониторы, удовлетворяющие указанным стандартам. Кроме того, любой монитор, работающий не на ЭЛТ, имеет то преимущество, что не излучает переменных компонент, связанных с наличием систем вертикального и горизонтального отклонения электронного луча.

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

 

7.10 Параметры микроклимата в машинном зале

Метеорологическими условиями согласно ГОСТ 12.1 005-88 являются:

температура;

относительная влажность;

скорость движения воздуха;

атмосферное давление.

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

Атмосферное давление в помещении машинного зала должно быть 1013.25±266 ГПа. При пониженном давлении воздуха ухудшается отвод теплоты от элементов ПЭВМ, снижаются изоляционные свойства воздуха.

Воздух, используемый для вентиляции машинного зала, должен очищаться от пыли. Запыленность воздуха не должна превышать 1 мг/м³, а размеры пылинок - 3 мкм.

Пыль, попадающая на платы комплекса, приводит к снижению теплообмена и способствует перегреву приборов.

В помещении машинного зала необходимо предусмотреть систему отопления.

Она должна обеспечивать достаточное, постоянное и равномерное нагревание воздуха в помещении в холодный период года, а также безопасность в отношении пожара и взрыва. При этом колебания температуры в течении суток не должны превышать 2-3 °С; в горизонтальном направлении - 2 °С на каждый метр длины; а в вертикальном - 1 °С на каждый метр высоты помещения.

Для отопления помещения машинного зала рекомендуется использовать водяные или воздушные системы центрального отопления.

Работающие люди и включенные компьютеры являются источниками избыточного тепла в помещении машинного зала.

Поэтому необходимо предусмотреть систему кондиционирования помещения.

Таблица 5. Параметры воздушной среды

Параметры воздушной среды на рабочих местах
Темпера-тура Оптимальные Допустимые
Наружного воздуха, °С Темпера-тура, °С Относитель-ная влажность,% Скорость движения воздуха, не более, м/c Темпера-тура, °С Относитель-ная влажность,% Скорость движения воздуха, не более, м/c
Ниже +10 20-22 40-60 0.2 18-22 Не более 70 0.3
Выше +10 20-25 40-60 0.3 Не более, чем на 3 °С выше наружного воздуха в 13 ч дня самого жаркого месяца, но не выше 28 °С

70 при 24 °С

и ниже;

65 при 25 °С;

60 при 26 °С;

55 при 27 °С;

50 при 28 °С.

0.5

7.11 Психофизиологические факторы

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

физические перегрузки (статические);

нервно-психические перегрузки:

умственное перенапряжение,

перенапряжение зрительных анализаторов,

монотонность труда,

эмоциональные перегрузки в большом коллективе.

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

общее время работы за дисплеем не должно превышать 50% всего рабочего времени программиста;

при обычной работе за компьютером необходимо делать 15-минутные перерывы через каждые два часа, а при интенсивной работе - через каждый час;

не следует превышать темп работы порядка 10 тысяч нажатий клавиш в час (примерно 1500 слов);

предпочтительнее использовать дисплеи с высокой разрешающей способностью (разрешением) и удобным размером экрана (лучше не применять CGA-мониторы и малоразмерные, менее 14" по диагонали, экраны);

лучше выбирать видеоадаптеры с высоким разрешением и, по возможности (если есть на рынке и цена приемлемая), частотой обновления экранного изображения не менее 70-72 Гц;

обязательно ставить на дисплеи экранные, в частности, поляризационные, фильтры, в несколько раз снижающие утомляемость глаз;

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

Рабочая поза оказывает значительное влияние на эффективность работы человека. Основные требования к рабочим местам при выполнении работы сидя приведены в ГОСТ 12.2 033-78 "ССБТ. Рабочее место при выполнении работ сидя. Общие эргономические требования". При организации рабочего места программиста необходимо придерживаться следующих рекомендаций:

рабочее место должно быть оборудовано так, чтобы исключать неудобные позы и длительные статические напряжения тела;

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

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

  7.12 Планировка рабочего места программиста и организация работы с компьютером

Планировка рабочего места программиста должна удовлетворять требованиям удобства выполнения работы и экономии энергии и времени программиста, рационального использования площади помещения, соблюдения правил охраны труда. Рекомендуемая планировка рабочего места программиста, учитывающая антропометрические данные человека и габариты аппаратуры представлена на Рис.28.

Рис.28. Рекомендуемая планировка рабочего места программиста.

Для облегчения чтения информации с документов рекомендуется использовать специальные держатели бумаг, крепящиеся к монитору компьютера. Для предотвращения перенапряжения зрительных анализаторов оператора и снижения монотонности труда, работу, связанную с использованием дисплея ПЭВМ, необходимо чередовать с работой, не требующей использования ПЭВМ, либо делать небольшие перерывы через каждые 45-90 минут. Общее время работы за экраном ЭВМ не должно превышать 6 часов в день.

 

7.13 Выводы

В этой главе дипломного проекта рассмотрены требования охраны труда и разработаны рекомендации по оптимизации санитарно-гигиенической обстановки при выполнении работ на ЭВМ.

В данной главе были рассмотрены вопросы:

Нерациональность освещения

Излучения экрана монитора

Электроопасность

Шум

Параметры микроклимата

Психофизиологические перегрузки.

Установлено, что уровень шума на рабочем месте не должен превышать 50 дб, объем производственного помещения на одного работающего должен составлять не менее 15 куб. м, площадь - не менее 4.5 кв. м, наименьшая допустимая освещенность - 200 лк.

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

В данной главе был проведен расчет искусственного освещения и подсчитано фактическое значение минимальной освещенности дисплейного класса - 200 лк.

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


Заключение

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

Дальнейшие этапы работы должны состоять в следующем:

создание имитационной программы, моделирующей процесс управления производством партий;

разработка алгоритмов дисциплины очереди;

проектирование системы управления;

реализация, тестирование и оптимизация системы управления производством партий на ОАО "Ангстрем".

Необходимо подчеркнуть, что разработка компьютерно-сетевых систем управления производственными процессами весьма актуальна для отечественной промышленности. И возможно, разрабатываемая АСУ ПП станет базовым образцом для широкого класса "интеллектуальных" промышленных систем управления.


Список использованной литературы

1.         Поспелов Д.А. Ситуационное управление. Теория и практика. М.: Наука, 1986, 285 с.

2.         Поспелов Д.А. Принципы ситуационного управления // Известия АН СССР. Серия Техническая кибернетика. 1971. N.2.

3.         Клыков Ю.И. Ситуационное управление большими системами. М.: Энергия, 1974.

4.         Поспелов Д.А. Большие системы. Ситуационное управление. М.: Знание, 1975.

5.         Искусственный интеллект. - В 3-х кн. Справочник. М.: Радио и связь, 1990.

6.         MES Explained: A High Level Vision for Executives. White Paper of MESA International (1997). Интернет-адрес: http://www.mesa.org/html/main. cgi? sub=7

7.         Technical Articles of Consilium Company. Интернет-адрес: http://www.consilium.com/Publications/technica. htm

8.         Уоссермен Ф. Нейрокомпьютерная техника. Теория и практика. М.: Мир, 1992.238 с.

9.         С.С. Гайсарян. Объектно-ориентированные технологии проектирования прикладных программных систем. Интернет-адрес: http://www.citforum.ru/programming/oop_rsis/index. shtml

10.       P. Coad, M. Mayfield. Object Models: Strategies, Patterns and Applications (Yourdon Press Computing Series). 1996.

11.       Буч.Г. "Объектно-ориентированный анализ и проектирование с примерами приложений на C++", М.,"Бином", 1998 г.


Приложение

Фрагменты исходного кода

 // Angstrem. h: main header file for the ANGSTREM application

 //

#if _MSC_VER > 1000

#pragma once

#endif // _MSC_VER > 1000

#ifndef __AFXWIN_H__

#error include 'stdafx. h' before including this file for PCH

#endif

#include "resource. h" // main symbols

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CAngstremApp:

 // See Angstrem. cpp for the implementation of this class

 //

class CAngstremApp: public CWinApp

{

public:

CAngstremApp ();

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CAngstremApp)

public:

virtual BOOL InitInstance ();

 // }}AFX_VIRTUAL

 // Implementation

 // {{AFX_MSG (CAngstremApp)

afx_msg void OnAppAbout ();

afx_msg void OnObjectsPartsNew ();

afx_msg void OnObjectsPartsOpen ();

afx_msg void OnObjectsPartsViewall ();

afx_msg void OnObjectsPartsDelete ();

afx_msg void OnAppFindpart ();

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // {{AFX_INSERT_LOCATION}}

 // Microsoft Visual C++ will insert additional declarations immediately before the previous line.

 // Angstrem. cpp: Defines the class behaviors for the application.

 //

#include "stdafx. h"

#include "Angstrem. h"

#include "MainFrame. h"

#include "ChildFrame. h"

#include "AngstremDoc. h"

#include "AngstremView. h"

#ifdef _DEBUG

#define new DEBUG_NEW

#undef THIS_FILE

static char THIS_FILE [] = __FILE__;

#endif

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CAngstremApp

BEGIN_MESSAGE_MAP (CAngstremApp, CWinApp)

 // {{AFX_MSG_MAP (CAngstremApp)

ON_COMMAND (ID_APP_ABOUT, OnAppAbout)

ON_COMMAND (ID_OBJECTS_PARTS_NEW, OnObjectsPartsNew)

ON_COMMAND (ID_OBJECTS_PARTS_OPEN, OnObjectsPartsOpen)

ON_COMMAND (ID_OBJECTS_PARTS_VIEWALL, OnObjectsPartsViewall)

ON_COMMAND (ID_OBJECTS_PARTS_DELETE, OnObjectsPartsDelete)

ON_COMMAND (ID_APP_FINDPART, OnAppFindpart)

 // }}AFX_MSG_MAP

 // Standard file based document commands

END_MESSAGE_MAP ()

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CAngstremApp construction

CAngstremApp:: CAngstremApp ()

{

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // The one and only CAngstremApp object

CAngstremApp theApp;

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CAngstremApp initialization

BOOL CAngstremApp:: InitInstance ()

{

 // Standard initialization

 // If you are not using these features and wish to reduce the size

 // of your final executable, you should remove from the following

 // the specific initialization routines you do not need.

#ifdef _AFXDLL

Enable3dControls (); // Call this when using MFC in a shared DLL

#else

Enable3dControlsStatic (); // Call this when linking to MFC statically

#endif

 // Change the registry key under which our settings are stored.

 // TODO: You should modify this string to be something appropriate

 // such as the name of your company or organization.

SetRegistryKey (_T ("Local AppWizard-Generated Applications"));

LoadStdProfileSettings (); // Load standard INI file options (including MRU)

 // Register the application's document templates. Document templates

 // serve as the connection between documents, frame windows and views.

CMultiDocTemplate* pDocTemplate;

pDocTemplate = new CMultiDocTemplate (

IDR_ANGSTRTYPE,

RUNTIME_CLASS (CAngstremDoc),

RUNTIME_CLASS (CChildFrame), // custom MDI child frame

RUNTIME_CLASS (CAngstremView));

AddDocTemplate (pDocTemplate);

 // create main MDI Frame window

CMainFrame* pMainFrame = new CMainFrame;

if (! pMainFrame->LoadFrame (IDR_MAINFRAME))

return FALSE;

m_pMainWnd = pMainFrame;

 // Enable drag/drop open

m_pMainWnd->DragAcceptFiles ();

 // Enable DDE Execute open

EnableShellOpen ();

RegisterShellFileTypes (TRUE);

 // Parse command line for standard shell commands, DDE, file open

CCommandLineInfo cmdInfo;

ParseCommandLine (cmdInfo);

 // Dispatch commands specified on the command line

if (! ProcessShellCommand (cmdInfo))

return FALSE;

 // The main window has been initialized, so show and update it.

pMainFrame->ShowWindow (m_nCmdShow);

pMainFrame->UpdateWindow ();

return TRUE;

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CAboutDlg dialog used for App About

class CAboutDlg: public CDialog

{

public:

CAboutDlg ();

 // Dialog Data

 // {{AFX_DATA (CAboutDlg)

enum { IDD = IDD_ABOUTBOX };

 // }}AFX_DATA

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CAboutDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // {{AFX_MSG (CAboutDlg)

 // No message handlers

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

CAboutDlg:: CAboutDlg (): CDialog (CAboutDlg:: IDD)

{

 // {{AFX_DATA_INIT (CAboutDlg)

 // }}AFX_DATA_INIT

}

void CAboutDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CAboutDlg)

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CAboutDlg, CDialog)

 // {{AFX_MSG_MAP (CAboutDlg)

 // No message handlers

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

 // App command to run the dialog

void CAngstremApp:: OnAppAbout ()

{

CAboutDlg aboutDlg;

aboutDlg. DoModal ();

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CNewPartDlg dialog

class CNewPartDlg: public CDialog

{

 // Construction

public:

CNewPartDlg (CWnd* pParent = NULL); // standard constructor

 // Dialog Data

 // {{AFX_DATA (CNewPartDlg)

enum { IDD = IDD_PARTNEW };

 // NOTE: the ClassWizard will add data members here

 // }}AFX_DATA

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CNewPartDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CNewPartDlg)

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

CNewPartDlg:: CNewPartDlg (CWnd* pParent /*=NULL*/)

: CDialog (CNewPartDlg:: IDD, pParent)

{

 // {{AFX_DATA_INIT (CNewPartDlg)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

void CNewPartDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CNewPartDlg)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CNewPartDlg, CDialog)

 // {{AFX_MSG_MAP (CNewPartDlg)

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

void CAngstremApp:: OnObjectsPartsNew ()

{

 // TODO: Add your command handler code here

CNewPartDlg newPartDlg;

newPartDlg. DoModal ();

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // COpenPartDlg dialog

class COpenPartDlg: public CDialog

{

 // Construction

public:

COpenPartDlg (CWnd* pParent = NULL); // standard constructor

 // Dialog Data

 // {{AFX_DATA (COpenPartDlg)

enum { IDD = IDD_PARTOPEN };

 // NOTE: the ClassWizard will add data members here

 // }}AFX_DATA

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (COpenPartDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (COpenPartDlg)

 // NOTE: the ClassWizard will add member functions here

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

COpenPartDlg:: COpenPartDlg (CWnd* pParent /*=NULL*/)

: CDialog (COpenPartDlg:: IDD, pParent)

{

 // {{AFX_DATA_INIT (COpenPartDlg)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

void COpenPartDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (COpenPartDlg)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (COpenPartDlg, CDialog)

 // {{AFX_MSG_MAP (COpenPartDlg)

 // NOTE: the ClassWizard will add message map macros here

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

void CAngstremApp:: OnObjectsPartsOpen ()

{

 // TODO: Add your command handler code here

COpenPartDlg openPartDlg;

openPartDlg. DoModal ();

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CViewAllPartsDlg dialog

class CViewAllPartsDlg: public CDialog

{

 // Construction

public:

CViewAllPartsDlg (CWnd* pParent = NULL); // standard constructor

 // Dialog Data

 // {{AFX_DATA (CViewAllPartsDlg)

enum { IDD = IDD_PARTSVIEWALL };

 // NOTE: the ClassWizard will add data members here

 // }}AFX_DATA

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CViewAllPartsDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CViewAllPartsDlg)

 // NOTE: the ClassWizard will add member functions here

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

CViewAllPartsDlg:: CViewAllPartsDlg (CWnd* pParent /*=NULL*/)

: CDialog (CViewAllPartsDlg:: IDD, pParent)

{

 // {{AFX_DATA_INIT (CViewAllPartsDlg)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

void CViewAllPartsDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CViewAllPartsDlg)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CViewAllPartsDlg, CDialog)

 // {{AFX_MSG_MAP (CViewAllPartsDlg)

 // NOTE: the ClassWizard will add message map macros here

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

void CAngstremApp:: OnObjectsPartsViewall ()

{

 // TODO: Add your command handler code here

CViewAllPartsDlg viewAllPartsDlg;

viewAllPartsDlg. DoModal ();

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CDeletePartDlg dialog

class CDeletePartDlg: public CDialog

{

 // Construction

public:

CDeletePartDlg (CWnd* pParent = NULL); // standard constructor

 // Dialog Data

 // {{AFX_DATA (CDeletePartDlg)

enum { IDD = IDD_PARTDELETE };

 // NOTE: the ClassWizard will add data members here

 // }}AFX_DATA

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CDeletePartDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CDeletePartDlg)

 // NOTE: the ClassWizard will add member functions here

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

CDeletePartDlg:: CDeletePartDlg (CWnd* pParent /*=NULL*/)

: CDialog (CDeletePartDlg:: IDD, pParent)

{

 // {{AFX_DATA_INIT (CDeletePartDlg)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

void CDeletePartDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CDeletePartDlg)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CDeletePartDlg, CDialog)

 // {{AFX_MSG_MAP (CDeletePartDlg)

 // NOTE: the ClassWizard will add message map macros here

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

void CAngstremApp:: OnObjectsPartsDelete ()

{

 // TODO: Add your command handler code here

CDeletePartDlg deletePartDlg;

deletePartDlg. DoModal ();

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CPartProcessingPage dialog

class CPartProcessingPage: public CPropertyPage

{

DECLARE_DYNCREATE (CPartProcessingPage)

 // Construction

public:

CPartProcessingPage ();

~CPartProcessingPage ();

 // Dialog Data

 // {{AFX_DATA (CPartProcessingPage)

enum { IDD = IDD_PART_PROCESSING };

 // NOTE - ClassWizard will add data members here.

 // DO NOT EDIT what you see in these blocks of generated code!

 // }}AFX_DATA

 // Overrides

 // ClassWizard generate virtual function overrides

 // {{AFX_VIRTUAL (CPartProcessingPage)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CPartProcessingPage)

afx_msg void OnRefresh ();

afx_msg void OnStart ();

afx_msg void OnFinish ();

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

IMPLEMENT_DYNCREATE (CPartProcessingPage, CPropertyPage)

CPartProcessingPage:: CPartProcessingPage (): CPropertyPage (CPartProcessingPage:: IDD)

{

 // {{AFX_DATA_INIT (CPartProcessingPage)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

CPartProcessingPage:: ~CPartProcessingPage ()

{

}

void CPartProcessingPage:: DoDataExchange (CDataExchange* pDX)

{

CPropertyPage:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CPartProcessingPage)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CPartProcessingPage, CPropertyPage)

 // {{AFX_MSG_MAP (CPartProcessingPage)

ON_BN_CLICKED (IDREFRESH, OnRefresh)

ON_BN_CLICKED (IDC_START, OnStart)

ON_BN_CLICKED (IDC_FINISH, OnFinish)

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CPartProcessingsPage dialog

class CPartProcessingsPage: public CPropertyPage

{

DECLARE_DYNCREATE (CPartProcessingsPage)

 // Construction

public:

CPartProcessingsPage ();

~CPartProcessingsPage ();

 // Dialog Data

 // {{AFX_DATA (CPartProcessingsPage)

enum { IDD = IDD_PART_PROCESSINGS };

 // NOTE - ClassWizard will add data members here.

 // DO NOT EDIT what you see in these blocks of generated code!

 // }}AFX_DATA

 // Overrides

 // ClassWizard generate virtual function overrides

 // {{AFX_VIRTUAL (CPartProcessingsPage)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CPartProcessingsPage)

 // NOTE: the ClassWizard will add member functions here

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

IMPLEMENT_DYNCREATE (CPartProcessingsPage, CPropertyPage)

CPartProcessingsPage:: CPartProcessingsPage (): CPropertyPage (CPartProcessingsPage:: IDD)

{

 // {{AFX_DATA_INIT (CPartProcessingsPage)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

CPartProcessingsPage:: ~CPartProcessingsPage ()

{

}

void CPartProcessingsPage:: DoDataExchange (CDataExchange* pDX)

{

CPropertyPage:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CPartProcessingsPage)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CPartProcessingsPage, CPropertyPage)

 // {{AFX_MSG_MAP (CPartProcessingsPage)

 // NOTE: the ClassWizard will add message map macros here

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CPartRoutePage dialog

class CPartRoutePage: public CPropertyPage

{

DECLARE_DYNCREATE (CPartRoutePage)

 // Construction

public:

CPartRoutePage ();

~CPartRoutePage ();

 // Dialog Data

 // {{AFX_DATA (CPartRoutePage)

enum { IDD = IDD_PART_ROUTE };

 // NOTE - ClassWizard will add data members here.

 // DO NOT EDIT what you see in these blocks of generated code!

 // }}AFX_DATA

 // Overrides

 // ClassWizard generate virtual function overrides

 // {{AFX_VIRTUAL (CPartRoutePage)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CPartRoutePage)

 // NOTE: the ClassWizard will add member functions here

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

IMPLEMENT_DYNCREATE (CPartRoutePage, CPropertyPage)

CPartRoutePage:: CPartRoutePage (): CPropertyPage (CPartRoutePage:: IDD)

{

 // {{AFX_DATA_INIT (CPartRoutePage)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

CPartRoutePage:: ~CPartRoutePage ()

{

}

void CPartRoutePage:: DoDataExchange (CDataExchange* pDX)

{

CPropertyPage:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CPartRoutePage)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CPartRoutePage, CPropertyPage)

 // {{AFX_MSG_MAP (CPartRoutePage)

 // NOTE: the ClassWizard will add message map macros here

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /

 // CFindPartDlg dialog

class CFindPartDlg: public CDialog

{

 // Construction

public:

CFindPartDlg (CWnd* pParent = NULL); // standard constructor

 // Dialog Data

 // {{AFX_DATA (CFindPartDlg)

enum { IDD = IDD_FINDPART };

 // NOTE: the ClassWizard will add data members here

 // }}AFX_DATA

 // Overrides

 // ClassWizard generated virtual function overrides

 // {{AFX_VIRTUAL (CFindPartDlg)

protected:

virtual void DoDataExchange (CDataExchange* pDX); // DDX/DDV support

 // }}AFX_VIRTUAL

 // Implementation

protected:

 // Generated message map functions

 // {{AFX_MSG (CFindPartDlg)

virtual void OnOK ();

 // }}AFX_MSG

DECLARE_MESSAGE_MAP ()

};

CFindPartDlg:: CFindPartDlg (CWnd* pParent /*=NULL*/)

: CDialog (CFindPartDlg:: IDD, pParent)

{

 // {{AFX_DATA_INIT (CFindPartDlg)

 // NOTE: the ClassWizard will add member initialization here

 // }}AFX_DATA_INIT

}

void CFindPartDlg:: DoDataExchange (CDataExchange* pDX)

{

CDialog:: DoDataExchange (pDX);

 // {{AFX_DATA_MAP (CFindPartDlg)

 // NOTE: the ClassWizard will add DDX and DDV calls here

 // }}AFX_DATA_MAP

}

BEGIN_MESSAGE_MAP (CFindPartDlg, CDialog)

 // {{AFX_MSG_MAP (CFindPartDlg)

 // }}AFX_MSG_MAP

END_MESSAGE_MAP ()

void CFindPartDlg:: OnOK ()

{

 // TODO: Add extra validation here

 // считывание номера партии и изделия в

 // видимые для PartSheet переменные

CDialog:: OnOK ();

}

void CAngstremApp:: OnAppFindpart ()

{

 // TODO: Add your command handler code here

INT partNumber;

INT productNumber;

CFindPartDlg findPartDlg;

if (findPartDlg. DoModal () == IDOK)

{

 // Создание объекта блока диалога с вкладками

CPropertySheet partSheet ("Part");

 // Создание объекта для каждой вкладки

CPartProcessingPage partProcessingPage;

CPartProcessingsPage partProcessingsPage;

CPartRoutePage partRoutePage;

 // Добавление вкладок в блок диалога

partSheet. AddPage (&partProcessingPage);

partSheet. AddPage (&partProcessingsPage);

partSheet. AddPage (&partRoutePage);

partSheet. DoModal ();

}

}

 // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /


Информация о работе «Программа регистрации процесса производства для автоматизированной системы управления предприятием электронной промышленности»
Раздел: Информатика, программирование
Количество знаков с пробелами: 182348
Количество таблиц: 5
Количество изображений: 27

Похожие работы

Скачать
138680
12
12

... приведения к базовому узлу, метод удельных весов, метод учета затрат на единицу веса изделия, расчет себестоимости по статьям затрат. В данном проекте приводится расчет себестоимости разработки автоматизированной системы управления торговым предприятием. (АСУТП). АСУТП служит для ведения учета торговой деятельности в Интернет и на аукционе EBay. Из основных преимуществ перед конкурентами стоит ...

Скачать
47979
1
0

... — системы управления ресурсами предприятия), которые включили в себя планирование ресурсов предприятия для всех основных видов его деятельности. 2. Автоматизируемые системы управления торговыми предприятиями и их возможности Первые автоматизированные системы стали появляться в начале 80-х гг. XX в., они были написаны для среды DOS и являлись довольно примитивными. Они не были рассчитаны на ...

Скачать
37178
0
9

... требуемый температурный режим во всех зонах реактора и холодильника-оросителя. Опуская подробности физико-химических процессов получения активного печного углерода, затронем только технический и программный аспекты созданной АСУ ТП производства технического углерода. ТЕХНИЧЕСКИЙ АСПЕКТ СИСТЕМЫ При выборе технических средств перед разработчиками (фирма «Эталон ТКС») стояла задача подобрать ...

Скачать
78053
2
0

... и количеством пользователей от 20 до 150.«Гран-Док» - корпоративная версия («Единая система электронного документооборота и делопроизводства муниципальных структур управления административного округа») - единая система электронного документооборота и делопроизводства административного округа. Ее можно отнести к специализированным системам автоматизации делопроизводства и ...

0 комментариев


Наверх