Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Программируемые логические контроллеры для управления технологическими процессами. В 2 ч. Ч 1.pdf
Скачиваний:
5
Добавлен:
29.11.2025
Размер:
2.39 Mб
Скачать

156

15.2Арифметические инструкции

15.2.1Сложение числовых данных. Команды (ADD) и (DADD)

Команда «ADD» выполняет сложение двух числовых данных. Результат сложения хранится по адресу цели. В адресе источника (S+) и адресе цели (D+) нужно также указывать одинаковые типы операндов. Двоичные данные в адресах источников (S1+) и (S2+) суммируются, при этом результат суммирования запоминается в адресе цели (D+). Таким образом: (S1+) + (S2+) = (D+). В старшем бите запоминается знак числа суммирования (0 – знак положительного числа, 1 – знак отрицательного числа). Пример применения «ADD»- команды показан на рисунке 15.9.

Рисунок 15.9 – Пример применения «ADD»-команды

Если включен Х0, то суммируются значения данных в регистрах D10 и D12. Результат суммирования запоминается в регистре данных D14.

Примечание:

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

Если результатом сложения является 0, включается флаг нуля.

Если результатом сложения явилось число меньше -32 767 (16-битовая операция) или же -2 147 483 648 (32-битовая операция), включается флаг заимствования.

157

Если результатом сложения явилось число выше +32 767 (16-битовая операция) или же ±2 147 483 647 (32-битовая операция), включается флаг переноса.

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

15.2.2 Вычитание числовых данных. Команды (SUB) и (DSUB)

Команда «SUB» выполняет вычитание двух числовых данных. Результат вычитания хранится по адресу цели. Все полностью аналогично предыдущей функции – (см. выше) команда сложения

«ADD».

15.2.3 Умножение числовых данных. Команды (MUL) и (DMUL)

Команда «MUL» выполняет умножение двух числовых данных. Результат умножения хранится по адресу цели. Данные в S1+ и S2+ перемножаются между собой. Результат умножения запоминается по адресу операнда указанного в D+ и в следующем за ним адресе операнда: (S1+) x (S2+) = (D+) . В старшем бите запоминается знак результата перемножаемых чисел (0 – знак положительного числа; 1 – знак отрицательного числа).

Умножение 16-битных данных (MUL-команда).

Результат 16-битного умножения оказывается 32-битным числом. Это число запоминается как 32-битное значение. Младшие 16-бит записываются по адресу операнда, заданному в (D+). Стар-

158

шие 16 бит записываются по следующему за ним адресу операнда. Пример применения «MUL»-инструкции показан на рисунке 15.10.

Рисунок 15.10 – Пример применения «MUL»-команды

Результат умножения записывается как 32-битное значение данных в регистры данных D4 и D5. В D4 стоят младшие 16 бит, а в D5 – старшие 16 бит. Знак числа стоит в 15-м бите D5.

Умножение 32-х битных данных (DMUL-команда).

Результат 32-х битного умножения запоминается 64 значением данных. Младшие 16 бит запоминаются по адресу операнда, заданному в (D+). Старшие биты записываются по следующему за ним адресу операнда. Пример применения «DMUL»-инструкции показан на рисунке 15.11:

Рисунок 15.11 – Пример применения «DMUL»-команды

Результат умножения записывается как 64-х битное значение данных в регистры данных D4, D5, D6 и D7. В D4 стоят младшие 16 бит, а в D5, D6 и D7 – старшие биты.

Примечание:

При 32-битном операнде для (D+) нельзя применять Z(V).

159

15.2.4 Деление числовых данных. Команды (DIV) и (DDIV)

Команда «DIV» выполняет деление двух числовых данных. Результат деления хранится по адресу цели. Выполняется деление данных в (S1+) и (S2+). Данные в (S1+) соответствуют делимому, в (S2+) – делителю. Результат деления запоминается по адресу операнда указанного в (D+) и в следующем адресе операнда. Остаток делимого запоминается в следующем адресе операнда: (S1+) : (S2+) = = (D+). В ста ршем бите запоминается знак числа результата деления (0 – знак положительного числа; 1 – знак отрицательного числа). При работе программы появляется ошибка, если значение делителя равно 0 и команда не обрабатывается.

Деление 16-битных данных (DIV-команда).

Результат 16-битного деления запоминается по адресу операнда в заданном D+. Остаток от деления запоминается в следующем за ним адресе операнда. Пример применения «DIV»-команды показан на рисунке 15.12.

Рисунок 15.12 – Пример применения «DIV»-команды

Результат деления 14 записывается в регистр данных D4. Остаток от деления 12 записывается в следующий регистр данных

D5.

Деление 32-битных данных (DDIV-команда).

При делении 32-битных данных для делимого, делителя, результата и остатка от деления имеется соответственно по два следу-