BERA语言实施
BERA语言的设计和定义使其实现可以移植到不同的建筑信息建模平台。图5.1描述了BERA语言的高级执行体系结构,图5.2 详细显示了它作为扩展图5.1。在BERA语言实现阶段,应该涵盖两个主要环境:无平台环境(换句话说,针对不同平台的BERA语言特定和公共前端部分)和依赖于BIM平台的环境。前端部分是所有其他部分的标准配置实现,而后端部分因BIM平台而异。本研究的目标实施基础是工业基础类(IFC)作为建筑信息模型,SolibriModelChecker®(SMC)作为IFC引擎,Java 虚拟机(JVM)作为编译和执行环境。
关于实现,BERA语言体系结构由两个高级组件组成,如下所述。
– 前端:BERA引擎:它包含用户生成的语言程序,目标语言的BERA转换器/解释器,以及用于生成BERA对象模型的其他中间表示和执行器。这个前线 – 终端引擎是所有实现和环境的标准。
– 后端:自定义引擎:如果没有给定的建筑模型,则无法执行BERA语言。建筑信息建模引擎是另一个巨大的平台。SMC是BERA引擎使用的候选平台,均为对象模型和应用程序。这种后端实现因平台而异,但目标中间模型始终是BERA对象模型。
图5.1。BERA语言的高级执行架构。作为高级数据流图,箭头表示数据流,上/下箭头也包括交互。
本章描述了关于一般语言后端问题的合理结构的BERA语言实现方法之一:词法分析,语法分析,语义分析,中间代码生成,目标代码生成和执行[Scott,2005]。后端方面的问题及其实施可以开发人员灵活采用。
本章中描述的实现方法基于名为BERA语言工具版本1.015的实际应用程序。这一章主要集中在BERA语言工具的一般性问题,而不是实现和平台的具体细节。几个示例程序及其执行结果将在下一章“应用程序和评估”中介绍。
本论文中描述的当前版本的BERA语言及其工具是 2010年秋季的初始版本。有关BERA语言及其工具的最新版本,请参阅附录 D:BERA语言用户手册及其在线资源网站。 图5.2。BERA语言架构细节:前端和后端。
本章组织并提出了一些描述BERA语言实现问题的重要特性。语言实现的实际过程在多个迭代函数中组合并同时执行,但为了清楚起见,它们将在本章中按顺序分开解释。
1)BERA监听器:BERA监听器负责对作为语言解析器的输入程序进行词法和句法分析。本节更侧重于语义分析和中间表示,将输入文本的含义转换为可执行的BERA数据结构:动态BOM和准备执行的用户定义的规则实例。
2)BOM处理程序:如第四章所述,有两种类型的BOM 及其属性静态和动态。静态BOM处理程序计算来自给定建筑模型的所有关联BOM数据,而动态BOM 处理程序负责根据用户查询收集对象,同时使用静态和动态BOM。规则生成器还有另一个重要的处理程序。它解析并构建用户定义规则的代码。
3)BERA执行程序:执行程序处理BERA语言语法中定义的用户执行语句。BERA监听器和BOM处理程序已经实例化了所有相关的用户定义对象,因此BERA执行器只是BERA语言执行方面的消费者。
4)BERA语言工具:BERA语言工具是BERA语言的集成开发环境,可用作具有本章所述功能的应用程序。
本章以独立于平台的方式强调BERA特定的前端实现问题,并解决在不同平台和环境上的进一步实现。本章还讨论了BERA语言扩展的一些方向。有关BERA语言语法定义或用例的详细信息,请参阅下一章和附录,尤其是附录D:BERA语言用户手册。
词法和句法分析
在建立语义和执行之前,应解析和识别用户文本输入流。名为BERA监听器的模块首先负责这个语言识别过程词法和句法分析。语言识别是任何语言应用程序中非常重要的一步。虽然这种技术解析在语言实现中起着重要作用,但它超出了这项工作的范围。
该论文并不试图解决有关分析或一般和具体问题的模式。BERA语言工具中的一些解析模块得到了ANTLR的推动[Parr,008; 2009年; 2010]作为用户BERA 语言输入的解析器生成器,特别是用于BERA语言识别的第一阶段的词法和句法分析步骤。相反,作者简要介绍了如何在构建BERA语义方面处理这些输入文本。一系列输入令牌将由BERA听众分类,如图5.3所示。 图5.3。描述BERA语言输入程序的顶级词法和句法分析的概述图。图5.3显示了负责处理输入文本的四个组件。它们相当于4.1 节中定义的BERA程序的最高分类:bReferenceнdefff,bBOMDefнBrBOM,bRuleDefнdefrule和bExeStatDefExe。输入文本仍被视为计算机的未知文本流。但是,通过使用BERA监听器,可以根据语言定义章节中介绍的高级BERA 语言结构对它们进行分类:
1)DefRef(参考声明),
2)DefBOM(动态BOM声明),
3)DefRule(规则定义声明),和
4)DefExe(执行声明)。
BERA监听器中的词法和句法分析器在为后续和更重要的任务验证,报告和分类用户输入文本方面发挥着重要作用:语义分析。
语义分析
语义分析通常被视为语言分析的最后阶段。所述BERA听者转换分类输入流成特定的数据结构类型,如在图5.4中示出的例子。它描述了BERA语言工具实现中使用的实际数据结构的示例。
图5.4中描述的对象是彼此触发或由语言执行语句使用的所有可实例化对象。
图5.4。描述建立BERA语言语义的概述图。如图5.4所示,他们的层次结构16,DefBOM,DefRule和DefExe可以填充多个DefBOM,而DefBOM和DefRule包括DefCond,它是条件定义语句。DefCond包含针对特定条件的单个操作数,使用点符号访问BOM,运算符和值。这个DefCond的一个重要方面是它与DOTExpr有一对一的关系,它定义了对BOM表的点符号访问的语义含义。执行语句DefExe 具有一个DefResult来实例化其执行结果。BERA听众解决了这个问题这些输入组件的含义经过验证并可以正确执行。16图5.3中的组件DefRef被删除,因为它是一个引用对象。 它的定义可以影响图5.4所示的数据结构,但仍然是它的一个子集。 例如,单个DefCond可以从DefBOM或DefRule派生。的下面是一个DefCond的示例:
path.one.distance <= 100
此示例DefCond可以从DefBOM被推导为条件之一,或从DefRule语句来定义的空间群的实例作为规则一个定义的条件作为一项规则。从此DefCond填充的DOTExpr实例可以表示如下(有关DOTExpr的结构,请参见图5.6):
( 容器。)((quant1。)BOM1。)((quant2。)BOM2。)(property)
– 其中所有都是非终端和可选令牌:例如,“path.one.Space.area”可以匹配如下:containerнpath,quant1нone,BOM1н空间和属性区域。(有关更多示例,请参阅表5.1)
BERA侦听器中的语义分析器负责将词法和句法分析器处理的文本输入转换为语言执行中要使用的对象实例。这还包含语义分析的大多数功能,例如BOM数据类型检查,名称或变量的分配以及对象绑定。图5.5描述了DOTExpr解析器,它在建立BOM语义中起着最重要的作用。语义分析可以通过早期语法级别或后期中间表示/执行级别来完成,考虑到实施环境。用例和示例将在
下一章和附录D:BERA语言用户手册中介绍。
表5.1。点符号访问BOM的一些有效示例(图5.4中的DOTExpr 示例)。在示例表达式列中,以大写字母开头的单词是BOM名称,以小写字母开头的单词是属性名称或量化单词。动态BOM的用户定义变量名称以斜体显示。
令牌DOTExpr令牌
示例表达式
1容器 空间 容器 myOffices
2 BOM1.property
Space.area
container.property
myPaths .distance
3 BOM1.BOM2.property
Space.Floor.name
container.BOM1.property
myOffices .Space.height
4 container.BOM1.BOM2 .property myOffice .Space.Floor.height
container.quant1.BOM1.property
myPath .one.Space.name
5 container.quant1.BOM1.BOM2.property path .one.Space.Floor.height
container.BOM1.quant2.BOM2。财产路径.Space.one.Floor.height
图5.5。DOTExpr结构概述。
BERA对象模型处理程序
BERA语言基于两种类型的BERA对象模型(BOM)静态和动态。静态BOM是来自特定给定建筑模型的静态数据集,可以通过语言设计章节中讨论的类名称(如建筑物,楼层和空间)来表示。静态BOM主要由给定的建筑模型预先确定,因此当建筑模型加载到内存中时,大多数给定的属性值都是静态建立的。某些属性可以由用户输入静态和动态分配,以便进一步开发。例如,构建对象下的“buildingType”可由用户使用分配Handler_bReference(参见图5.3)和Space对象下的“security” 可由附加的BERA库分配,该库负责自动分配安全级别,即使它们的默认值为空。这是针对其他用例的技术BERA 语言可扩展性的示例。 BOM构建器负责处理构建对象及其属性。在静态BOM生成器建筑模型专用; 因此,本章将更加强调描述动态BOM构建器。本研究和
实现的重点是空间BOM,如SpaceGroup和Path,如图4.1所示,但结构BOM实例(例如ObjectGroup的子类)也是
在工具中实例化和使用,因为它们与空间BOM 实例有物理关系。图5.6说明了本章描述的实现中的BOM类。简而言之,SpaceGroup,Path和其他之间的箭头表示继承(与结构和其他之间相同),其他箭头表示它们的关联关系。
图5.6。实现级BERA对象模型类概述。
静态BOM构建器
BOM处理程序在导入模型时或在解析或执行用户输入语言之前建立静态BOM数据。如图3.2和4.1所示,BOM是复杂建筑状态的抽象,侧重于其几个“规则和分析”视角。BOM是建筑环境规则和分析的关键概念之一,正如语言名称所暗示的那样。在BERA语言工具实现中,已经为特定目的提出并实现了许多计算和派生属性,以及直接从给定建筑模型。该实现利用了输入建筑
信息,但是需要额外的实现来计算一些特定于BERA的属性。这些由静态BOM构建器管理。图4.2中的“Building”是BOM的任何可能实例的默认“容器”,如图5.5中所定义:
对BOM 的点符号访问。
图4.2中的静态BOM及其属性可以通过Java特定的数据类型实现,例如Java double for Numeric,java String for String。该结构可能与图4.2(前端)中的概念结构不同,但为了提高效率,本文中描述的实现采用与图4.2 相同的结构。(也是下一节和图4.3中图5.7之间的相同关系)
动态BOM生成器
动态BOM构建器负责建立用户定义的静态BOM 集合。这些将在设计规则和分析任务中使用,就像静态BOM一样。例如,在流通规则中“A和B之间的流通应该是公开的”,如何获得A和B?常规规则检查软件使用空间名称从给定的建筑模型中获取它们。BERA语言工具也可以支持这一点,但此外还可以使用用户的动态BOM定义提供各种复杂的方法。他们的空间名称不仅可以用于
获取某些空间集合,还可以用于它们的空间属性和关系。
本节介绍两种主要类型的动态BOM实现:
SpaceGroup和另一个重要的SpaceGroup类路径。它们可以源自超类ObjectGroup。动态BOM和静态BOM 之间的主要区别在于其无限的可实例化性。用户可以使用给定建筑模型中的预定静态BOM 创建任何一个用户定义的SpaceGroup或Path实例。
图5.7描述了这两个类及其超类对象组。为了处理和计算建筑物循环特定属性,还有另一个静态元元素图表。它用于计算路径上的度量距离和转数,这些属性存储在每个Path实例下。(有关BERA语言工具中图形结构及其实际应用的详细信息,请参阅6.3.2节。)SpaceGroup是Path的超类; 因此Path 实例具有SpaceGroup的所有属性。例如,Path实例也具有SpaceGroup的属性,例如`numberOfSpace’,`height’和`area’。图5.7。动态BOM及其属性实现概述。动态BOM对象由用户的BERA语言(图5.3和5.4中名为DefBOM 的对象)实例化。动态BOM构建器负责实例化响应用户的ObjectGroup和对象定义的那些对象。任何动态BOM本质上都是静态BOM的派生子集。用户的SpaceGroup 变量名称将是该静态BOM子集的新容器。例如,用户定义的ObjectGroup“myOffices”可以包含名为“office”的Space对象,而“myOffices”是所选空间对象的容器。所有信息都以结构DefBOM和DefCondDOTExpr结构加载如图5.4所示。动态BOM构建器的一个重要功能是一种对象选择算法,如图5.8所示。这将返回一系列布尔结果,以确定是否可以 为给定的DefBOM 选择当前元素Object [n] 。这对执行规则也很有用。例如,图5.9显示了以下动态BOM定义的此过程:
Space myOffice {
Space.name
= “office”;
Space.area
>
500;
或Space.Floor.height> 16;
或Space.department =“office”;
}
图5.8。对象选择算法概述:多个条件DefCond中的一个DefBOM迭代Object Collection并收集其布尔结果数组。
图5.9。上述程序的空间对象选择示例:选择了一个实例Space [3],因为其结果为true。布尔数组{T,T,T,F}返回T,因为其中一个连词是“或”,其值为T17。(从左到右的评估)
BERA执行程序
BERA语言执行语句基本上由简单的行格式执行命令及其参数组成。基本命令关键字是“get”,如BERA语言设计章节中所述。从字面意思上讲,`get’命令检索所有BOM并根据其参数显示它们。本节重点介绍规则检查,在这种情况下,命令关键字是用户定义的规则名称。 用户定义的规则基本上由变量名,一系列DefCond和可选的嵌套DefBOM组成,如图5.4所示。在实现级别中,DefRule 和DefBOM具有几乎相同的结构,因为它们最终由17 处理。在此实现中,尚未开发布尔数组的嵌套结构。只有左TO- 正确的评价是允许在此版本中,但它会在下一版本中进行更新。 用于定义对象或调节规则条件的DOTExpr表示及其对象选择过程。
BOM和Rule18的定义之间的主要区别在于它们的容器 – 动态BOM定义基本上具有默认或静态BOM,但规则定义具有动态BOM作为其容器。与描述对象选择算法概述的一系列示例类似,图5.10将对象选择过程显示为从DefRule派生的规则检查过程。循环路径集合“p”是此规则定义DefRule 的容器,其DefCond 通过迭代发出布尔结果。此过程发生在规则执行中。规则执行
statement将某个规则名称作为函数调用,并将用户变量参数作为给定的对象容器提供。在此示例中,容器“p”包含n 个路径实例,并且此过程返回一系列布尔结果,以确定条件是否满足(选择)此实例Path [n]。在规则检查过程中,此选定实例表示“已通过”实例。BERA执行程序负责处理该过程以及考虑每个条件下给定的逻辑连接。规则检查执行的最简单结果是布尔值传递或失败; 但是,BERA语言工具提供了一整套收集的信息这个过程给用户。 18这些规则定义可以存储为文本格式重用, 用户可以通过BERA语言工具中实现的文件I / O和网络实用程序轻松导入/导出。
图5.10。路径对象选择示例:传递实例Path [3],因为其结果为true。布尔数组{T,F,T,T}返回T,因为其中一个连词是
“或”,其值为T.(从左到右评估)
BERA语言工具
BERA语言工具是作为提议的BERA语言的集成开发环境实现的。它是作为SMC之上的插件软件开发的,可在JVM环境中运行。图5.11是BERA语言工具的初始屏幕,图5.12是其编辑器和控制台界面。它支持独立模式和SMC插件模式。
图5.11。BERA语言工具启动屏幕。
BERA语言编辑器区域
BERA语言控制台区域
图5.12。BERA语言工具界面。
图5.13。BERA语言工具位于BIM平台之上SMC。
图5.13是SMC插件模式的屏幕截图。
左侧的窗口界面是BERA语言编辑器和控制台。在模块开发的各种迭代之后,这个BERA语言工具v.1.0是最初的产品级实现。
BERA语言特定功能和BERA语言工具相关模块都需要在后续版本中进行更新。附录D:BERA语言用户手册说明了该工具的详细功能。以下部分涉及可扩展性问题。
BERA语言可扩展性
与其他编程语言的开发类似,BERA 语言开发是一个开放式项目。语言语法在技术上是主要的更新的主题。然而,本节强调语言可扩展性问题,侧重于其语义和前端和后端可扩展性。
BERA语言可扩展性有两个不同的方向:
1)后端可扩展性:可重新定位的BERA语言,支持其他类型的BIM平台,如BIM创作工具,模型检查工具或模拟工具。
2)前端可扩展性:可扩展的BERA对象模型,以及BERA语言语法/语义改进,升级的BERA语言工具等问题.BOM可扩展性是双重的:横向可扩展性(更多的构建元素响应新规则的要求) )和垂直可扩展性(元素的属性)。
可重新定位的BERA语言
图5.14描述了根据BERA语言及其目标语言:Java 的数据流概 述。如本章所述,用户BERA语言程序由读者翻译,然后解释器执行一系列内部过程,如词法,句法和语义分析,数据收集,中间表示的生成等。作为翻译的结果,在内部以目标语言重新生成BERA程序。BERA 监听器和BOM处理程序的一系列过程使用户的输入语言可执行。后端可扩展性问题出现在此阶段,因为它们与平台有关。怎么可以BERA语言可以移植到不同的平台吗?从软件工程的角度来看,“关注点分离”的原则[Dijkstra等,982; Parr,2009] 可能会提供BERA语言后端可扩展性的线索。
图5.14。用于描述BERA 语言工具实现的简要数据流程图。BERA代码被转换为Java代码并执行。作为BERA代码的示例转换,这里是一个BERA程序,用于定义名为“bigOffices” 的动态BOM,它定义了两个条件:
102
Space bigOffices {
Space.name
= “office”;
Space.area
>
600;
}
get(bigOffices);
这只是一个5行的BERA代码示例,但它应该被翻译成目标语言(在此实现中,它是Java),如下所示。此示例还演示了与下面的Java代码相比,BERA语言如何有效和简单。下面的示例Java代码是某个后端平台中的示例代码。
import
java.util.ArrayList;
import
… IFCModel;
进口
… IFCSpace;
导入
…工具;
//省略了类定义,构造函数,方法等。
IFCModel model =
(IFCModel)ProductModelHandlingPlugin.getInstance()。getCurrentModel();
IFCSpace [] spaces =(IFCSpace [])model.findAll(IFCSpace.class);
2019/1/14 beras.html
file:///G:/books/BIM/bera/beras.html 58/115
ArrayList <IFCSpace> bigOffices = new ArrayList <IFCSpace>();
for(int i = 0; i <spaces.length; i ++){
if(Tools.isSameName(spaces [i] .name.getStringValue(),
“office”))
&& Tools.sm2sf(spaces [i] .area。 getDoubleValue())> 600){
bigOffices.add(spaces [i]);
}
}
如果(!bigOffices = NULL){
Tools.printInfoToConsole(bigOffices);
Tools.visualizeOnViewer(bigOffices);
} else {
103
Tools.printInfoToConsole(“找不到这样的对象。”);
}
在实际执行的BERA语言工具,主要一个担忧是,BERA语言的目标是成为一个重新定位的语言考虑到它的可扩展能力,由不同的语言和开发其它平台库。此实现中的目标语言是Java,但其他通用语言(如C ++和C#)也可用于使用模型驱动的语言转换引擎[MDA,2001; 肯特,2002年; 帕尔,2009年; 帕尔,2010b]。这种方法使BERA语言可以重新定位到其他平台。对于高级用户,BERA语言工具也直接从BERA 编辑器支持其目标语言,这使用户能够处理非常详细的数据级别以及目标BIM平台的API 。(请参阅6.5.2作为应用示例)图5.15说明了可重新定位的BERA侦听器的概述,它将相同的BERA输入语言转换为不同的目标语言。
图5.15。可重新定位的BERA监听器概述。19这种可重新定位的语言翻译功能目前依赖于其解析器生成器的 功能ANLR生成器[Parr,2010a]。它支持基础级别的词法分析器和解析器不同的目标语言。由于这种开放式工具,BERA语言实现也 利用了这些实用程序。
可扩展的BERA对象模型
BOM的定义是开放式的,作者意识到定义通用和有价值的BOM 是另一个挑战,因为它越来越详细。目前的BERA语言侧重于评估建筑物循环和空间规划在研究和实施范围方面的应用。在这个初步开发中,空间BOM是重点20。图4.2,4.3 和5.6 描述了主要在当前BERA语言及其详细属性中处理的对象类。此外,还有一个名为“Property”的灵活属性集,允许添加用户定义的属性。正如前几节所述,点符号在BOM和规则的定义中直观地使用对BOM的访问。当前实现中还有几个结构构建元素,如图5.16 所示。它们与空间对象(如空间和楼层)有直接关系,并且可在当前BOM中实例化。例如,Structure是类似于SpaceGroup或Path 的动态BOM ,是ObjectGroup的另一个子类型。由于这些超出了本论文的范围,它们的属性尚未深入开发。一些默认属性可直接从建筑模型中获得。但是,它们仍在构建与空间对象有直接关系的元素。例如,一个点 – 符号操作数mySpace.Door.width返回20的一个或多个数值。有关这些域应用程序中的演示,请参见第6.3,6.4 和6.5节。
本论文的范围在于这些领域。但是,作为可扩展BOM的示例应用程序, 6.6节演示了Wall对象示例。BERA语言工具的当前版本具有 许多用于处理扩展BOM的功能,如图5.16所述,并且仍在 开发中以供进一步应用。 一个名为mySpace的空间中的门的宽度,正如它所暗示的那样。(参见图5.5和附录D)
图5.16。扩展构建对象的示例:Structure是这些结构构建对象的动态BOM 的示例类。例如,对象组“ 地下室楼层的所有墙壁和平板”或“所有外墙”可以由用户动态地实例化为结构的实例。它将用于规则检查,分析或仅用于各种可视化。横向扩展,例如结构构建元素(如图5.16 中的示例所示)和垂直扩展(例如现有BOM的附加属性)对象)是BERA语言开放性的很好的例子。图5.17 说明了BOM开发的这种双向可扩展性。在图4.2和4.3中描述的静态和动态BOM中,已经提出并实现了许多计算和导出的属性用于以下目的:评估建筑物循环和空间规划。
根据“建筑环境规则和分析”的范围和范围,横向和纵向可扩展性都存在许多挑战性问题。因此,BOM可以具有多个具有不同约定的模型视图。换句话说, 下一章中描述的当前实施和应用是用于评估建筑物循环和空间计划的BOM的模型视图之一。目标是提供对域的概念的轻松访问,以进行规则检查。
图5.17。BERA对象模型的双向可扩展性
今天的文章BIM建筑环境规则和分析(BERA)语言介绍(六)第五章 BERA语言实施分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/87796.html