IFC转换为RDF并在Protege中查看

IFC转换为RDF并在Protege中查看

IFC为建筑信息模型的存储提供了一个准则。IFC文件有许多表述模式,例如STEP、RDF、OWL。理论上来说,这些格式都是可以互相转化的。STEP的可读性不佳,但是转化成RDF/OWL后,就可以在Protege中进行查看,从而进一步了解IFC文件的组织格式。

创建一个IFC文件并导出

最快捷的方式:在Revit中创建一个项目并导出为IFC,这个模型包括四面墙,两个自定义族,导出格式为IFC2X3。
IFC转换为RDF并在Protege中查看

IFC2RDF

https://github.com/pipauwel/IFCtoRDF提供了一个将IFC转化为RDF的工具。这个工具可以将.IFC后缀的文件转化为.TTL,支持以下IFC格式:

  • IFC2X3_TC1
  • IFC4_ADD1
  • IFC4_ADD2
  • IFC4_ADD2_TC1
  • IFC4x1
  • IFC4
  • IFC4x3_RC1
    下载其jar包后,与ifc文件放在同一目录下,打开当前目录的cmd输入:
    java -jar .\IFCtoRDF-0.4-shaded.jar .\test.ifc .\testrdf.ttl
    即在目录下生成了RDF文件。

在Protege下查看RDF文件

用Protege打开RDF文件后,可以看到此文件包含的类与属性。

IFC2RDF:消失的属性

在类下可以看到该文件包括的所有ifc类,以及它们的实例。如IfcWallStandardCase就有四个实例,对应四堵墙:
IFC转换为RDF并在Protege中查看
然而看不到任何的Object properties和Data properties。这是因为RDF不区分什么object和data properties,这点和STEP类似。所以所有的properties都以Annotation properties的方式呈现,如图:
IFC转换为RDF并在Protege中查看

IFC中原先定义了Object和data properties吗?

答案是肯定的。从buildingSMART中下载ISO标准版本、TTL格式的IFC文档并用Protege打开,可以看到各类属性。首先是Data Property:
IFC转换为RDF并在Protege中查看
以及Object Properties:
IFC转换为RDF并在Protege中查看
那么就有一个问题:IFC2RDF得到的RDF文件,annotation properties和标准版本的IFC中是否是一一对应的呢?

IFC2RDF的缺陷,是否能够改正?

Data properties的对应

首先是hasInteger一类的Data properties,答案是:yes。
IFC转换为RDF并在Protege中查看

Object properties的对应

Object properties的对应稍微复杂一点。以ifwallstandardcase中一堵墙的objectPlacement_IfcProduct作为例子,返回在IFC标准文件的Object properties搜索对应项。
IFC转换为RDF并在Protege中查看
我们发现,确实有一项称为ObjectPlacement的object properties,其domain为IfcProduct,Ranges为IfcObjectPlacement。
其他的properites大抵相同,也就是说_之前的是该object properties的URI,_之后的是该properties的domain。了解了这一点之后,我们就可以知道如何将IFC2RDF产生的文件进一步转化为OWL了。

上一篇:抛开炒作看知识图谱,为什么现在才爆发?


下一篇:知识图谱发展历程简介