[发明专利]三维图布局方法、装置、计算设备及存储介质在审
| 申请号: | 202111492162.8 | 申请日: | 2021-12-08 |
| 公开(公告)号: | CN114140605A | 公开(公告)日: | 2022-03-04 |
| 发明(设计)人: | 吕嘉洛;张如亭;原雅姣;王亮;肖新光 | 申请(专利权)人: | 安天科技集团股份有限公司 |
| 主分类号: | G06T19/20 | 分类号: | G06T19/20;G06T11/20 |
| 代理公司: | 北京格允知识产权代理有限公司 11609 | 代理人: | 王文雅 |
| 地址: | 150028 黑龙江省哈尔滨市高新技术产*** | 国省代码: | 黑龙江;23 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 三维 布局 方法 装置 计算 设备 存储 介质 | ||
本发明提供了一种三维图布局方法、装置、计算设备及存储介质,其中方法包括:基于待布局的拓扑数据,创建并得到拓扑图中的各个联通子图;其中,任意一个联通子图均与其它联通子图之间不存在连接关系;将各个联通子图分类为完全图和非完全图;所述完全图包括:由一个或两个节点组成的联通子图、由三个以上节点组成且任意两个节点之间相连接的联通子图;将各完全图分别按照第一布局方式进行规则布局,以及将各非完全图分别按照第二布局方式进行分层布局;对规则布局后的各完全图以及分层布局后的各非完全图进行子图间布局,得到对所述拓扑数据进行布局后的三维图。本方案,不仅能够体现出网络拓扑的层次结构,且可以提高布局效率。
技术领域
本发明实施例涉及计算机技术领域,特别涉及一种三维图布局方法、装置、计算设备及存储介质。
背景技术
网络拓扑绘制完成后,为了能够清楚表示出网络拓扑中节点间的关系,一般需要对网络拓扑进行布局。目前,常用的网络拓扑布局算法是力导向类布局算法。但是力导向算法的布局效果呈现空间发散形状,并且布局耗时长、效率较低。
发明内容
基于力导向算法布局效果呈空间发散形状,且布局耗时长、效率较低的问题,本发明实施例提供了一种三维图布局方法、装置、计算设备及存储介质,不仅能够体现出网络拓扑的层次结构,且可以提高布局效率。
第一方面,本发明实施例提供了一种三维图布局方法,包括:
基于待布局的拓扑数据,创建并得到拓扑图中的各个联通子图;其中,任意一个联通子图均与其它联通子图之间不存在连接关系;
将各个联通子图分类为完全图和非完全图;所述完全图包括:由一个或两个节点组成的联通子图、由三个以上节点组成且任意两个节点之间相连接的联通子图;
将各完全图分别按照第一布局方式进行规则布局,以及将各非完全图分别按照第二布局方式进行分层布局;
对规则布局后的各完全图以及分层布局后的各非完全图进行子图间布局,得到对所述拓扑数据进行布局后的三维图。
优选地,所述将各完全图分别按照第一布局方式进行规则布局,包括:
当完全图由一个节点组成时,将该节点布局在中心位置处;
当完全图由两个以上、设定数量以下的节点组成时,将完全图中的各节点按照环布局方式进行规则排列;所述设定数量大于等于2;
当完全图由大于设定数量的节点组成时,将完全图中的各节点按照球布局方式进行规则排列。
优选地,所述将各非完全图分别按照第二布局方式进行分层布局,包括:
针对每一个非完全图,确定该非完全图是否为树图;若是,则对该非完全图按照树图布局方式进行分层布局;若否,则对该非完全图按照非树图布局方式进行分层布局。
优选地,在确定该非完全图是否为树图之前,还包括:
遍历该非完全图中的每一个节点,对该非完全图中与旁路节点直接连接的节点配置旁路属性,以及对该非完全图中与桥节点直接连接的两个连接节点分别配置桥属性;并对每一个节点创建如下属性:布局半径、预留半径、层级和子节点集合;所述旁路节点为只具有一个连边且被配置为旁路类型的节点;所述桥节点为只具有两个连边且被配置为桥类型的节点;所述预留半径为预留给该节点下子节点的布局范围;
将该非完全图中的旁路节点和桥节点从该非完全图中断开,并将被桥节点断开的两个连接节点相连。
优选地,在所述将各非完全图分别按照第二布局方式进行分层布局之后,还包括:
根据与旁路节点直接连接的节点的三维布局位置,以及旁路节点相对与其直接连接的节点进行环布局排列时的相对布局位置,确定每一个旁路节点的三维布局位置;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于安天科技集团股份有限公司,未经安天科技集团股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111492162.8/2.html,转载请声明来源钻瓜专利网。





