Разработка программного обеспечения реального времени верхнего уровня для установки определения остаточного ресурса изделия
Анализ технологического процесса, требования к нему и определение основных этапов. Статическое моделирование: прецеденты для режима работы "опыт" и "анализ", диаграммы классов. Динамическое моделирование, его принципы и оценка полученных результатов.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курсовая работа |
Язык | русский |
Дата добавления | 15.12.2013 |
Размер файла | 1,4 M |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Размещено на http://www.allbest.ru/
КУРСОВАЯ РАБОТА
Разработка программного обеспечения реального времени верхнего уровня для установки определения остаточного ресурса изделия
Введение
В комплексно-автоматизированных предприятиях автоматически выполняются как основные технологические, так и вспомогательные операции. Освобождая персонал от выполнения самых трудоемких операций, комплексная автоматизация дает большой технико-экономический эффект.
Управление и контроль за работой комплексно-автоматизированного предприятия осуществляется централизованно из диспетчерского пункта. Однако при большом количестве управляемых объектов и контролируемых параметров диспетчер не в состоянии обеспечить выбор оптимального режима работы Автоматизация приводит к улучшению основных показателей эффективности производства: увеличению количества, улучшению качества и снижению себестоимости выпускаемой продукции, повышению производительности труда. Внедрение автоматических устройств обеспечивает высокое качество продукции, сокращение брака и отходов, уменьшение затрат сырья и энергии, уменьшение численности основных рабочих, удлинение сроков межремонтного пробега оборудования.
Развитие микроэлектроники и широкое применение ее изделий в промышленном производстве, в устройствах и системах управления самыми разнообразными объектами и процессами является в настоящее время одним из основных направлений научно-технического прогресса.
Использование микроэлектронных средств в управлении производственного назначения не только приводит повышению технико-экономических показателей изделий (стоимости, надежности, потребляемой мощности, качества продукции), но и придает им принципиально новые потребительские качества.
Основой проектируемого устройства является микроконтроллер. Применение микроконтроллеров в последнее время нашло широкое применение, так как он в своем составе содержит все необходимое для проектирования практически любой системы автоматического управления различными объектами (память, АЦП, таймера и так далее.). Использование микроконтроллеров в системах управления обеспечивает достижение высоких показателей эффективности при относительно низкой стоимости. Это объясняет массовое применение различных микроконтроллеров в самых различных областях промышленности. Более двух третей мирового рынка микропроцессорных средств составляют именно микроконтроллеры.
В данном курсовом проекте решается задача по автоматизации управления, и сбору, хранению, обработки данных установки определения остаточного ресурса изделия.
1. Анализ технологического процесса
В настоящее время известно несколько методов неразрушающего контроля эволюции дислокационных структур при усталостных испытаниях: акустические, по скорости распространения ультразвуковых волн, по скорости счёта сигналов акустической эмиссии и т.д., магнитные, по коэрцитивной силе, по изменению магнитного потока, намагниченности с помощью датчика Холла, по амплитуде сигналов акустической эмиссии, сопровождающей шумы Баркгаузена, оптические, по смещению линий интерференционной картины от лазерного излучения и т.д.
Физический метод неразрушающего контроля (или их совокупность), близкий к идеальному решению, должен удовлетворять следующим требованиям:
- неразрушающий контроль всех этапов эволюции дислокационных структур: однородного распределения дислокаций, ячеистой структуры, фрагментации, образования, роста и объединения микротрещин и т.д. в процессе эксплуатации образцов и изделий
- локальность контроля 10-4 -10-6 m;
- возможность определения плотности и характерных размеров ячеек, фрагментов, микротрещин с помощью локальных акустических или магнитных характеристик;
- определение изменения углов разориентировок ячеек, фрагментов в процессе эволюции дислокационных структур;
- определение долговечности и остаточного ресурса, основных локальных усталостных (предел выносливости) и прочностных (предел текучести) характеристик на уровне зерен (10-4 -10-5 m) и фрагментов
(10-6 m).
Однако ни один из вышеприведенных методов не удовлетворяет ни сейчас, ни в перспективе вышеуказанным требованиям. Ближе всего к идеальному решению находится неразрушающий ультразвуковой (у. з.) метод обратного рассеяния с помощью электромагнитного (ЭМА) и иммерсионного у.з. преобразователей на частотах заполнения 10-100 MHz.
В нашем случае применяется второй вариант, где пъезопреобразователь, работающий в совмещённом режиме излучения - приёма, позволяет получить распределение коэффициент затухания у. з. волн d a по глубине образца (до 10-1 m) и в конечном итоге построить акустическую кривую усталости (АКУ) - зависимость d a от числа циклов N (рис. 1.1).
Рисунок 1.1 - Зависимость коэффициента затухания ультразвуковых волн d a от числа циклов
моделирование прецедент технологический программный
Для этого разработана и опробована установка на базе испытательной машины УП50. Внешний вид установки изображен на рисунке 2.2. Устройство установки представлено на рисунке 2.3.
Рисунок 1.2 - Общий вид установки для усталостных испытаний стальных образцов с применением неразрушающего контроля
Рисунок 1.3 - Конструкция (схема) экспериментальной установки
Установка состоит из двух колеблющихся масс 2, установленных на пружинах 3, которые закреплены на основании 1. В одной из масс находится закреплённый на валу эксцентрик 6, который приводится во вращение двигателем 8 посредством гибкой связи 7. Скорость вращения вала двигателя регулируется реостатом 9. Исследуемый образец 5 крепится клиновым распором между массами. На испытуемый образец устанавливается локальная иммерсионная ванна 4, в которой крепится у.з. пъезопреобразователь. Габариты стола установки 850 x 1200 мм.
Образец подвергается циклическому знакопеременному чистому плоскому изгибу в диапазоне рабочих напряжений от предела выносливости до предела прочности данного материала образца.
В основе работы акустического блока установки лежит метод обратного рассеивания у. з. колебаний.
Для введения у. з. волн в образец использована локальная иммерсионная ванна с плоской поверхностью контакта 48x30 мм.
В качестве средства регистрации использован ультразвуковой дефектоскоп УД2-12 с комплектом преобразователей на 10 МГц. На этапе опытного образца установки перевод аналогового сигнала на экран монитора компьютера производится с помощью цифрового фотоаппарата. Для полупромышленных установок этот перевод можно произвести с помощью АЦП-плат российского или западного производства.
В качестве критерия остаточного ресурса использован критерий нулевого остаточного ресурса. Этот критерий связан с максимумом акустической кривой усталости при числе циклов Nmax, где начинается объединение микротрещин в магистральную трещину. При N >Nmax образец или деталь уже не подлежит восстановлению и может привести к аварии в реальной конструкции.
При N <Nmax деталь может быть восстановлена путём «залечивания» микротрещин с помощью ряда методов ОМД.
Объектом автоматизации является сама установка по определению остаточного ресурса изделия.
Автоматизируются такие стадии технологического процесса как:
- задание очередности скоростей работы установки;
- загрузка шаблона задания из файла;
- сбор и хранение данных с установки;
- работа с сохраненными данными.
Все эти стадии будут - проводится программным продуктом верхнего уровня, что увеличит работоспособность установки и анализ ее данных, т.к. раньше, надо было задавать поочередно каждую скорость, интенсивность работы установки и тем самым создавая большое время простоя установки. Также надо отметить, что сбор данных с установки ручной, что влечет в себе некие неудобства в сборе, обработке и хранении данных. Из этого всего следует, что автоматизация всех выше перечисленных стадий увеличит производительность установки, уменьшит трудоемкость на ее обслуживание и облегчит задачу регистрации и обработку данных с установки.
2. Статическое моделирование
2.1 Прецеденты
Имя прецедента: Отслеживание состояний программы.
Актер: Пользователь.
Предусловие: Память была очищена, переменные инициализируются.
Описание:
- После запуска программы таймер 1 вырабатывает событие с определенным интервалом. А обработчик этого события проверяет состояние программы.
- Если пользователь находится в режиме работы «опыт» то обработчик события таймера 1, показывает пользователю меню этого режима. А так же проверяет состояние создания файла базы данных, задание на проведение опыта. Если хоть один из этих пунктов не выполняется, то блокирует кнопку старта опыта.
Альтернатива:
- Если пользователь находится в режиме работы «Анализ» обработчик события таймера 1, показывает пользователю меню режима «Анализ». И проверяет, загружена ли база данных, если база данных загружена или импортирована из опыта, то разблокирует кнопки работы с базой данных.
Прецеденты для режима работы «опыт»
Имя прецедента: Загрузить, создать задание для установки.
Сводка: Пользователь загружает или задает задание для установки.
Актер: Пользователь.
Предусловие: Установка не работает, задание отсутствует.
Описание:
- Пользователь нажимает кнопку «загрузить задание», после чего открывается диалоговое окно для выбора файла задания.
- Пользователь выбирает файл задания, указывая имя и расположение файла программе, и нажимает кнопку «ок» обработчик события которой, открывает файл и выгружает задание из него в программное обеспечение.
Альтернативы:
- Если пользователь не может загрузить задание, либо у него нет подготовленного ранее задания, то он задает задание в ручную, заполняя таблицу задания.
- Если задание отсутствует то кнопка «старт» блокируется.
Постусловие:
- Задано задание для установки.
Имя прецедента: создать новый файл (новый тех процесс).
Сводка: Пользователь создает новый файл базы данных для проведения опыта.
Актер: Пользователь.
Предусловие: на установке не проводится опыт.
Описание:
- По нажатию кнопки «новый файл» обработчик события нажатия кнопки генерирует событие, которое открывает диалоговое окно «создания нового файла базы данных».
- В диалоговом окне «новый файл» пользователь выбирает одно из 2х расширений файла, и задает его имя, после чего нажимает кнопку «ок», обработчик события которой, создает файл базы данных с выбранным расширение и заданным именем.
Альтернативы:
- Если пользователь задал файл с одинаковым именем и расширением тогда пользователю генерируется сообщение о замене файла, где пользователь может заменить существующий файл, либо переименовать текущий.
- Если нет созданной базы данных для сохранения опыта, то кнопка старт блокируется.
Постусловие: создана база данных для сохранения опыта.
Имя прецедента: Запустить опыт.
Актеры: Пользователь.
Предусловие: Была создана база данных для записи в нее данных опыта, а так же получено задание для установки.
Описание:
- После нажатия кнопки «старт» обработчик события передает установке задание работы, разблокирует кнопки «стоп» и «пауза». Следующий шаг работы выше указанного события - это запуск таймера 2, который вырабатывает событие, которое определяет конец выполнения задания, записи данных с опыта в базу данных и передача последующего задания установке. Эта процедура повторяется до тех пор, пока установка не отработает все задания, после чего приводит установку в исходное состояние, сохраняет данные в базу данных и закрывает ее, после чего отключает таймер 2, и блокирует кнопки «старт», «пауза», «стоп».
Альтернатива:
- Была нажата кнопка «пауза», вследствие чего генерируется событие, которое останавливает работу установки, таймера 2 и запись данных с контролера в базу данных. Так же меняется надпись на кнопке «пауза» на «продолжить».
- После нажатия кнопки «продолжить» установка и все остальные элементы возвращаются в рабочее состояние.
- Если была нажата кнопка «стоп», то работа установки останавливается, а таймер записывает данные сохраненные до этого момента и время, прошедшее с начала задания до времени нажатия кнопки «стоп» и закрывает базу, а также разблокирует кнопку «очистить базу», и блокирует кнопки «старт», «пауза», «стоп».
Имя прецедента: Проверка подключения микро контролера.
Актеры: Пользователь
Предусловие: Программа была запущена, данные инициализируется.
- После загрузки программы в постоянном режиме считывает данные с микро контролера с помощью библиотеки LibUSB, инициализируются переменные настройки для входов выходов каналов USB на получение данных с контролера способом control, который представляет собой приём и передачу массивов данных по прерыванию.
- В момент проведения опыта передает данные задания установки, и считывает полученные данные с датчиков установки.
Альтернатива: Контролер отсоединён и ввод, вывод данных невозможен.
Постусловие: Проведение опыта и запись данных в файл.
Имя прецедента: Очистить базу данных.
Актеры: Пользователь.
Зависимость: «была нажата кнопка стоп»
Предусловие: Пользователя не удовлетворяет проведенный опыт, и он хочет очистить базу, для начала нового опыта на замену проведенному.
Описание:
- Пользователь нажал кнопку «очистить базу», обработчик события которой запустил окно диалога «об очищении базы данных». Если в диалоговом окне пользователь нажал кнопку «ок», генерируется событие очищения базы данных.
Альтернатива:
- Пользователь после запуска диалогового ока «очищения базы данных» передумал очищать базу, и нажал кнопку «отмена», вследствие чего данные не были стерты из базы.
Прецеденты для режима работы «анализ»
Имя прецедента: импорт базы данных с опыта.
Актер: Пользователь.
Предусловие: Был проведен опыт.
Описание:
- Пользователем была нажата клавиша «Текущая Б.Д.», обработчик которой разблокировал кнопки работы с базой данных.
Альтернатива: В случае ошибки импорта базы выдается окно с сообщением об ошибке.
Постусловие: была импортирована база только что проведенного опыта.
Имя прецедента: загрузка базы данных из старого опыта.
Актер: Пользователь.
Предусловие: Ранее были проведены опыты, и которые надо проанализировать.
Описание:
- По нажатию пользователем клавиши «Открыть», обработчик события кнопки открывает диалоговое окно для выбора файла базы данных, в котором пользователь непосредственно и выбирает файл нужного ему опыта. После выбора файла пользователь нажимает кнопку «ок», обработчик события открытия файла открывает файл с базой данных и позволят дальнейшую работу с базой данных.
Альтернатива:
- Пользователь не загрузил базу данных, либо загрузил поврежденный файл вследствие этого - база не была загружена, кнопки работы с базой не доступны.
Постусловие: Была загружена база данных со старого опыта.
Имя прецедента: Просмотр записей базы данных.
Актер: Пользователь.
Предусловие: Была загружена, импортирована база данных с данными опыта.
Описание:
- После загрузки, импорта базы, становится доступен режим работы, анализа полученных ранее данных. Здания, с которыми работала установка, загружаются в табличку заданий, где располагаются, так же как и задания в проведенном опыте.
- По нажатию клавиш «<» и «>» пользователь генерирует события, которые переключают записи в базе данных, что отображается в текстовом поле в виде: [количества записей/ текущая запись]. Данные выбранной записи извлекаются, и проектируется на графики дефектоскопа и датчика положения.
Альтернатива:
- Пользователь ввел в текстовое поле «количество записей / текущая», номер нужной ему записи, и нажал кнопку «ок», обработчик события которой проверил введенное значение на соответствие правильности ввода и если такая запись есть, то выдал ее значения на графики.
- Пользователь нажал кнопку «Общий», обработчик события которой, в разделах построения графиков дефектоскопа и датчика положения, построит общие графики всех записей.
Имя прецедента: Анализ базы данных.
Актер: Пользователь.
Зависимость: Была выбрана анализируемая запись.
Предусловие: Была загружена, импортирована база данных с данными опыта.
- Пользователь, анализируя графики, по которым перемещается с помощью зажатой правой клавишей мышки, просматривая при этом все фрагменты. По окончанию анализа записи пользователь записывает в текстовое поле записи выводы результата проведенного опыта. После чего нажимает клавишу «Сохранить», в результате чего обработчик события ищет в базе выбранную пользователем запись и сохраняет в нее сделанные пользователем выводы.
Альтернатива:
- Если в поле вывода к выбранной записи уже есть выводы, и они не удовлетворяют пользователя, то он может их редактировать, и по нажатию клавиши «Сохранить», в результате чего обработчик события ищет в базе выбранную пользователем запись и заменяет в ней сделанные ранее пользователем выводы.
Постусловие: Проведен анализ опыта, и сохранены выводы.
2.2 Диаграммы классов
Всего в программном коде используется 4 класса. Класс «Дефектоскоп», «Датчик положения», «База данных» и класс «Задание». Каждый из них является обычным классом, не содержащим в себе дружественные классы (т.е. не являются родительскими классами) и не являются дружественными относительно других классов. Экземпляры этих классов используются относительно технологических объектов и технологического процесса в целом для упрощения понимания программного кода и сокращения строк кода.
На рисунке 2.1 показана диаграмма класса «Дефектоскоп»:
Рисунок 2.1 - Диаграмма класса «Дефектоскоп»
На рисунке 2.2 показана диаграмма класса «Датчик положения»:
Рисунок 2.2 - Диаграмма класса «Датчик положения»
На рисунке 2.3 показана диаграмма класса «База данных»
Рисунок 2.3 - Диаграмма класса «База данных»
На рисунке 2.4 показана диаграмма класса «Задание».
Рисунок 2.4 - Диаграмма класса «Задание»
На диаграммах в первой строке написано название класса, во второй строке - свойства, а в третьей строке (если имеется) - функции класса.
Класс «Датчик положения» отвечает за принятие данных датчика положения с микроконтроллера.
Класс «Дефектоскоп» служит для принятия данных с пъезопреобразователя, и надстройку дефектоскопа.
Класс «База данных» служит для создания, хранения и обработки базы данных.
Класс «Задания» используется для загрузки задания, и передачи его на установку.
Далее представим статическую модель программного обеспечения, на которой явно просматриваются все отношения между актерами и прецедентами в системе управления. На статической модели приведены виды связей и отношений (один-к-одному, один-ко-многим). Таймер является и актером и прецедентом одновременно, т.к. управляет многими прецедентами, а сам в свою очередь запускается другим прецедентом.
На рисунке 2.5 приведена статическая модель программного обеспечения в двух режимах работы.
Рисунок 2.5 - Статическая модель программного обеспечения для установки определения остаточного ресурса изделия в двух режимах работы.
На рисунке 2.6 приведена статическая модель программного обеспечения в режиме работы «Опыт».
Рисунок 2.6 - Статическая модель программного обеспечения в режиме работы «опыт»
На рисунке 2.7 приведена статическая модель программного обеспечения в режиме работы «Анализ».
Рисунок 2.7 - Статическая модель программного обеспечения в режиме работы «Анализ»
3. Динамическое моделирование
3.1 Диаграммы взаимодействий
Диаграммы взаимодействий необходимы для того, чтобы рассмотреть программный алгоритм с точки зрения актеров и прецедентов, сущностей и интерфейсов.
Динамические зависимости представлены с помощью динамической модели, которая состоит из диаграмм кооперации и диаграмм состояний.
Диаграммы кооперации соответствуют прецедентам, описанным в разделе 2. На них изображаются объекты, прецеденты, в которых они участвуют, и сообщения, которыми они обмениваются.
Рассмотрим диаграмму коопераций для клиент-серверных прецедентов дежурного оператора.
Сначала рассмотрим прецедент общий для всех режимов. Он относится к типу клиент-сервер, причем клиентом является объект пользовательского интерфейса. Начнем с прецедента «Отслеживание состояний программы», (рис. 3.1):
S1.1: Оператор отсылает запрос на выбор одного из режимов работы программы.
S1.2: Выбранный режим работы с минимальным интервалом опрашивается событием таймера.
S1.3: передаются таймеру состояние выбранного режима, и состояние основных переменных.
S1.4: после чего таймер ведет проверку данных для выборного режима и отправляет интерфейсу программы соотносящиеся к нему пользовательское меню, и блокирует-разблокирует некоторые возможности программы в зависимости от ее состояния.
S1.5: Полученный интерфейс отправляется пользователю.
Рисунок 3.1 - Диаграмма кооперации для прецедента «Отслеживание состояний программы».
Далее рассмотрим диаграммы прецедентов для режима работы «Опыт».
На рисунке 3.2 изображена диаграмма для прецедента «Загрузить, создать задание для установки».
V1.1: Пользователь в интерфейсе режима «Опыт», нажимает «загрузить задание».
V1.1.1: пользователь задает задание в ручную.
V1.2: Открывается окно для загрузки файла.
V1.3: Пользователю предлагается выбрать файл.
V1.4: В открывшемся окне пользователь задает файл.
V1.5: Задание с файла передается в интерфейс.
V1.6: Полученное задание отображается пользователю.
На рисунке 3.3 изображена диаграмма для прецедента «Создать новый файл».
G1.1: Пользователь в интерфейсе режима «Опыт», нажимает «Новый файл».
G1.2: Открывается окно для создания файла.
G1.3: Пользователю предлагается создать файл.
G1.4: В открывшемся окне пользователь задает имя и расширение файла.
Рисунок 3.2 - Диаграмма кооперации для прецедента «Загрузить, создать задание для установки»
G1.5: Создается файл и передается в интерфейс пользователя для дальнейшей работы.
G1.6: Если был создан файл, и задано задание, то интерфейс выводит информацию о готовности программы выполнить опыт.
Рисунок 3.3 - Диаграмма кооперации для прецедента «Создать новый файл»
На рисунке 3.4 изображена диаграмма для прецедента «Запустить опыт». Надо отметить, что этот прецедент работает в клиент-серверном режиме.
С1.1: Пользователь нажимает кнопку «Старт».
С1.2.1: Передача данных задания выполнение опыта «Таймеру 2».
С1.2.2: Передача данных задания на установку.
С1.3: Опрос «Таймером 2» установки.
С1.4: Передача «Таймеру 2» данных с установки.
С1.5: Передача полученных с установки данных на графики интерфейса.
С1.6.1: Проверка «Таймером 1», нажатия клавиш «Пауза», «Стоп»
Была нажата клавиша «Пауза».
С1.6.2: Отправка информации «Таймеру 1» об нажатии кнопки.
С1.6.3.1: Отсылает запрос на остановку «Таймера 2».
С1.6.3.2: Запрос на остановку установки.
Была нажата клавиша «Продолжить».
С1.6.4.1: Отсылает запрос на возобновление работы «Таймера 2».
С1.6.4.2: Запрос на возобновление работы установки.
Была нажата клавиша «Стоп».
С1.6.5.1: Запрос на запись сохраненных на данный момент данных в файл.
С1.6.5.2: Отсылает запрос на остановку «Таймера 2».
С1.6.5.3: Запрос на остановку установки.
С1.7: По окончанию задания запись полученных данных в файл.
С1.8: Информация об окончании выполнения задания.
На рисунке 3.5 изображена диаграмма для прецедента «Проверка подключения микро контролера».
U1.1: Пользователь запускает опыт.
U1.2: Данные отсылаются микро контролеру.
U1.3: Данные считываются с контролера.
U1.4: Считанные данные отображаются пользователю.
Рисунок 3.5 - Диаграмма кооперации для прецедента «Проверка подключения микро контролера»
На рисунке 3.6 изображена диаграмма для прецедента «Очистить базу данных».
F1.1: Пользователь отсылает запрос на очищение базы данных.
F1.2: Производится очистка базы данных.
F1.3: пользователь информируется что База данных успешно очищена.
Рассмотрим диаграммы прецедентов для режима работы «Анализ».
На рисунке 3.6 изображена диаграмма для прецедента «Импорт базы данных с опыта».
Рисунок 3.5 - Диаграмма кооперации для прецедента «Очистить базу данных»
Q1.1: Пользователь нажал кнопку «Текущая Б. Д».
Q1.2: Выдача данных Б.Д. на экран.
Рисунок 3.6 - Диаграмма кооперации для прецедента «Импорт базы данных с опыта»
Прецедент «загрузка базы данных из старого опыта» не рассматривается, так как он аналогичен прецеденту «Загрузить, создать задание для установки».
На рисунке 3.7 изображена диаграмма для прецедента «Просмотр записей базы данных».
Z1.1: Пользователь отдает запрос на выбор записи.
Z1.2: Базе данных отсылается запрос на выдачу указанной записи.
Z1.3: База данных выдает данные выбранной записи.
Z1.4: Полученные данные выводятся на экран.
Рисунок 3.7 - Диаграмма кооперации для прецедента «Просмотр записей базы данных»
На рисунке 3.8 изображена диаграмма для прецедента «Анализ базы данных».
W1.1: Пользователь сохраняет сделанные им по просмотренной записи выводы.
W1.2: Данные вывода сохраняются в поле выводов указанной записи.
W1.3: Данные в из записи выводятся на экран.
W1.4: Пользователю выдается сообщение что данные успешно сохранены.
Рассмотрим диаграмму состояний программы.
Диаграмма состояний программы включает в себя две ортогональные диаграммы: «Опыт» и «Анализ». Они представлены в виде над состояний, на диаграмме верхнего уровня, и разделены пунктирной линией (рис. 3.8). В любой момент времени программа находится в одном из под состояний состояния «Опыт», которое соответствует текущей стадии проведения опыта на данной установке, и в под состояний состояния «Анализ», когда производятся выводы по проведенному опыту. Сказанное не означает, что внутри программы имеется какой-то параллелизм, просто так удобнее моделировать эти относительно независимые события.
Рисунок 3.7 - Диаграмма кооперации для прецедента «Анализ базы данных»
Рисунок 3.3 - Диаграмма состояний программы
4. Разработка визуальных компонентов
Визуальный интерфейс программного обеспечения представляет собой две вкладки режимов работы «опыт» и «анализ».
В режиме «опыт» производится настройка и выполнение опыта, который сопровождается выводам данных на графики дефектоскопа и датчика положения, а также сохранением их в базу данных.
В режиме «анализ» производится просмотр выполненного опыта, что позволяет просмотреть более детально данные проведенного опыта и сделать по ним выводы.
Панель управления режима «Опыт» представлена в виде элементов Button, MainMenu, StringGrid, CheckBox и Char. После нажатия кнопки «старт» происходит передача данных работы установке, и считываются данные с датчиков, которые в дальнейшем выводятся на графики.
Панель управления режима «Анализ» представлена в виде элементов Button, MainMenu, StringGrid, Edit, Memo и Char. После загрузки базы данных, с помощью кнопок управления поочередно просматриваются данные каждой записи, которые выводятся на графики. После анализа каждой записи по ней делаются выводы, которые сохраняются по нажатию кнопки «сохранить».
Заключение
В процессе исследования «стенда определения остаточного ресурса изделия», выявил недостатки существующей установки. Имеющийся стенд требовал большого объема ручного труда по сбору и анализу показаний от датчиков. Поэтому было принято решение создать новую цифровую систему управления.
Программное обеспечение было написано на языке высокого уровня Delphi 7, а также языка разработки структуры UML.
В ходе разработки было программное обеспечение верхнего уровня, которое поддерживает связь с П.О. нижнего уровня по протоколу USB.
Список использованной литературы
1. Буч Г. Объектно-ориентированный анализ и проектирование с примерами приложений на C++. Пер. с англ. М. Бином, СП. 1998. 115 с.
2. Буч Г., Рамбо Д., Джекобсон А. Язык UML. Руководство пользователя. Пер. с англ. М.: ДМК. 1995 185 с.
3. Гома Х. UML проектирование систем реального времени, параллельных и распределенных приложений. Пер. с англ. - М. ДМК Пресс, 2011. - 704 с.
Приложение
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls, libusb, ExtCtrls, ComCtrls, TeeProcs, TeEngine, Chart, Series, FMTBcd, DBXpress, ADODB, DB, SqlExpr, SQLite3, SQLiteTable3, Grids, ValEdit, unit2, Simoreg, XPMan, ComObj, DBCtrls, ExtDlgs, Buttons, Menus, jpeg;
type
TMainForm = class(TForm)
private
{Private declarations}
public
udev: pusb_dev_handle;
conn_res: integer;
sldb: TSQLiteDatabase;
last_select: Integer;
rslt: String;
procedure set_engine_speed (value: Double);
procedure UpdateDefscope();
end;
var
MainForm: TMainForm;
danie_D_Poloj, danie_Defektoskopa1, danie_Defektoskopa2, NameFileBase, Danie_Do_P_S2, Danie_Do_P_S1_1, Danie_Do_P_S1_2: String;
fla, bila_najata_pauza, Pauza_Schitivania_dannih: Integer;
ReqStep: Boolean;
mins_past, current_interval, ReqAddress, nach, kon: Integer;
ReqAddrIdx: Byte;
Counter: Integer = 0;
Received_count: Integer = 0;
state: Integer = 1;
counter1: integer = 0;
implementation
uses StrUtils;
{$R *.dfm}
const
UART_EP = $83;
IN_EP = $82;
OUT_EP = $02;
function USBDeviceOpen (var devhandle:pusb_dev_handle; VID, PID: word): bool;
var
bus: pusb_bus;
dev: pusb_device;
begin
usb_init;
usb_find_busses;
usb_find_devices;
bus:= usb_get_busses;
Result:= false;
dev:=nil;
while Assigned(bus) do
begin
dev:= bus^.devices;
while Assigned(dev) do
begin begin
devhandle:= usb_open(dev);
Result:= true;
end;
dev:= dev^.next; end;
bus:= bus^.next;
end; end;
procedure TMainForm. Timer1Timer (Sender: TObject);
var
res_read: Integer;
Buffer: array [0..127] of byte;
str: String;
begin
Received_count:= 0;
ReqStep:=True; end;
procedure TMainForm.onIdle (Sender: TObject; var done: Boolean);
var
res_read: Integer;
Buffer: array [0..127] of byte;
str, str_time: String;
value: Double;
i, j: Integer;
s:string;
id:int64;
F: TFileStream;
begin
if (conn_res <> 0) or not Assigned(udev) then
Exit;
if (ReqStep) then
begin
ReqAddrIdx:=ReqAddrIdx+1;
if ReqAddrIdx>5 then ReqAddrIdx:=0;
case ReqAddrIdx of
0: ReqAddress:=$83;
1: ReqAddress:=$85;
2: ReqAddress:=$88;
3: ReqAddress:=$8B;
4: ReqAddress:=$8E;
5: ReqAddress:=$8F;
end;
res_read:= usb_bulk_read (udev, ReqAddress, @Buffer, 48, 10);
SetString (str, PChar(@Buffer), res_read);
ReqStep:=False;
end;
res_read:= usb_bulk_read (udev, $82, @Buffer, 128, 10);
if (res_read >= 0) then
begin
SetString (str, PChar(@Buffer), res_read);
Received_count:= Received_count + res_read;
value:= PLONGINT(@Buffer)^*47408.0/1000.0 /1000;
str_time:= TimeToStr(Time);
str:= IntToStr (PLONGINT(@Buffer)^);
if (value<200) then
begin
if (Pauza_Schitivania_dannih=0) then
begin
danie_D_Poloj:=danie_D_Poloj+FloatToStr(value)+', ';
end;
counter1:= counter1 + 1;
Series2. AddXY (counter1, value); end;
if chkRunning. Checked then
begin
Chart2. BottomAxis. Maximum:= counter1;
Chart2. BottomAxis. Minimum:= Chart2. BottomAxis. Maximum - 400;
end; end;
done:= True; end;
procedure TMainForm. FormCreate (Sender: TObject);
var
res: Integer;
begin
N7. Enabled:=False;
N8. Enabled:=False;
N9. Enabled:=False;
pgcUnits. Pages[1].TabVisible:=false;
pgcUnits. Pages[2].TabVisible:=false;
fla:=0;
Pauza_Schitivania_dannih:=1;
bila_najata_pauza:=0;
last_select:= -1;
StringGrid1. Cells [1, 0]:= 'Время';
StringGrid1. Cells [2, 0]:= 'Интенсивность';
StringGrid2. Cells [0, 0]:= 'Время';
StringGrid2. Cells [1, 0]:= 'Интенс.';
StringGrid1. Cells [1, 1]:= '5';
StringGrid1. Cells [2, 1]:= '100';
StringGrid1. Cells [1, 2]:= '5';
StringGrid1. Cells [2, 2]:= '200';
Application. OnIdle:= MainForm.onIdle;
if USBDeviceOpen (udev,$C251, $1307) = true then
begin
res:= usb_set_configuration (udev, 1);
if res = 0 then
begin
conn_res:= usb_claim_interface (udev, 0);
if conn_res = 0 then
begin
MainForm. Caption:= MainForm. Caption + ' - Connection OK';
end; end; end;
Series2. Clear;
end;
procedure TMainForm. FormDestroy (Sender: TObject);
begin
if Assigned(udev) then
begin
usb_release_interface (udev, 0);
usb_close(udev); end;
sldb. Free; end;
function string_to_hex (str:string): String;
var
res_str: String;
i: Integer;
begin
for i:= 1 to length(str) do
begin
res_str:= res_str + format ('%.2x ', [Ord (str[i])]);
end;
result:= res_str; end;
procedure TMainForm. Button3Click (Sender: TObject);
var
res, res_read: Integer;
Buffer: array [0..127] of byte;
Buffer2: word;
val: Integer;
str: String;
i, j: Integer;
begin
for i:= 1 to 1 do
begin
val:= Random(20);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 0, val, 0, @Buffer2, 2, 100);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 12, j, 0, @Buffer2, 2, 100);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 13, j, 0, @Buffer2, 2, 100);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 14, j, 0, @Buffer2, 2, 100);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 15, j, 0, @Buffer2, 2, 100);
for j:= 1 to 2 do
begin
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_VENDOR or USB_ENDPOINT_IN, 17, Counter, 0, @Buffer, 2, 100);
if (res > 0) then
begin
SetString (str, PChar(@Buffer), res);
end; end; end; end;
procedure TMainForm.set_engine_speed (value: Double);
var
pos: double;
val, res: Integer;
Buffer2: Smallint;
simoreg_thread: TSimoreg;
begin
pos:= value;
Label4. Caption:= Format (' % 3f', [pos]);
val:= round (pos * 1500);
if not Assigned(udev) then
exit;
simoreg_thread:= TSimoreg. Create(True);
simoreg_thread.udev:= udev;
simoreg_thread.main_form:=Self;
simoreg_thread. EngineSpeed_Task:= value;
simoreg_thread. Resume; end;
procedure TMainForm. TrackBar1Change (Sender: TObject);
var
simoreg_thread: TSimoreg;
begin
simoreg_thread:= TSimoreg. Create(True);
simoreg_thread.udev:= udev;
simoreg_thread.main_form:=Self;
simoreg_thread. Resume; end;
procedure TMainForm. ListBox1DblClick (Sender: TObject);
var
str: String;
sltb:TSQLiteTable;
i, j:integer;
begin
Series1. Clear;
for j:= 10 to 1000 do
begin
danie_Defektoskopa1:=danie_Defektoskopa1+IntToStr (byte(str[j]))+', ';
danie_Defektoskopa2:=danie_Defektoskopa2+ IntToStr(j)+', ';
Series1. AddXY (j, byte (str[j]));
end; end;
procedure TMainForm. ListBox1KeyPress (Sender: TObject; var Key: Char);
begin
if key = #13 then
begin
ListBox1DblClick(Sender);
end; end;
procedure TMainForm. StringGrid1GetEditText (Sender: TObject; ACol, ARow: Integer; var Value: String);
Begin Value:= StringGrid1. Cells [Acol, ARow]; end;
procedure TMainForm. StringGrid1KeyDown (Sender: TObject; var Key: Word;
Shift: TShiftState);
var
i: Integer;
begin
if (Key = 46) and (last_select >= 0) then
begin
if (state >= last_select) then
exit;
if (last_select = 0) or (StringGrid1. RowCount < 3) then
exit;
if (last_select <= StringGrid1. RowCount-2) then
for i:= last_select to StringGrid1. RowCount-2 do
StringGrid1. Rows[i]:= StringGrid1. Rows [i+1];
StringGrid1. Cells [StringGrid1. RowCount-1, 1]:= «;
StringGrid1. Cells [StringGrid1. RowCount-1, 2]:= «;
StringGrid1. RowCount:= StringGrid1. RowCount - 1;
end;
if (Key = 45) and (last_select >= 0) then // Insert
begin
StringGrid1. RowCount:= StringGrid1. RowCount + 1;
for i:= StringGrid1. RowCount-1 downto last_select+1 do
StringGrid1. Rows[i]:= StringGrid1. Rows [i-1];
StringGrid1. Cells [1, last_select]:= «;
StringGrid1. Cells [2, last_select]:= «;
end; end;
procedure TMainForm. StringGrid1SelectCell (Sender: TObject; ACol, ARow: Integer; var CanSelect: Boolean);
begin last_select:= ARow; end;
procedure TMainForm. StringGrid1SetEditText (Sender: TObject; ACol, ARow: Integer; const Value: String);
begin
if ARow = StringGrid1. RowCount - 1 then
begin
if (Value <> «) then
StringGrid1. RowCount:= StringGrid1. RowCount + 1;
end; end;
procedure TMainForm. Button7Click (Sender: TObject);
var
i: Integer;
Pictures: TSQLiteDatabase;
SQLite_table: TSQLiteTable;
begin
Button18. Enabled:= true;
Button6. Enabled:=false;
Button7. Enabled:=false;
Pictures:=TSQLiteDatabase. Create(NameFileBase);
Pictures. ExecSQL ('INSERT INTO pics (Datchik_Polojenia, vremia, intensivnost) VALUES («'+danie_D_Poloj+'», '+StringGrid1. Cells [1, state]+', '+StringGrid1. Cells [2, state]+ ')');
Pictures. Destroy;
state:= 1;
current_interval:= 0;
Timer_minute. Enabled:= False;
mins_past:= 0;
for i:= 1 to StringGrid1. RowCount do
begin
StringGrid1. Cells [0, i]:= «;
end;
set_engine_speed(0); end;
procedure TMainForm. Timer_minuteTimer (Sender: TObject);
var
Pictures: TSQLiteDatabase;
SQLite_table: TSQLiteTable;
begin
Pictures:=TSQLiteDatabase. Create(NameFileBase);
mins_past:= mins_past + 1;
if current_interval <= mins_past then
begin
Pictures. ExecSQL ('INSERT INTO pics (Datchik_Polojenia, vremia, intensivnost, danie_Defektoskopa1, danie_Defektoskopa2) VALUES («'+danie_D_Poloj+'», '+StringGrid1. Cells [1, state]+', '+StringGrid1. Cells [2, state]+', «'+danie_Defektoskopa1+'», «'+danie_Defektoskopa2+'»)');
danie_D_Poloj:='';
danie_Defektoskopa1:='';
danie_Defektoskopa2:='';
Pauza_Schitivania_dannih:=1;
mins_past:= 0;
StringGrid1. Cells [0, state]:= 'Готово';
state:= state + 1;
if (state >= StringGrid1. RowCount) or
(StringGrid1. Cells [1, state] = «) then
begin
state:= 1;
current_interval:= 0;
Timer_minute. Enabled:= False;
mins_past:= 0;
set_engine_speed(0);
Pictures. Destroy;
Button5. Enabled:=False;
Button6. Enabled:=False;
Button7. Enabled:=False;
Button18. Enabled:=True;
exit; end;
Pauza_Schitivania_dannih:=0;
StringGrid1. Cells [0, state]:= '->';
set_engine_speed (StrToInt(StringGrid1. Cells [2, state])/1500);
current_interval:= StrToInt (StringGrid1. Cells [1, state]);
end; end;
procedure TMainForm. Button5Click (Sender: TObject);
var
i: Integer;
Pictures: TSQLiteDatabase;
SQLite_table: TSQLiteTable;
begin
Button5. Caption:= 'Старт';
Button6. Enabled:= true;
Button7. Enabled:= true;
Button5. Enabled:=false;
Pictures:=TSQLiteDatabase. Create(NameFileBase);
try
if not Pictures. TableExists('pics') then
begin
Pictures. ExecSQL ('CREATE TABLE pics (id INTEGER PRIMARY KEY AUTOINCREMENT, Datchik_Polojenia TEXT, vremia int, intensivnost int, vivod text, danie_Defektoskopa1 text, danie_Defektoskopa2 text)');
end;
except
MessageBox (0,'неудача', 'ошибка', MB_OK+MB_ICONERROR);
Application. Terminate;
end;
if (bila_najata_pauza=0) then
danie_D_Poloj:=Danie_Do_P_S2;
Pauza_Schitivania_dannih:=0;
for i:= 1 to StringGrid1. RowCount do
begin
StringGrid1. Cells [0, i]:= «;
end;
Timer_minute. Enabled:= True;
current_interval:= StrToInt (StringGrid1. Cells [1, state]);
StringGrid1. Cells [0, state]:= '->';
set_engine_speed (StrToInt(StringGrid1. Cells [2, state])/1500);
end;
procedure TMainForm. Button6Click (Sender: TObject);
begin
Button5. Caption:= 'продолжить';
Button5. Enabled:=true;
Button6. Enabled:=False;
Button7. Enabled:=false;
Timer_minute. Enabled:= False;
bila_najata_pauza:=1;
Pauza_Schitivania_dannih:=1;
Danie_Do_P_S2:=danie_D_Poloj;
set_engine_speed(0); end;
procedure TMainForm. Button2Click (Sender: TObject);
var
def_thread: Defscope;
begin
def_thread:= Defscope. Create(True);
def_thread.udev:= udev;
def_thread.main_form:= self;
def_thread. Resume; end;
procedure TMainForm. UpdateDefscope();
var
i: Integer;
stream: TStream;
str: String;
begin
Series1. Clear;
for i:= 10 to Length(rslt) do
begin
Series1. AddXY (i, Byte (rslt[i])); {показания на дифекто скоп}
end;
Exit;
stream:= TStringStream.create(rslt);
str:= TimeToStr(Time);
sldb. ExecSQL ('insert into Defscope (TIME) values («'+str+'»)');
sldb. UpdateBlob ('UPDATE Defscope SET DATA =? WHERE ID = «' + IntToStr (sldb. GetLastInsertRowID()) +'» ', stream);
stream. Free; end;
procedure TMainForm. Button8Click (Sender: TObject);
var
Buffer2: Integer;
res: Integer;
begin
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 25, 0, 0, @Buffer2, 4, 100); end;
procedure TMainForm. Button9Click (Sender: TObject);
var
Buffer2: Integer;
res: Integer;
begin
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 25, 0, 0, @Buffer2, 4, 100); end;
procedure TMainForm. Button10Click (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
li:integer;
begin
if OpenDialog2. Execute then
begin
Pictures:=TSQLiteDatabase. Create (ExtractFileName(OpenDialog2. FileName));
try
except
MessageBox (0,'неудача', 'ошибка', MB_OK+MB_ICONERROR);
Application. Terminate;
end; end;
SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia FROM pics');
for li:= 0 to SQLite_table. Count - 1 do
begin
SQLite_table. Next;
end;
SQLite_table. Destroy; end;
procedure TMainForm. Button11Click (Sender: TObject);
var
Excel: Variant;
WBk, ListAktivn: OleVariant;
i:integer;
begin
Excel:= CreateOleObject ('Excel. Application');
if OpenDialog1. Execute then
begin
WBk:= Excel. WorkBooks. Open (OpenDialog1. FileName);
ListAktivn:=Excel. ActiveWorkbook. ActiveSheet;
StringGrid1. RowCount:=ListAktivn. UsedRange. Rows. Count;
for I:= 2 to ListAktivn. UsedRange. Rows. Count do
begin
StringGrid1. Cells [1, I-1]:=Excel. Range ['B'+inttostr(I)];
StringGrid1. Cells [2, I-1]:=Excel. Range ['C'+inttostr(I)];
end;
Excel. ActiveWorkbook. Close;
Excel. Application. Quit;
bila_najata_pauza:=0;
fla:=0;
danie_D_Poloj:='';
end; end;
procedure TMainForm. Button13Click (Sender: TObject);
var
s, konec: String;
Pictures: TSQLiteDatabase;
SQLite_table: TSQLiteTable;
begin
if (fla=0) then
begin
NameFileBase:=InputBox ('Пользователь', 'Введите название БД латинскими буквами', 'opit')+'.sqlite';
fla:=1;
DeleteFile(NameFileBase);
end;
DeleteFile(NameFileBase);
Pictures:=TSQLiteDatabase. Create(NameFileBase);
try
if not Pictures. TableExists('pics') then
begin
Pictures. ExecSQL ('CREATE TABLE pics (id INTEGER PRIMARY KEY AUTOINCREMENT, Datchik_Polojenia TEXT)');
end;
except
MessageBox (0,'неудача', 'ошибка', MB_OK+MB_ICONERROR);
Application. Terminate;
end;
Pictures. ExecSQL ('INSERT INTO pics (Datchik_Polojenia) VALUES («'+danie_D_Poloj+'@'+'»)');
Pictures. Destroy;
Pictures:=TSQLiteDatabase. Create(NameFileBase); SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia FROM pics');
Pictures. Destroy; end;
procedure TMainForm. OpenbClick (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
li:integer;
begin
if OpenDialog2. Execute then
begin
NameFileBase:=ExtractFileName (OpenDialog2. FileName);
Pictures:=TSQLiteDatabase. Create(NameFileBase);
try
except
MessageBox (0,'неудача', 'ошибка', MB_OK+MB_ICONERROR);
Application. Terminate;
end;
SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia, vremia, intensivnost FROM pics');
Edit1. Text:=IntToStr (SQLite_table. Count)+'\0';
StringGrid2. RowCount:= SQLite_table. Count+1;
for li:= 0 to SQLite_table. Count - 1 do
begin
danie_D_Poloj:=danie_D_Poloj+SQLite_table. FieldAsString(0);
StringGrid2. Cells [0, li+1]:= SQLite_table. FieldAsString(1);
StringGrid2. Cells [1, li+1]:= SQLite_table. FieldAsString(2);
SQLite_table. Next;
end;
SQLite_table. Destroy;
Pictures. Destroy;
end; end;
procedure TMainForm. Button14Click (Sender: TObject);
var
kap, kn, i, j:integer;
zn: string;
begin
zn:='';
j:=0;
i:=1;
Edit1. Text:='all';
Series3. Clear;
while (i<Length (danie_D_Poloj) - 1) do
begin
if (danie_D_Poloj[i]=', ') then
begin
Series3. AddXY (j, StrToInt(zn));
j:=j+1;
zn:='';
i:=i+1; end;
zn:=zn+danie_D_Poloj[i];
i:=i+1;
end; end;
procedure TMainForm. SpeedButton1Click (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
i, j, li:integer;
zn, str: string;
begin
i:=1;
j:=0;
str:='';
if (Edit1. Text='all') then Edit1. Text:= IntToStr (SQLite_table. Count)+'\0'; Pictures:=TSQLiteDatabase. Create(NameFileBase); SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia, vivod FROM pics');
if (StrToInt(ExtractFileName (Edit1. Text))>0) then
begin
Edit1. Text:=IntToStr (SQLite_table. Count)+'\'+IntToStr (StrToInt(ExtractFileName (Edit1. Text)) - 1);
end;
for li:= 0 to SQLite_table. Count - 1 do
begin
if((li+1)=StrToInt (ExtractFileName(Edit1. Text))) then
begin
str:=SQLite_table. FieldAsString(0);
Memo3. Text:= SQLite_table. FieldAsString(1); end;
SQLite_table. Next; end;
SQLite_table. Destroy;
Pictures. Destroy;
Series3. Clear;
if (StrToInt(ExtractFileName (Edit1. Text))>0) then
begin
while (i<Length(str)) do
begin
if (str[i]=', ') then
begin
Series3. AddXY (j, StrToInt(zn));
j:=j+1;
zn:='';
i:=i+1;
end;
zn:=zn+str[i];
i:=i+1;
end; end; end;
procedure TMainForm. SpeedButton2Click (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
i, j, li:integer;
zn, str: string;
begin
i:=1;
j:=0;
str:='';
if (Edit1. Text='all') then Edit1. Text:= IntToStr (SQLite_table. Count)+'\0'; Pictures:=TSQLiteDatabase. Create(NameFileBase); SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia, vivod FROM pics');
if (StrToInt(ExtractFileName (Edit1. Text))<(SQLite_table. Count)) then
begin
Edit1. Text:=IntToStr (SQLite_table. Count)+'\'+IntToStr (StrToInt(ExtractFileName (Edit1. Text))+1);
end;
for li:= 0 to SQLite_table. Count - 1 do
begin
if((li+1)=StrToInt (ExtractFileName(Edit1. Text))) then
begin
str:=SQLite_table. FieldAsString(0);
Memo3. Text:= SQLite_table. FieldAsString(1); end;
SQLite_table. Next; end;
SQLite_table. Destroy;
Pictures. Destroy;
Series3. Clear;
while (i<Length(str)) do
begin
if (str[i]=', ') then
begin
Series3. AddXY (j, StrToInt(zn));
j:=j+1;
zn:='';
i:=i+1;
end;
zn:=zn+str[i];
i:=i+1; end; end;
procedure TMainForm. Button15Click (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
i, j, li:integer;
zn, str: string;
begin
i:=1;
j:=0;
str:='';
Pictures:=TSQLiteDatabase. Create(NameFileBase); SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia FROM pics');
if (StrToInt(Edit1. Text)<(SQLite_table. Count)) then
begin
Edit1. Text:= IntToStr (SQLite_table. Count)+'\'+Edit1. Text;
End else begin
Edit1. Text:=IntToStr (SQLite_table. Count)+'\'+IntToStr (SQLite_table. Count); end;
for li:= 0 to SQLite_table. Count - 1 do
begin
if((li+1)=StrToInt (ExtractFileName(Edit1. Text))) then
begin
str:=SQLite_table. FieldAsString(0);
end;
SQLite_table. Next;
end;
SQLite_table. Destroy;
Pictures. Destroy;
Series3. Clear;
if (StrToInt(ExtractFileName (Edit1. Text))>0) then
begin
while (i<Length(str)) do
begin
if (str[i]=', ') then
begin
Series3. AddXY (j, StrToInt(zn));
j:=j+1;
zn:='';
i:=i+1;
end;
zn:=zn+str[i];
i:=i+1;
end; end; end;
procedure TMainForm. Button16Click (Sender: TObject);
begin
if SaveDialog1. Execute then
begin
NameFileBase:=SaveDialog1. FileName;
fla:=1;
Button5. Enabled:=true;
N7. Enabled:=true;
DeleteFile(NameFileBase);
End else begin
SaveDialog1. Free; end; end;
procedure TMainForm. TekusiaBDClick (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
li:integer;
begin
if (NameFileBase<>'') then
begin
Pictures:=TSQLiteDatabase. Create(NameFileBase);
try
except
MessageBox (0,'неудача', 'ошибка', MB_OK+MB_ICONERROR);
Application. Terminate;
end;
SQLite_table:=Pictures. GetTable ('SELECT Datchik_Polojenia, vremia, intensivnost FROM pics');
Edit1. Text:=IntToStr (SQLite_table. Count)+'\0';
StringGrid2. RowCount:= SQLite_table. Count+1;
for li:= 0 to SQLite_table. Count - 1 do
begin
danie_D_Poloj:=danie_D_Poloj+SQLite_table. FieldAsString(0);
StringGrid2. Cells [0, li+1]:= SQLite_table. FieldAsString(1);
StringGrid2. Cells [1, li+1]:= SQLite_table. FieldAsString(2);
SQLite_table. Next; end;
SQLite_table. Destroy;
Pictures. Destroy;
end else begin
MessageBox (0,'Извените, при данном запуске программы в не создавали базы данных, пожайлуста загрузите созданную рание, или создайте новую базу', 'Ошибка', MB_OK+MB_ICONERROR); end; end;
procedure TMainForm. SavebClick (Sender: TObject);
var
SQLite_table: TSQLiteTable;
Pictures: TSQLiteDatabase;
i, j, li:integer;
zn, str: string;
begin
if (NameFileBase<>'') then
begin
if (StrToInt (ExtractFileName(Edit1. Text))>0) then
begin
Pictures:=TSQLiteDatabase. Create(NameFileBase);
Pictures. ExecSQL ('UPDATE pics SET vivod = «'+Memo3. Text+'» WHERE id='+ExtractFileName (Edit1. Text));
Pictures. Destroy;
end else begin
ShowMessage ('Вы можете сохранять выводы только на активные фрагменты графика');
end; end else begin
MessageBox (0,'Извените, база данных не загружена!!!', 'Ошибка', MB_OK+MB_ICONERROR); end; end;
procedure TMainForm. Timer2Timer (Sender: TObject);
begin
StatusBar1. Panels[1].Text:=' '+DateToStr(now)+' '+TimeToStr(now);
if (NameFileBase<>'') then
begin
TekusiaBD. Enabled:=true;
N3. Enabled:=true;
SpeedButton1. Enabled:=true;
SpeedButton2. Enabled:=true;
Button14. Enabled:=true;
Button15. Enabled:=true; end else begin
SpeedButton1. Enabled:=false;
SpeedButton2. Enabled:=false;
Button14. Enabled:=false;
Button15. Enabled:=false;
TekusiaBD. Enabled:=false;
N3. Enabled:=false; end;
if (pgcUnits. Pages[0].CanFocus=true) then
begin
N1. Visible:=true;
afbk1. Visible:=false; end else
begin
N1. Visible:=false;
afbk1. Visible:=true; end; end;
procedure TMainForm. Button18Click (Sender: TObject);
begin
DeleteFile(NameFileBase);
Button5. Enabled:=true;
Button18. Enabled:=false;
end; end.
unit Unit2;
interface
uses
Classes, LibUSB;
type
Defscope = class(TThread)
private
{Private declarations}
protected
procedure Execute; override;
public
udev: pusb_dev_handle;
main_form: TObject;
len400ms: Boolean;
procedure UpdateDefscope(); end;
implementation
uses Unit1, sysutils;
procedure Defscope. Execute;
var
i, res, res_read: Integer;
Buffer: array [0..1500] of byte;
Buffer2: word;
str: String;
poked: Boolean;
myrslt: String;
begin
if not Assigned(udev) then Exit;
if len400ms then
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 30, 0, 0, @Buffer2, 2, 50) else
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 20, 0, 0, @Buffer2, 2, 50);
res_read:= usb_bulk_read (udev, $81, @Buffer, 100, 50);
if (res_read >= 0) then
begin
SetString (str, PChar(@Buffer), res_read); end;
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 23, 0, 0, @Buffer2, 2, 50);
sleep(100);
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 24, 0, 0, @Buffer2, 2, 50);
poked:= False;
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 18, 0, 0, @Buffer2, 2, 50);
for i:= 1 to 100 do
begin
res_read:= usb_bulk_read (udev, $81, @Buffer, 64, 50);
if (res_read < 0) then
begin
if poked then
break else begin
res:= usb_control_msg (udev, USB_RECIP_INTERFACEor USB_TYPE_CLASS or USB_ENDPOINT_IN, 21, 0, 0, @Buffer2, 2, 50);
poked:= True; end; end;
if (res_read >= 0) then
begin
SetString (str, PChar(@Buffer), res_read);
end; end;
poked:= False;
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 19, 0, 0, @Buffer2, 2, 50);
for i:= 1 to 100 do
begin
res_read:= usb_bulk_read (udev, $81, @Buffer, 64, 50);
if (res_read < 0) then
begin
if poked then
break else begin
res:= usb_control_msg (udev, USB_RECIP_INTERFACE or USB_TYPE_CLASS or USB_ENDPOINT_IN, 21, 0, 0, @Buffer2, 2, 50);
poked:= True;
end; end;
if (res_read >= 0) then
begin
SetString (str, PChar(@Buffer), res_read);
myrslt:= myrslt + str;
end; end;
TMainForm (main_form).rslt:= myrslt;
Synchronize(UpdateDefscope);
end;
procedure Defscope. UpdateDefscope;
begin
TMainForm (main_form).UpdateDefscope;
end; end.
Размещено на Allbest.ru
Подобные документы
Среда Microsoft Visio: понятие, основные функции. Функция автосоединения в Office Visio 2007. Логарифмическая функция правдоподобия. График вероятностей отказа версий программного обеспечения. Визуальное моделирование в UML. Общий вид диаграммы классов.
курсовая работа [53,9 K], добавлен 09.01.2012Моделирование работы системы массового обслуживания: рассмотрение структурной схемы и временной диаграммы функционирования вычислительного центра, разработка алгоритмического и программного способов решения поставленной задачи, анализ результатов.
курсовая работа [886,5 K], добавлен 24.06.2011Использование моделирования в программной инженерии в процессе разработки программного обеспечения. Основные этапы процесса разработки программного обеспечения, их характеристика. Моделирование процессов, их определение фазами и видами деятельности.
реферат [2,2 M], добавлен 25.12.2017Функциональное и эксплуатационное назначение изделия – интернет-магазина, требования к нему, порядок контроля и приемки. Назначение и область применения, выбор информационного обеспечения. Моделирование бизнес-процессов. Разработка внутренней структуры.
дипломная работа [2,0 M], добавлен 27.01.2013Разработка программного обеспечения для управления базой данных. Место задачи в системе автоматизации. Семантическое моделирование данных. Разработка программного обеспечения и базы данных. Расчет трудоемкости и себестоимости этапов проектирования.
дипломная работа [2,9 M], добавлен 04.02.2016Понятие технологии разработки программного обеспечения и модели жизненного цикла. Сущность объектно-ориентированного подхода. Строительные блоки, общие механизмы языка моделирования UML, диаграммы классов, состояний, взаимодействий и компонентов.
курсовая работа [262,5 K], добавлен 10.07.2014Выбор языка программирования и средств реализации поставленной задачи. Диаграмма прецедентов использования лифта. Построение основной диаграммы классов. Создание интерфейса, с помощью которого пользователь мог бы легко понять моделирование лифта.
курсовая работа [477,2 K], добавлен 01.05.2016Разработка программного обеспечения, моделирующего работу банкомата. Особенности области применения терминала и выделение главных функциональных частей. Разработка алгоритма работы программы и реализация системы. Ее тестирование и анализ результатов.
курсовая работа [5,5 M], добавлен 12.10.2011Моделирование разработки системы тестирования остаточных знаний на основе компетентностного подхода с помощью нескольких этапов: моделирование бизнес-процесса, планирование работ, UML-моделирование, моделирование данных логического и физического уровня.
курсовая работа [2,2 M], добавлен 14.12.2012Моделирование системы разгрузки, поступления в хранилище и переработки нефти. Исследование начальных условий имитации работы флота, состоящего из 15 танкеров. Разработка библиотеки функциональных блоков. Анализ результатов имитационных экспериментов.
курсовая работа [376,0 K], добавлен 28.10.2013