47811 (608381), страница 6
Текст из файла (страница 6)
(0x8050ab8) VAR=x
(0x8050aa8) left=0x80509e8 right=0x8050a98 op=+
(0x8050a98) left=0x8050a68 right=0x8050a88 op=^
(0x8050a88) CONST=0.5
(0x8050a68) left=0x8050a38 right=0x8050a58 op=*
(0x8050a58) CONST=2
(0x8050a38) left=0x8050a08 right=0x8050a28 op=^
(0x8050a28) CONST=3
(0x8050a08) CONST=2
(0x80509e8) left=0x80509b8 right=0x80509d8 op=^
(0x80509d8) CONST=2
(0x80509b8) CONST=4
nodes num: 47
Как видно из вывода, количество узлов в синтаксическом дереве равно 47.
После прохода оптимизатора дерево имеет следующий вид:
Syntax Tree: (optimized)
(0x8050da8) left=0x8050aa8 right=0x8050c28 op=+
(0x8050c28) left=0x8050e08 right=0x8050ab8 op=*
(0x8050ab8) VAR=x
(0x8050e08) left=0x8050b08 right=0x8050c08 op=+
(0x8050c08) left=0x8050b88 right=0x8050bf8 op=*
(0x8050bf8) VAR=x
(0x8050b88) CONST=24
(0x8050b08) CONST=10
(0x8050aa8) left=0x80509e8 right=0x8050d08 op=+
(0x8050d08) op=s next=0x8050cf8
(0x8050cf8) left=0x8050ce8 right=0x8050c98 op=+
(0x8050c98) VAR=x
(0x8050ce8) CONST=3
(0x80509e8) left=0x80509b8 right=0x8050d98 op=+
(0x8050d98) right=0x8050d58 op=-
(0x8050d58) op=l next=0x8050d48
(0x8050d48) op=s next=0x8050d38
(0x8050d38) VAR=x
(0x80509b8) CONST=22
nodes num: 19
Это дерево соответствует формуле:
22-log (sin(x))+sin (3+x)+x*(10+24*x)
Как видно из вывода, количество узлов в синтаксическом дереве равно 19, против 47, что приводит к повышению скорости выполнения программы.
Сохранение синтаксического дерева в файл
Эта функциональность добавлена для ускорения работы с математическими выражениями. После трансляции математического выражения в синтаксическое дерево, есть возможность сохранить его в том виде, в котором оно находится в оперативной памяти, в файл на жесткий диск. Т. о. если требуется вычислить несколько математических выражений несколько раз, то их можно оттранслировать один раз, сохранить в файлы, а потом извлекать их в виде, готовом для интерпретации, не тратя время на лексический и синтаксический анализ.
Сохранение синтаксического дерева начинается с корня дерева и обходит дочерние узлы слева – направо с их последующим сохранением.
Аналогичным образом происходит извлечение дерева из файла.
Интерпретатор
Интерпретатор выполняет извлечение из файла синтаксического дерева, являющегося результатом выполнения транслятора.
После извлечения дерева интерпретатор совершает его обход. Результатом работы интерпретатора является число, в точности соответствующее значению математического выражения, которому, в свою очередь, эквивалентно извлеченное синтаксическое дерево.
Заключение
В работе были рассмотрены теоретические основы построения трансляторов.
Результатом работы являются:
– класс Analyser, реализующий заявленную функциональность
– транслятор с языка математических выражений на язык деревьев вывода
– интерпретатор языка деревьев вывода















