Разделы презентаций


В.В. Ершов, доцент кафедры НДиС УлГУ, к.в.н., доцент

Содержание

1. СТАНДАРТ IEC 61131-3Результатом работы Международной Электротехнической Комиссии (МЭК или английская аббревиатура IEC) был выпуск в 1982 г. стандарта IEC 1131. Современная редакция стандарта (который с 1997 г. называется IEC 61131)

Слайды и текст этой презентации

Слайд 1В.В. Ершов, доцент кафедры НДиС УлГУ, к.в.н., доцент
Лекция 1.4

ПРОГРАММИРОВАНИЕ ПЛК


1.

СТАНДАРТ IEC 61131-3;
2. КРАТКАЯ ХАРАКТЕРИСТИКА СТАНДАРТНЫХ ЯЗЫКОВ ПРОГРАММИРОВАНИЯ ПЛК;
3. АЛГОРИТМ

ВЫПОЛНЕНИЯ ПРОГРАММ В ПЛК;
4. ИНСТРУМЕНТАЛЬНАЯ СРЕДА ПРОГРАММИРОВАНИЯ ISaGRAF.
В.В. Ершов, доцент кафедры НДиС УлГУ, к.в.н., доцентЛекция 1.4ПРОГРАММИРОВАНИЕ ПЛК1. СТАНДАРТ IEC 61131-3;2. КРАТКАЯ ХАРАКТЕРИСТИКА СТАНДАРТНЫХ ЯЗЫКОВ

Слайд 21. СТАНДАРТ IEC 61131-3
Результатом работы Международной Электротехнической Комиссии (МЭК или

английская аббревиатура IEC) был выпуск в 1982 г. стандарта IEC

1131. Современная редакция стандарта (который с 1997 г. называется IEC 61131) включает 8 разделов:
1. Общая информация.
2. Требования к оборудованию и тестам.
3. Языки программирования.
4. Руководства пользователя.
5. Спецификация сообщений.
6. Полевые сети.
7. Программирование с нечеткой логикой.
8. Руководящие принципы применения и реализации языков ПЛК.
1. СТАНДАРТ IEC 61131-3Результатом работы Международной Электротехнической Комиссии (МЭК или английская аббревиатура IEC) был выпуск в 1982

Слайд 3СТАНДАРТ IEC 61131-3
Раздел 3 данного стандарта (IEC 61131-3) регламентирует

использование пяти стандартных языков программирования ПЛК:
язык функциональных блоков (FBD);
язык релейной

логики (LD);
язык последовательных функциональных схем (SFC);
язык инструкций (IL) и язык структурированного текста (ST).
Выбор этих языков обусловлен простотой и наглядностью представления с их помощью алгоритмов управления.
Внедрение стандарта IEC 61131 дало основу для создания единой школы подготовки специалистов. После появления стандарта появилась возможность создавать аппаратно-независимые библиотеки.
СТАНДАРТ  IEC 61131-3Раздел 3 данного стандарта (IEC 61131-3) регламентирует использование пяти стандартных языков программирования ПЛК:язык функциональных

Слайд 4Типы данных
В языках IEC 61131-3 используется строгая проверка на тип

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

относятся к одному определенному типу либо к совместимому типу, имеющему более широкий диапазон допустимых значений.
Это обстоятельство требует предварительного описания переменных в библиотеке прикладной программы (процедура объявления переменных).
Типы данных в IEC 61131-3 разделяются на две группы:
элементарные;
составные.
К элементарным типам данных относятся:
целочисленные переменные;
логические (булевы) переменные;
действительные переменные;
переменные времени;
строковые переменные.
Элементарные типы данных являются основой для построения составных типов данных. К составным относятся следующие типы данных: массивы, структуры, перечисления, массивы структур и др.
Типы данныхВ языках IEC 61131-3 используется строгая проверка на тип обрабатываемых данных. Операции над данными производятся только

Слайд 5Типы данных
Логические переменные. Данные переменные могут принимать только два значения

False (Ложь или ≪О≫) или True (Правда или ≪1≫). Эти

переменные определяются ключевым словом BOOL и относятся к алгебре Буля. Для хранения значений логической переменной используется один бит.
Целочисленные переменные. Приведем основные типы целочисленных данных:
BYTE - 8 бит;
WORD - 16 бит,
DWORD (Double WORD) - 32 бита;
LWORD (Long WORD) - 64 бита;
SINT (Small INT) - 8 бит, может принимать значения от -128 до 127;
INT - 16 бит, может принимать значения от -32768 до 32767;
DINT (Double INT) - 32 бита, может принимать значения от -231 до 231^- 1;
LINT (Long INT) - 64 бита, может принимать значения от -263 до 2^- 1 ;
USINT (Unsigned Small INT) - 8 бит, может принимать значения от 0 до 255;
UINT (Unsigned INT) - 16 бит, может принимать значения от 0 до 65535;
UDINT (Unsigned Double INT)- 32 бита, может принимать значения от 0 до232^-1;
ULINT (Unsigned Long INT) - 64 бита, может принимать значения от 0 до 2е4-1.

Типы данныхЛогические переменные. Данные переменные могут принимать только два значения False (Ложь или ≪О≫) или True (Правда

Слайд 6Типы данных
Действительные переменные.
Данный тип переменных обозначается ключевым словом REAL,

и представляется в виде действительных чисел в диапазоне от -1038

до 1038. Переменная имеет 32-разрядный формат, в котором 23 разряда используется для обозначения мантиссы. Поддерживается также длинный формат действительной переменной, в котором действительное число представляется в виде 64-разрядного двоичного числа.
Данный формат обозначается LREAL и может принимать значения в диапазоне от -10 до 10.
Переменные времени. Обозначаются сломом TIME и используются для определения интервалов времени. Для хранения переменных времени отводится 4 байта.
Строковые переменные. Используются для хранения текстовой информации и обозначаются ключевым словом STRING.
Длина строки (количество используемых символов) задаётся при объявлении переменных. Поэтому объём памяти, в которой будет храниться строковая переменная, зависит от длины строки. Каждый символ занимает 1 байт памяти.
Типы данныхДействительные переменные. Данный тип переменных обозначается ключевым словом REAL, и представляется в виде действительных чисел в

Слайд 7Типы данных
Рассмотренные элементарные типы данных могут объединяться в массивы, структуры,

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

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

Слайд 8Виды и правила объявления переменных
Переменные бывают:
Входные - значения, считываемые со

входов ПЛК. Входные переменные могут быть аналоговыми или дискретными.
Выходные -

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

Слайд 92. Краткая характеристика стандартных языков программирования ПЛК
Язык функциональных блоков
 Реализует комплексные

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

функциональных блоков, соединенных между собой линиями связи.
Пример программы на языке функциональных блоков (FBD) показан на рис. 1.
Программа формирует булевой выходной сигнал Qut_1, если произведение сигналов In_1. In≥1000.

Рис. 1

2. Краткая характеристика стандартных языков программирования ПЛКЯзык функциональных блоков Реализует комплексные процедуры, состоящие из различных входных, выходных переменных,

Слайд 10ЯЗЫК РЕЛЕЙНОЙ ЛОГИКИ
Используется для описания логических выражений различного уровня сложности

с помощью электромеханических элементов (реле и контактов).
Пример программы на языке

релейной логики (LD) показан на рис. 2.

Первая строка программы реализует логическую операцию ≪И≫ двух дискретных сигналов inl и in2, так как появление выходного сигнала outl возможно только тогда, когда будут замкнуты оба нормально разомкнутых контакта inl и in2.
Вторая строка программы реализует сразу две операции ≪ИЛИ≫ (с помощью нормально разомкнутых контактов outl, in3 и in4) и ≪НЕ≫ с помощью нормально замкнутого контакта in5.
Язык предусматривает также выполнение условных переходов между блоками программы (на рис. 2 показан переход по метке END:).

ЯЗЫК РЕЛЕЙНОЙ ЛОГИКИИспользуется для описания логических выражений различного уровня сложности с помощью электромеханических элементов (реле и контактов).Пример

Слайд 11ЯЗЫК ПОСЛЕДОВАТЕЛЬНЫХ ФУНКЦИОНАЛЬНЫХ СХЕМ
Реализует последовательность процедурных шагов и условных переходов.
На

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

осуществляется после выполнения логических условий, назначенных данным условным переходам.
Пример программы на языке последовательных функциональных схем (SFC) показан на рис. 15.3.
ЯЗЫК ПОСЛЕДОВАТЕЛЬНЫХ ФУНКЦИОНАЛЬНЫХ СХЕМРеализует последовательность процедурных шагов и условных переходов.На каждом шаге выполняется конкретное действие, запрограммированное пользователем.

Слайд 12ЯЗЫК ИНСТРУКЦИЙ
Текстовый язык низкого уровня. Принцип программирования, команды и структура

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

Язык инструкций (IL) стандартизован и не зависит от используемой аппаратной платформы. Каждая инструкция может содержать четыре поля, разделяемых пробелами или знаками табуляции.
Структура записи команд в языке инструкций выглядит следующим образом:
<Метка> : <Оператор> + <Модификатор> <Операнд> <Комментарий>
Метка, модификатор и комментарий в строке инструкции необязательны. Оператор должен присутствовать в строке всегда, а операнд иногда может отсутствовать.
Метка - это символическое имя (адрес) некоторой области памяти, в которой хранится номер отмеченной меткой строки в списке команд.
Совместно с метками используются команды условного (исполняемые при выполнении определенных условий) и безусловного (выполняемые всегда) перехода (соответственно, операторы JMPC или JMP).
Оператор - это непосредственно команда, которая выполняет определенное действие над операндом. Совместно с оператором может присутствовать модификатор, который предназначен для преобразования оператора к необходимому виду. Так модификатор N выполняет инверсию операнда до выполнения самой команды, а модификатор С - добавляет проверку содержимого аккумулятора и выполняет оператор только в том случае, если значение в аккумуляторе соответствует true (истина).
ЯЗЫК ИНСТРУКЦИЙТекстовый язык низкого уровня. Принцип программирования, команды и структура записи команд такая же, как и у

Слайд 13ЯЗЫК СТРУКТУРИРОВАННОГО ТЕКСТА
Текстовый язык высокого уровня для создания гибких процедур

обработки данных. По структуре этот язык похож на Паскаль.
Основу языка

структурированного текста (ST) составляют выражения, каждое из которых должно заканчиваться точкой с запятой. Для присвоения значений переменным используется оператор ≪:=≫.
Для описания математических выражений используются общепринятые символы: +, *, /, (,), <, <=, >=, > и др.
Порядок вычисления выражений такой же, как и в алгебре - действия выполняются слева направо. Сначала выполняются действия, заключенные в скобки, затем - операции умножения или деления, и только после этого - сложение или вычитание.
Для увеличения функциональных возможностей языка структурированного текста в нём предусмотрены операторы выбора (IF ... THEN ... ELSE ... ENDIF), операторы множественного выбора (CASE ... OF ... ELSE ... ENDCASE), операторы цикла (WHILE ... DO ... ENDWHILE, REPEAT ... UNTIL ...ENDREPEAT или FOR ... TO ... BY ... DO ... ENDFOR).
Ниже рассмотрим правила использования данных операторов.
ЯЗЫК СТРУКТУРИРОВАННОГО ТЕКСТАТекстовый язык высокого уровня для создания гибких процедур обработки данных. По структуре этот язык похож

Слайд 14АЛГОРИТМ ВЫПОЛНЕНИЯ ПРОГРАММ В ПЛК
Выполнение программ в ПЛК осуществляется циклически,

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

(новый цикл начинается сразу после окончания предыдущего цикла).
На первом шаге ПЛК получает необходимую для обработки информацию о состоянии объекта управления – производится считывание входных переменных (входы модулей аналогового и дискретного ввода). Далее осуществляется непосредственная обработка полученной информации - выполняется основная программа ПЛК.
В результате обработки информации формируются команды управления, которые на следующем шаге передаются на выходы контроллера - процедура обновления выходных переменных.
АЛГОРИТМ ВЫПОЛНЕНИЯ ПРОГРАММ В ПЛКВыполнение программ в ПЛК осуществляется циклически, причем время выполнения одного цикла может быть

Слайд 15ИНСТРУМЕНТАЛЬНАЯ СРЕДА ПРОГРАММИРОВАНИЯ ISaGRAF
Традиционно все ведущие производители ПЛК разрабатывают собственные

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

Однако мелкие и средние производители ПЛК зачастую не имеют возможности разрабатывать полнофункциональные инструментальные средства программирования. Это привело к появлению фирм, занятых исключительно разработкой инструментов программирования ПЛК. Одним из таких производителей является фирма CJ International создавшая программное обеспечение ISaGRAF.
Инструментальная среда программирования ISaGRAF предназначена для программирования и конфигурирования ПЛК различных производителей (например, PEP Modular Computers, Motorola, ABB и др.).
ИНСТРУМЕНТАЛЬНАЯ СРЕДА ПРОГРАММИРОВАНИЯ ISaGRAFТрадиционно все ведущие производители ПЛК разрабатывают собственные средства программирования и конфигурирования контроллеров, оптимизированные под

Слайд 16СТРУКТУРА ИС ПРОГРАММИРОВАНИЯ ISaGRAF
Условно инструментальная среда программирования ISaGRAF состоит

из двух систем:
- система разработки проектов (ISaGRAF DevSys);
- система исполнения

программ (ISaGRAF Target).
СТРУКТУРА  ИС ПРОГРАММИРОВАНИЯ ISaGRAFУсловно инструментальная среда программирования ISaGRAF состоит из двух систем:- система разработки проектов (ISaGRAF

Слайд 17ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAF
В инструментальной системе программирования ISaGRAF предусмотрены следующие

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

со специализированными функциями (не включенными в стандартные библиотеки языков программирования ПЛК), написанными на языке ANSI С (требует компилятор для соответствующей операционной системы).
2. Встроенный отладчик, обеспечивающий поддержку следующего набора функций:
выполнение программы по шагам;
изменение кода программы в процессе работы отладчика;
трассировка рабочих переменных;
интерактивная модификация значений переменных;
запуск/останов отдельных программ, входящих в состав проекта ISaGRAF;
изменение продолжительности цикла выполнения программы в процессе работы отладчика;
эмуляция входных сигналов ПЛК и др.

ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAFВ инструментальной системе программирования ISaGRAF предусмотрены следующие возможности:1. Поддержка пяти стандартных языков программирования ПЛК,

Слайд 18ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAF
3. Поддержка протокола Modbus (RTU, Slave).
4. Открытость

системы для доступа извне к внутренним структурам данных проекта ISaGRAF

(опция ISaGRAF Server).
5. Разработка собственных драйверов на модули ввода/вывода УСО.
6. Адаптация ядра ISaGRAF под любую аппаратно-программную платформу.
7. Набор драйверов для работы с контроллерами некоторых производителей аппаратных средств автоматизации технологических процессов (PEP Modular Computers, Motorola, ABB и др.).
8. Использование интерактивных редакторов для описания переменных, определений и конфигурации ввода/вывода.
9. Встроенные средства контроля за разработкой проектов, печати отчетов и документирования приложений.
ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAF3. Поддержка протокола Modbus (RTU, Slave).4. Открытость системы для доступа извне к внутренним структурам

Слайд 19ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAF
В основе системы исполнения (ISaGRAF Target) лежит

принцип синхронизации выполнения прикладной программы. Время выполнения прикладной программы (цикл)

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

Например, для ПЛК, работающих под управлением операционной системы MS-DOS, минимальный цикл составляет 55 мс, а для ПЛК, работающих под управлением операционной системы OS-9, минимальный цикл составляет 10 мс. Если время цикла установить равным нулю, то каждый следующий программный цикл будет обрабатываться сразу же по окончании обработки предыдущего программного цикла.

Структура программного цикла с жёстким заданием времени исполнения прикладной программы ( а ) и без задания времени исполнения программ.

ОСОБЕННОСТИ ИС ПРОГРАММИРОВАНИЯ ISaGRAFВ основе системы исполнения (ISaGRAF Target) лежит принцип синхронизации выполнения прикладной программы. Время выполнения

Слайд 20Структура прикладных программ и программного цикла в среде программирования ISaGRAF
Структура

прикладных программ в среде ISaGRAF включает 3 основные секции:
- BEGIN

(начальная) - процедуры и программы, выполняемые в начале каждого цикла системы исполнения;
- SEQUENTIAL (последовательная) - процедуры и программы, подчиняющиеся динамическим правилам языка SFC;
- END (заключительная) - процедуры и программы, выполняемые в конце каждого цикла системы исполнения.
Программы начальной секции систематически выполняются в начале каждого цикла исполнения, а программы заключительной секции - в его конце, как показано на рис.. Шаги последовательной секции выполняются в соответствии с правилами языка последовательных функциональных схем.

Структура программного цикла в системе исполнения ISaGRAF Target

Структура прикладных программ и программного цикла в среде программирования ISaGRAFСтруктура прикладных программ в среде ISaGRAF включает 3

Слайд 21Структура ПП и ПЦ в среде программирования ISaGRAF
Программы начальной секции

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

от модулей ввода. Сформированные в начальной секции переменные используются программами последовательной секции.
Программы заключительной секции традиционно формируют переменные, обработанные в последовательной секции, перед передачей значений в модули вывода.
Программы последовательной секции должны быть написаны только на языке последовательных функциональных схем (SFC).
Программы начальной и заключительной секций могут быть написаны на любом из пяти стандартных языков программирования ПЛК, кроме языка последовательных функциональных схем (SFC), т.е. на одном из следующих языков:
язык функциональных блоков (FBD);
язык релейной логики (LD);
язык структурированного текста (ST);
язык списка инструкций (IL).

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

Слайд 22Благодарю за внимание

Благодарю за внимание

Обратная связь

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

Email: Нажмите что бы посмотреть 

Что такое TheSlide.ru?

Это сайт презентации, докладов, проектов в PowerPoint. Здесь удобно  хранить и делиться своими презентациями с другими пользователями.


Для правообладателей

Яндекс.Метрика