LR0分析程序的设计与实现代码

时间: 2023-08-13 19:08:31 浏览: 52
以下是一个简单的 LR(0) 分析程序的设计与实现代码,用 Python 语言实现: ```python # LR(0) 分析程序 # 标识符常量 SHIFT = 1 REDUCE = 2 ACCEPT = 3 ERROR = 4 # 产生式类 class Production: def __init__(self, head, body): self.head = head self.body = body # 项目类 class Item: def __init__(self, production, dot): self.production = production self.dot = dot def __eq__(self, other): return self.production == other.production and self.dot == other.dot def __hash__(self): return hash(str(self.production) + str(self.dot)) # LR(0) 分析表类 class LR0Table: def __init__(self, grammar): self.grammar = grammar self.actions = {} self.gotos = {} # 构造项目集规范族 self.canonical_collection = self.build_canonical_collection() # 构造 LR(0) 分析表 self.build_table() # 构造项目集规范族 def build_canonical_collection(self): # 第一步:初始化 start_production = self.grammar.productions[0] start_item = Item(start_production, 0) closure = self.closure(set([start_item])) current_state = frozenset(closure) canonical_collection = {current_state: closure} # 第二步:循环直到项目集规范族没有变化 while True: for item in current_state: # 对于每个项目 A -> α·Bβ,进行 GOTO 操作 if not item.dot == len(item.production.body): symbol = item.production.body[item.dot] goto = self.goto(current_state, symbol) if not goto in canonical_collection: closure = self.closure(goto) canonical_collection[goto] = closure # 如果项目集规范族没有变化,则退出循环 if len(canonical_collection) == len(current_state): break else: current_state = list(canonical_collection.keys())[-1] return canonical_collection # 求闭包 def closure(self, items): closure = set(items) while True: new_items = set() for item in closure: # 对于每个项目 A -> α·Bβ,将 B -> γ 加入 new_items if not item.dot == len(item.production.body): symbol = item.production.body[item.dot] if symbol in self.grammar.non_terminals: for production in self.grammar.productions: if production.head == symbol: new_item = Item(production, 0) if not new_item in closure: new_items.add(new_item) if not new_items: break closure |= new_items return closure # 求 GOTO(A -> α·Bβ, b) def goto(self, items, symbol): goto = set() for item in items: if not item.dot == len(item.production.body) and item.production.body[item.dot] == symbol: goto.add(Item(item.production, item.dot + 1)) return frozenset(self.closure(goto)) # 构造 LR(0) 分析表 def build_table(self): for i, state in enumerate(self.canonical_collection): # 对于每个项目 A -> α·,将 ACTION[s, a] 设为 SHIFT(t),其中 t = GOTO[s, a] for item in state: if item.dot == len(item.production.body): if item.production.head == self.grammar.start_symbol: self.actions[(i, '$')] = (ACCEPT, None) else: for symbol in self.grammar.follow(item.production.head): self.actions[(i, symbol)] = (REDUCE, item.production) else: symbol = item.production.body[item.dot] goto = self.goto(state, symbol) if symbol in self.grammar.terminals: self.actions[(i, symbol)] = (SHIFT, goto) else: self.gotos[(i, symbol)] = goto # 执行 LR(0) 分析 def parse(self, input): stack = [0] output = [] while True: state = stack[-1] symbol = input[0] if (state, symbol) in self.actions: action, arg = self.actions[(state, symbol)] if action == SHIFT: stack.append(arg) input = input[1:] elif action == REDUCE: head = arg.head body = arg.body output.append(arg) for i in range(len(body)): stack.pop() state = stack[-1] stack.append(self.gotos[(state, head)]) elif action == ACCEPT: output.append(arg) return output else: raise Exception('Syntax error') else: raise Exception('Syntax error') ``` 此代码实现了 LR(0) 分析程序的主要功能,包括构造项目集规范族、构造 LR(0) 分析表和执行 LR(0) 分析。使用时需要提供一个文法对象(包括产生式和起始符号)和一个输入串。输出为分析树或语法错误。

相关推荐

最新推荐

recommend-type

编译原理LR(1)自动构造,自动分析输入语句

LR(1)分析表自动构造程序的实现,对输入语句分析 设计内容及要求:对任意给定的文法G构造LR(1)项目集规范族(要求实现CLOSURE(I)、GO(I,X)、FIRST;然后实现LR(1)分析表构造算法。构造并输出其LR(1)分析表。由分析表...
recommend-type

LL(1)分析法实验报告及代码

1.根据某一文法编制调试LL(1)分析程序,以便对任意输入的符号串进行分析。 2.本次实验的目的主要是加深对预测分析LL(1)分析法的理解。
recommend-type

中间代码生成器的设计(实验报告+代码+运行结果) 编译方法

(3) 本实验已给出递归子程序法的四元式属性翻译文法的设计,鼓励学生在此基础上进行创新,即设计LL(1)分析法或LR(0)分析法的属性翻译文法,并根据这些属性翻译文法,使用扩展的语法分析器实现语法制导翻译。
recommend-type

《编译原理》课程设计指导书 算术表达式的语法分析及语义分析程序设计。

通过设计、编制、调试一个算术表达式的语法及语义分析程序,加深对语法及语义分析原理的理解,并实现词法分析程序对单词序列的词法检查和分析。  2.设计内容及要求: 算术表达式的文法: 〈无符号整数〉∷= ...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依