三维引擎系列(三):BIM数据管理与可视化功能

本文涉及的产品
数据管理 DMS,安全协同 3个实例 3个月
推荐场景:
学生管理系统数据库
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
简介: Ganos三维引擎的BIM数据管理分析解决方案,旨在充分发挥BIM模型价值,满足数字孪生技术发展的高精度需求。该方案通过结构化拆解BIM数据,实现统一管理和联合查询;支持精细化计算BIM模型指标,并与规划红线对比;同时提供高效渲染能力。Ganos内置多种功能,如ST_ImportIFC导入IFC格式数据,ST_As3DTiles生成3D Tiles瓦片数据结构,无需依赖第三方软件即可完成BIM数据的存储、计算与可视化展示。此外,通过简单的后端服务即可实现与渲染引擎的无缝对接,显著提升三维空间计算效率。

基于Ganos三维引擎的BIM数据管理分析
业务需求
BIM数据是数字孪生领域常见的三维数据类型,以往的平台建设中针对BIM数据往往只发挥了“看”的功能,即将BIM数据抽壳(或简化)后,在三维空间上配准,将其与倾斜摄影、白模、精模等一起用于三维可视化展示,只是针对BIM数据可以进一步查看模型内部结构。这样的方式并没有能够充分发挥BIM模型的价值,业务的精细化程度也不能得到有效的体现。
随着数字孪生技术向纵深发展,各行业对实体化数字孪生的理解越发深入,对于实体支撑下的精细化业务构建要求越来越高。BIM作为孪生领域最为精细的三维模型,是建筑实体最为典型的数字化表现,因此如何更好的发挥BIM模型的价值又成为广泛探索的技术方向,这其中产生的需求主要包括:

  1. BIM数据往往以专业格式按文件存储,不利于结合其他二三维数据统一管理、联合查询,需要对其进行结构化拆解,提供业务/空间查询的能力;
  2. 基于BIM的三维报建系统逐步推广,要求可以精细化计算设计院生成的BIM模型的相关指标(投影面、体积、碰撞关系等),并与二三维的规划红线进行空间比对;
  3. 结构化拆解后的BIM模型依然具备快速可视化的能力,与主流渲染引擎对接高效渲染;
    功能介绍
    针对客户日益增长的存储、计算、展示一体化需求,Ganos在库内支持数字孪生相关系列能力,其中具备了BIM数据导入、查询计算以及可视化等基础能力。
    BIM数据导入
    BIM数据有多种数据格式,其中IFC目前是主流的BIM标准,已经被ISO指定为国际标准
    Ganos 提供了ST_ImportIFC函数,支持将基于对象存储或内存结构的IFC数据导入到数据库中。
    语法
    • boolean ST_ImportIFC(cstring prefix, cstring url, cstring options default ‘{}’);
    • boolean ST_ImportIFC(cstring prefix, bytea content, cstring options default ‘{}’);
    返回值
    返回值
    描述
    true
    导入成功
    false
    导入失败
    参数
    参数名称
    描述
    prefix
    ifc表名前缀
    url
    基于对象存储服务的路径
    content
    以内存方式提供的IFC文件
    options
    导入选项:
    导入成功后会在数据库内生成三张表:
    • XXX_ifc_geom_elem(几何组件表):存储所有几何对象。
    • XXX_ifc_material_elem(IFC材质表):存储所有关联的材质对象。
    • XXX_ifc_elem(IFC部件表):存储所有实际的IFC部件对象及其相关属性。
    其中部件表以树状结构进行存储,三张表通过一个project_uuid进行关联。
    三维快显数据创建
    为了便于BIM数据入库后能快速就行可视化,Ganos提供了ST_As3DTiles 函数支持将Sfmesh数据转换为3dtiles瓦片数据结构,能通过前端可视化工具(如cesium,dataV等)进行可视化操作:
    语法
    • boolean ST_As3dTiles(sfmesh sfmesh_object, cstring table_name, cstring options default ‘{}’);
    返回值
    返回值
    描述
    true
    导出成功
    false
    导出失败
    参数
    参数名称
    描述
    sfmesh_object
    需要处理的sfmesh对象
    table_name
    业务表名称
    options
    json 字符串描述处理配置参数
    导入成功后会在数据库中生成三张表:
    • XXX(主表):存储该项目的元数据信息。
    • XXX_tile(瓦片表):存储该项目所有的三维快显数据。
    • XXX_tileset(tileset.json表):存储该项目对应的tileset.json信息。
    Ganos BIM数据管理的技术优势
    相比于传统的技术方案,Ganos提供的BIM数据管理方案优势在于:
    • 原生支持BIM数据的存储、计算与可视化,不依赖于任何第三方的BIM/GIS软件,库内使用SQL语句即可操作;
    • 将非结构化的BIM文件解构,保留了BIM数据的语义及各类属性,使其可以与其他空间数据一样进行管理与联合查询;
    • 库内提供三维基础算子进行空间分析,可通过云原生数据库的各项能力进行计算加速,经项目实测三维空间计算能力相较于传统方案有百倍提升;
    • 提供了三维快显能力,库内直接构建BIM的快显瓦片,通过简单的后端服务即可与渲染引擎进行对接,做到视算一体;
    功能使用案例
    下面,我们以存储在OSS上的某医院的BIM数据为例(IFC格式,113M),介绍如何使用Ganos进行BIM数据的管理与可视化。
    目前Ganos主要支持IFC格式的BIM数据。
  4. 创建扩展
    通过使用数据库客户端(以下为DBeaver)执行如下SQL语句创建 ganos_importer 扩展及依赖(ganos_sfmesh、ganos_sfmesh扩展会自动被创建):
    create extension ganos_importer cascade;
  5. 数据入库
    使用ST_ImporIFC函数(参考手册)导入IFC BIM数据。
    例如, 导入表名为 ifc_demo 为例,SQL为:
    select ST_importIFC('ifc_demo'::cstring, 'OSS://:@oss-cn-beijing.aliyuncs-internal.com/ifc/data/Architecture.ifc'::cstring);
    注意: 公有云实例必须填写internal的endpoint地址
    导入过程中会自动将创建对应的数据表并写入数据。
  6. 查看库内数据
    BIM数据导入后,部件,几何对象以及材质纹理都是以表对象方式存储,并能进行相互引用,以减少存储体积。
    3.1 查看BIM的部件信息
    SELECT project_uuid, project_name, parent_uuid, uuid, "family", "name", attrs, props_set, ST_AsText("element")
    FROM ifc_demo_ifc_elem;
    3.2 查看构件的几何信息
    SELECT project_uuid, project_name, geometry_id, ST_AsText(geom_element)
    FROM ifc_demo_ifc_geom_elem;
    3.3 查看材质信息
    SELECT project_uuid, project_name, material_name, ST_AsText(material_element)
    FROM ifc_demo_ifc_material_elem;
    可以通过 PolarAdmin 以可视化的方式对BIM中的部件进行浏览:
  7. 业务查询
    对于每一个部件,其属性以json的方式存储在props_set字段中。通过对props_set字段进行解析和过滤,可以有效地过滤出特定类型部件,并进行下一步操作。
    以下示例查询了类型为 ‘System Panel’ 的部件:
    SELECT project_uuid, project_name, parent_uuid, uuid, "family", "name", attrs, props_set
    FROM ifc_demo_ifc_elem
    WHERE
    (((props_set->'Other')::json)->'Type')::text like '%System Panel: %'
  8. 空间分析
    同样,可以基于空间范围对部件进行查询。 以下示例表示查询所有在三楼的部件,查询的条件是空间范围包含在第三层楼的范围内:
    select a.name
    from ifc_demo_ifc_elem a, ifc_demo_ifc_elem b
    where ST_3DIntersects(b."element", a."element") = true
    and b."family" = 'IfcBuildingStorey' and b.name = 'Level 3';
  9. 可视化展示
    6.1 创建三维快显格式
    使用ST_As3DTiles函数创建基于3dtiles的三维快显数据结构。创建完成后会在数据库内创建对应表和数据库。
    注:ST_As3DTiles函数将发布于Ganos 6.0版本中,计划11月下旬可以在公共云PolarDB-PG数据库中使用,参考手册同步上线
    操作时需要指定导入的ifc的根节点sfmesh对象,一般为 family='IfcProject' 对象。
    以上面导入的ifc_demo为例,SQL为:
    select ST_As3DTiles(element, 'ifc_demo_tiles') from ifc_demo_ifc_elem where family='IfcProject';
    注 :一些IFC不带有空间位置信息,需要手工更新空间范围的锚点,才能在前端正确的位置上进行显示。
    Update ifc_demo_tiles
    SET anchor=ST_SetSrid(ST_MakePoint(120, 30, 0), 4326)
    WHERE project_id = 'xxxxxxx'
    6.2 发布服务进行浏览
    我们使用Node.js编写一个简易的后端服务,实现代理3DTiles请求,并以Cesium作为前端框架展示结果。
    首先在用户自定义目录下编写依赖文件package.json:
    {
    "dependencies": {
    "koa": "^2.14.2",
    "koa-router": "^12.0.0",
    "koa-send": "^5.0.1",
    "pg": "^8.10.0"
    }
    }
    在本目录下执行npm install安装依赖库。
    在同一目录下创建Node.js脚本文件index.js:
    const Koa = require('koa');
    const Send = require('koa-send');
    const Router = require('koa-router');
    const router = new Router()
    const { Pool } = require('pg');
    const pool = new Pool({ user: , host: , database: , port: });
    const TABLE_NAME = 'ifc_demo_tiles'
    const PROJECTNAME = ''
    router.get('/', (
    ) => Send(_, '/index.html'))
    / get metadata of current project /
    router.get('/project', async (ctx) => {
    const sql = SELECT (REGEXP_MATCHES(ST_ASTEXT(ST_TRANSFORM(ANCHOR,4326)), 'POINT Z \\((.*?)\\)'))[1] _ANCHOR, PROJECT_ID FROM ${TABLE_NAME} WHERE PROJECT_NAME='${PROJECT_NAME}';
    const { rows: [{ _anchor, project_id }] } = await pool.query(sql)
    const anchor = _anchor.split(' ').map(x => parseFloat(x))
    const url = /tileset/${project_id}/${project_id}
    ctx.body = { url, anchor }
    })
    router.get('/tileset/:project_id/:uid', async (ctx) => {
    const { params: { project_id, uid } } = ctx
    const sql = SELECT TILESET FROM ${TABLE_NAME}_TILESET WHERE PROJECT_ID=$1::UUID AND UID=$2::UUID;
    const { rows: [{ tileset }] } = await pool.query(sql, [project_id, uid])
    ctx.body = tileset
    })
    router.get('/b3dm/:project_id/:uid', async (ctx) => {
    const { params: { project_id, uid } } = ctx
    const sql = SELECT ST_ASB3DM(TILE) TILE FROM ${TABLE_NAME}_TILE WHERE PROJECT_ID=$1::UUID AND UID=$2::UUID;
    const { rows: [{ tile }] } = await pool.query(sql, [project_id, uid])
    ctx.body = tile
    })
    new Koa().use(router.routes()).listen(5500, '0.0.0.0');
    在同一目录下创建HTML文件index.html:
    <!DOCTYPE html>













在同一目录下执行如下命令启动服务:
//代码效果参考: https://www.nbhbjx.cn
//代码效果参考: https://www.xx-ph.com
//代码效果参考: https://www.tvdy.cn
//代码效果参考: http://www.603393.com
node index.js
最终前端基于cesium的可视化效果如下所示:
总结
Ganos作为全球首个库内原生提供多种三维数据存储分析能力的空间数据库,自5.0开始将开发的重点聚焦在数字孪生领域的各类空间数据存、算、显一体化,从数据库系统最底层为物理世界数字化提供时空处理框架。目前Ganos已经支持了BIM、倾斜摄影、DEM、精/白模等多种三维空间数据的结构化存储、查询、分析与可视化服务,未来Ganos还将提供更多高效的库内三维空间分析能力,推动各行业数字孪生应用真正走向“视算一体”。
相关实践学习
MySQL基础-学生管理系统数据库设计
本场景介绍如何使用DMS工具连接RDS,并使用DMS图形化工具创建数据库表。
相关文章
|
数据可视化 定位技术
GIS空间分析 三维分析2 TIN创建与三维可视化
本文中,我将带你了解如何在ArcGIS中使用DEM数据制作三维模型
250 0
|
3月前
|
数据可视化 搜索推荐 atlas
DataV Atlas深度解析与实战应用:打造个性化地理信息可视化
阿里云DataV的Atlas功能专注于地理信息可视化,提供范围选择、边界生成和层级展示等工具,助用户轻松创建专业地图应用。通过代码示例展示了如何用Geo组件展示中国省份销售数据,强调了数据安全和性能优化的重要性。DataV Atlas简化了复杂地理信息的展示,提升了数据洞察的直观性和美感。【6月更文挑战第19天】
508 3
|
4月前
|
Ubuntu 数据可视化 Shell
一键访问多功能数据解决方案:如何轻松构建和管理APITable智能多维表格
一键访问多功能数据解决方案:如何轻松构建和管理APITable智能多维表格
86 0
|
数据可视化 定位技术
GIS空间分析 三维分析3 要素三维可视化
在本文中,我们使用ArcScene软件三维化了图层要素,并分析了要素间的关系,这对决策有着很重要的作用🎈🎈🎈
148 0
|
11月前
|
存储 数据可视化 数据管理
Ganos三维引擎系列(三):BIM数据管理与可视化功能解析
本文介绍了阿里云多模态时空数据库Ganos三维引擎在BIM数据管理中的应用。Ganos三维引擎支持三大类存储结构:表面网格模型、体网格模型与3D实景模型,其中表面网格模型(SFMesh)用于存储带有语义的类BIM精细化三维模型,同时提供了空间索引、分析算子、导入工具、可视化支撑等功能,本文详细介绍表面网格模型应用于IFC格式的BIM数据管理与可视化等功能。
|
存储 SQL 数据可视化
Ganos三维引擎系列(一):倾斜摄影数据管理与可视化功能解析
本文介绍了阿里云多模态时空数据库Ganos三维引擎在倾斜摄影数据管理中的应用。Ganos三维引擎支持三大类存储结构:表面网格模型、体网格模型与3D实景模型,其中表面网格模型用于存储带有语义的类BIM精细化三维模型,体网格模型用于存储地质体等非匀质“场”类三维模型,3D实景模型用于存储倾斜摄影、精白模等用于渲染的三维模型,三种存储结构都提供了原生数据类型、空间索引、分析算子、导入导出工具、可视化支撑等功能,为数字孪生类应用提供闭环的存算显能力,本文重点介绍基于3D实景模型开展倾斜摄影数据管理与可视化等功能。
|
数据采集 自然语言处理 监控
智慧数据驱动:基于smardaten构建多维数据可视化大屏
前段时间有位粉丝找到我问数据可视化大屏怎么做,我说我之前的博文里介绍过基于Flask和Echarts搭建的大屏,你可以去看看。结果他来了句“没学过任何编程代码怎么办?”,好家伙,一下给我整懵了,于是为了解决这个问题,照顾零基础的粉丝,我花了几天时间找了个不需要代码就可以做可视化大屏的方法,这篇文章就讲手把手教会你使用smardaten搭建数据可视化大屏(无需代码)。
175 0
|
监控
构建三维一体立体化监控,看这一篇就够了!
如果你需要搭建一套能够立体化监控你的应用及业务,出现问题及时告警的监控体系,这篇文章应该是你所需要的!
516 0
构建三维一体立体化监控,看这一篇就够了!
|
数据可视化 安全 图形学
实时云渲染技术应用之三维可视化部署
实时云渲染技术是以上两个方案的升级方案,该方案是纯B/S架构,将三维可视化、UE\Unity模型放置在服务器上,通过云渲染软件系统流化出可以在手机、电脑、平板、智慧屏等设备上可以直接访问的URL地址。程序运行是在云端服务器上,本地设备无需提供任何算力,用户也不需安装任何插件,而且在网络OK的情况下在任何设备任何地点(办公室、家里等)都可随时打开。在模型建设的阶段也可以选择多种引擎,无论是精美度更高的UE5还是unity、3dmax 或者其他设计软件都是OK的。因为云流化的原理其实不改变程序的指令执行过程,而是把整个执行过程画面以视频流的方式传回给用户终端设备。
424 0
实时云渲染技术应用之三维可视化部署
|
数据可视化 数据格式
水厂流程三维场景可视化解决方案
水厂流程三维场景可视化解决方案
水厂流程三维场景可视化解决方案