Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Операционная семантика

Метод таблиц решений.

Метод таблиц решений базируется на использовании таблиц следующего вида (см. табл. 5.1).

Переменные/условия Ситуации (комбинации значений)
x1 a[1,1] a[1,2] ... a[1,m] *
x2 a[2,1] a[2,2] ... a[2,m] *
... ...
xn a[n,1] a[n,2] ... a[n,m] *
  s1 u[1,1] u[1,2]   ... u[1,m] u[1,m+1]
s2 u[2,1] u[2,2] ... u[2,m] u[1,m+1]
... ...
sk u[k,1] u[k,2] ... u[k,m] u[k,m+1]
Действия Комбинации выполняемых действий

Табл. 5.1. Общая схема таблиц решений.

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

Нижняя часть таблицы решений определяет действия, которые требуется выполнить в той или иной ситуации, определяемой в верхней части таблицы решений. Она также состоит из нескольких (k) строк, каждая из которых связана с каким-либо одним конкретным действием, указанным в первом поле (столбце) этой строки. В остальных полях (столбцах) этой строки (т.е. для u[i, j], i=1,... m+1, j=1,... k) указывается, следует ли выполнять (u[i, j]= '+') это действие в данной ситуации или не следует (u[i, j]= '-'). Таким образом, первый столбец нижней части этой таблицы представляет собой список обозначений действий, которые могут выполняться в той или иной ситуации, определяемой этой таблицей. В каждом следующем столбце этой части указывается комбинация действий, которые следует выполнить в ситуации, определяемой в том же столбце верхней части таблицы решений.

Условия   Ситуации
Состояние светофора   Кр   Кр   Кр   Жел   Жел   Зел   Зел   Зел
T=Tкр Нет Нет Да * * * * *
T=Tжел * * * Нет Да * * *
T>Tзел * * * * * Нет Да Да
Появление привиле-гированной машины   Нет     Да     *   *   *   *   Нет     Да  
Включить красный - - - - - -   +   -
Включить желтый - + + - - - - -
Включить зеленый - - - - + - - -
T:=0 - + + - + - + -
T:=T+1 + - - + - + - +
Освобож- дение пе-шеходной дорожки   -     -     -     +     -     -     -     -  
Пропуск пешеходов + + + - - - - -
Пропуск машин - - - - - + + +
  Действия   Комбинации выполняемых действий

Рис. 5.2. Таблица решений "Светофор у пешеходной дорожки".

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

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

В операционной семантике алгебраического подхода к описанию семантики функций рассматривается следующий частный случай системы равенств (5.1):

f1(x1, x2,..., xk)= E1,

f2(x1, x2,..., xk)= E2,

............. (5.3)

fn(x1, x2,..., xk)= En,

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

Операционная семантика интерпретирует эти равенства как систему подстановок. Под подстановкой

s

E

T

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

fi(x1, x2,..., xk)= Ei

задает в параметрической форме множество правил подстановок вида

x1, x2,..., xk

fi(T1, T2,..., Tk) ® Ei,

T1, T2,..., Tk

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

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

В качестве примера операционной семантики рассмотрим определение функции F(n)=n! Она определяется следующей системой равенств:

F(0)=1,

F(n)=F(n-1)*n.

Для вычисления значения F(3) осуществляются следующие шаги.

1-й шаг:

F(0)=1,

F(3)=F(2)*3.

2-й шаг:

F(0)=1,

F(3)=F(2)*3,

F(2)=F(1)*2.

3-й шаг:

F(0)=1,

F(3)=F(2)*3,

F(2)=F(1)*2,

F(1)=F(0)*1.

4-й шаг:

F(0)=1,

F(3)=F(2)*3,

F(2)=F(1)*2,

F(1)=1.

5-й шаг:

F(0)=1,

F(3)=F(2)*3,

F(2)=2,

F(1)=1.

6-й шаг:

F(0)=1,

F(3)=3,

F(2)=2,

F(1)=1.

Значение F(3) на 6-ом шаге получено.

<== предыдущая лекция | следующая лекция ==>
Основные подходы к спецификации семантики функций | Денотационная семантика
Поделиться с друзьями:


Дата добавления: 2014-01-11; Просмотров: 389; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.017 сек.