[发明专利]用于光线跟踪的SAH-KD树设计方法有效

专利信息
申请号: 201810061647.3 申请日: 2018-01-22
公开(公告)号: CN108171785B 公开(公告)日: 2021-12-10
发明(设计)人: 廖胜辉;李建锋;谭耀华;夏佳志;郭璠;赵于前;邹北骥 申请(专利权)人: 中南大学;吉首大学
主分类号: G06T15/06 分类号: G06T15/06;G06T17/00;G06T17/20;G06T1/20
代理公司: 深圳市中原力和专利商标事务所(普通合伙) 44289 代理人: 谢芝柏
地址: 410083 湖南省*** 国省代码: 湖南;43
权利要求书: 查看更多 说明书: 查看更多
摘要: 发明提供了一种用于光线跟踪的SAH‑KD树设计方法,包括:步骤S1、在进行所述SAH‑KD树的构建之前,对节点中的当前根节点的所有三角面片进行预处理;步骤S2、按层次递归构建所述SAH‑KD树,生成当前所述节点的左、右子节点的有序包围盒序列,并计算出当前层次每个所述节点的包围盒的三个维度的表面积;步骤S3、求出当前节点需要划分的维度,生成每一层所有所述节点的空间树和候选划分点,计算出每个所述候选划分点对应的SAH值;步骤S4、选择最小SAH值对应的所述候选划分点作为当前节点的最优划分点,并将该当前节点分成左、右两个子节点。与相关技术相比,本发明提供的用于光线跟踪的SAH‑KD树设计方法构建的SAH‑KD树性能好且效率高。
搜索关键词: 用于 光线 跟踪 sah kd 设计 方法
【主权项】:
1.一种用于光线跟踪的SAH‑KD树设计方法,其特征在于,该方法包括如下步骤:

步骤S1、在进行所述SAH‑KD树的构建之前,对节点中的当前根节点的所有三角面片进行预处理,计算所述当前根节点的所有三角面片的包围盒,将所述包围盒在三个维度排列,形成有序包围盒序列;

步骤S2、按层次递归构建所述SAH‑KD树,通过遍历上层每个所述节点的所述有序包围盒序列,生成当前所述节点的左、右子节点的有序包围盒序列,并计算出当前层次每个所述节点的包围盒的三个维度的表面积;

步骤S3、根据每个所述节点的所述包围盒求出当前节点需要划分的维度,生成每一层所有所述节点的空间树和候选划分点,利用所述空间树并行计算出每个所述候选划分点对应的SAH值;

步骤S4、对于当前层的每个所述节点,遍历其包含的所述候选划分点,选择最小SAH值对应的所述候选划分点作为当前节点的最优划分点,并将该当前节点分成左、右两个子节点。

2.根据权利要求1所述的用于光线跟踪的SAH‑KD树设计方法,其特征在于,步骤S1中,所述包围盒为AABB包围盒。

3.根据权利要求1所述的用于光线跟踪的SAH‑KD树设计方法,其特征在于,步骤S1中,将所述包围盒在三个维度按升序排列。

4.根据权利要求1所述的用于光线跟踪的SAH‑KD树设计方法,其特征在于,步骤S2中,具体还包括:

迭代计算出每个节点在新的一层空间中的偏移D,使用AssignTri算法将所述左、右子节点包含的所述三角面片有序指派至所述左、右子节点中:

其中,NT为新一层三角面片的总和;NL为左子节点的三角面片数,NR为右子节点的三角面片数,i为自然数;D为偏移。

5.根据权利要求1所述的用于光线跟踪的SAH‑KD树设计方法,其特征在于,步骤S3中,选择所述包围盒最长的维度作为需要划分的维度。

6.根据权利要求1所述的用于光线跟踪的SAH‑KD树设计方法,其特征在于,该方法为CPU/GPU混合编程的SAH‑KD树设计方法,利用GPU使用宽度优先搜索构建所述SAH‑KD树,所述CPU对每次结果进行同步。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中南大学;吉首大学,未经中南大学;吉首大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/patent/201810061647.3/,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top