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

Пример оформления задания:

Задание 1.

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

3–(0x0c)+(0x0d)–(0x0f) →(0x0d)

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

Далее показано оформление решения в виде трассировочной таблицы.

Решение.


Команда

W

0x0c

0x0f

0x0d

MOVF 0X0C,0 

(0x0c)

x

x

x

ADDWF 0X0F,0 

(0x0c)+(0x0f)

x

x

x

SUBLW 3

3–((0x0c)+(0x0f))

x

x

x

ADDWF 0X0D, 1 

3–((0x0c)+(0x0f))

x

x

(0x0d)+(3–((0x0c)+(0x0f)))


ЛАБОРАТОРНАЯ РАБОТА № 2

Тема: Исследование принципа работы циклических алгоритмов в PIC-контроллерах

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

1 Сведения из теории

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

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

DECFSZ  F, d

НЕ нашли? Не то? Что вы ищете?

(DECrement  F, Skip if Zero), которая вычитает единицу из содержимого ячейки ОЗУ с адресом F и пропускает следующую команду, если в результате вычитания получился 0, d – признак приемника;

и GOTO <метка>, которая выполняет переход на команду с указанной меткой.

Циклическая часть алгоритма имеет следующую структуру:

<переслать в счетчик число повторений цикла>

<метка>  <действия, которые необходимо повторять>

<……………………………………………...>

DECFSZ  <счетчик>, 1

GOTO  <метка>

В качестве счетчика можно использовать любую ячейку ОЗУ с адресом, начиная с 0x0C.

Метка – любой идентификатор (слово, начинающееся с буквы).

Например, пусть требуется 8 раз добавить к аккумулятору число 10:

MOVLW.8

MOVWF 0x0C

CLRW

L1  ADDLW.10

DECFSZ 0x0C,1

GOTO L1

Цикл работает следующим образом. В регистр 0x0C помещаем число 8. Очищаем содержимое аккумулятора. Затем после каждого добавления к аккумулятору числа 10 вычитаем из регистра 0х0С единицу. Если при этом в регистре остается не 0, то выполняется следующая команда GOTO, которая возвращает управление на начало цикла (на команду с меткой). Если в результате получился 0 (а он получится через заданное число повторений, поскольку мы каждый раз вычитаем единицу), то команда перехода будет пропущена, и программа будет продолжать выполняться со следующей за GOTO команды. Таким образом, содержимое регистра, используемого в команде «DECFSZ», определяет, сколько раз будут повторяться команды в цикле.

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

Пример 1.

Пусть в регистре (0x0c) содержится значение 4, а в (0x1f) – значение 3.

Получить (0x0c)*(0x1f)→(w).

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

Решение.


Команды

W

(0x0c)

(0x0d)

  clrw

0

4

3

L1 addwf 0x0c, 0

0+4

4

2

  Decfsz 0x0d, 1

0+4+4

4

1

  Goto L1

0+4+4+4

4

0


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

Пример 2.

Получить (0x0c)*(0x1f)→(0x0c).

Решение. В этом случае сумма должна накапливаться в регистре 0x0c, поэтому его начальное состояние должно равняться нулю. Добавляться к нему будет значения аккумулятора, в котором должно храниться добавляемое. Поэтому сначала переместим содержимое регистра 0x0c в аккумулятор, затем очистим регистр.


Команды

W

(0x0c)

(0x0d)

  Movf  0x0c,0

4

4

3

  Clrf 0x0c

4

0

3

L1 addwf 0x0c, 1

4

0+4

2

  Decfsz 0x0d, 1

4

0+4+4

1

  Goto L1

4

0+4+4+4

0


Пример 3.

Получить (0x0c)2→(0x0c).

Решение. Здесь понадобится дополнительный регистр, в который нужно скопировать содержимое ячейки, так как оно должно быть умножено само на себя. Скопируем содержимое регистра 0x0c через аккумулятор в регистр 0x0f. Теперь в аккумуляторе, регистре 0x0c и регистр 0x0f одно и то же значение. Далее очистим регистр 0x0c, так как в нем должна накапливаться сумма. Теперь можно в цикле, число повторений которого задается значением в регистре 0x0f добавлять к содержимому регистра 0x0c содержимое аккумулятора.


Команды

W

(0x0c)

(0x0f)

  Movf  0x0c,0

4

4

x

  Movwf 0x0f

4

4

4

  Clrf 0x0c

4

0

4

L1 addwf 0x0c, 1

4

0+4

3

  Decfsz 0x0f, 1

4

0+4+4

2

  Goto L1

4

0+4+4+4

1

4

0+4+4+4+4

0


2 Порядок выполнения работы

1 Наберите каждую из программ, соответствующую заданию, в MPLAB.

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

3 Оформите отчет так, как это показано в примерах.

Варианты заданий находятся в табл. 2 приложения.

3 Содержание отчета

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

ЛАБОРАТОРНАЯ РАБОТА № 3

Тема: Исследование принципов построения алгоритмов

с ветвлениями в микроконтроллерах среднего семейства серии PIC

Цель: Изучение принципов и получение навыков организации ветвлений

1 Сведения из теории

Алгоритмами с ветвлениями называются алгоритмы, в которых, в зависимости от выполнения или не выполнения некоторого условия выполняется одна или другая группа команд. Для организации ветвлений в контроллерах PIC используются команды:

BTFSS f, b – проверяет состояние бита с номеров b в регистре с адресом f и пропускает следующую команду, если бит равен 1.

BTFSC f, b – проверяет состояние бита с номеров b в регистре с адресом f и пропускает следующую команду, если бит равен 0.

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

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

Результат операции вычитания проверяется по состоянию 0-го(С) и 2-го (Z) битов этого регистра.

Бит Z устанавливается в 1, если в результате предыдущей операции получился нулевой результат, и в 0 – в противном случае.

Бит С устанавливается в 1 в случае получения неотрицательного результата операции и сбрасывается в 0 в противном случае.

Пример 1.

Записать в аккумулятор наименьшее из содержимого ячеек 0х0c и 0x0d.

MOVF 0X0C,0 ; (w)=(0x0c)

SUBWF 0X0D,0 ; (w)=(0x0d) – (0x0c)

MOVF 0X0D,0 ;  (w)=(0x0d)

BTFSC 0X03,0  ; пропустим следующую команду, если флаг С = 0

MOVF 0X0C,0  ; (w)=(0x0c), если флаг С = 1

NOP

END

Пример 2.

Пусть значение х хранится в регистре 0х0с, а значение а – в регистре 0x0d. Значение y поместить в регистр 0x0e.

MOVF 0X0D,0 ; (w)=(0x0d)=a

SUBWF 0X0C,0 ; (w)=(0x0c)–(0x0d)=x–a

Из за большого объема этот материал размещен на нескольких страницах:
1 2 3 4 5