CGAL的3D皮肤表面网格

1、介绍

        Edelsbrunner 引入的皮肤表面和具有丰富而简单的组合和几何结构,使其适合在生物计算中模拟大分子。 对这些表面进行网格划分通常是进一步处理其几何形状所必需的,例如在数值模拟和可视化中。

        皮肤表面由一组加权点(输入球)和一个称为收缩因子的标量定义。如果收缩因子等于一,则表面只是输入球并集的边界。对于小于一的收缩因子,由于出现连接球的球面和双曲面的斑块,皮肤表面变得切线连续。

        此程序包使用中描述的算法构建由一组球和收缩因子定义的皮肤表面网格同位素。

        实现了一种优化算法,用于对一组球的并集进行网格划分。

2、定义一个skin曲面

        左图:两个加权点(两个虚线圆)的凸组合。右图:加权点的表面曲线。较小的圆形成加权点的子集,其边界是表面曲线。

        本节首先简要回顾了皮肤表面。

        皮肤表面由一组有限个加权点 P 和一个收缩因子 s 定义,其中 0≤s≤1。加权点 p=(p,wp)∈R3×R 对应于一个中心为 p、半径为 wp−−√ 的球。权重为零的加权点称为无权点。

        加权点p=(p,wP)和无权点x之间的伪距离被定义为: π(p,x)=∥p−x∥2−wp,

        其中p−x是p和x之间的欧几里得距离。加权点p对应的球是π(p,⋅)的零集。请注意,如果wp<0,则球的半径为虚数,并且零集为空集。

        我们可以通过取加权点距离函数的凸组合来获得加权点的凸组合。上图左显示了通过取虚线圆圈的凸组合获得的加权点。

        从加权点p=(p,wP)开始,通过与以p为中心的无权点进行凸组合获得收缩加权点ps。形式上,ps=sp+(1-s)p',其中p'=(p,0)。经过简单计算后,我们得到ps=(p,s⋅wp)。通过将P中的每个加权点按比例s收缩获得的集合Ps定义为Ps={ps∣p∈P}。上图(左)中收缩的加权点显示在上图(右)中。

        现在我们定义与一组加权点P相关联的皮肤表面skns(P)。考虑输入加权点的凸包的加权点集合。经过计算,可以发现每个加权点都在输入球的并集中。接下来,我们通过收缩凸包中的每个加权点来收缩它们。因此,我们将相应(实数)输入圆的半径乘以因子s√。皮肤表面是该集合的边界:

        这里conv(P)⊂R3×R是加权点集P的凸包,而∂表示相应球集的并集在R3中的边界。

        回想一下,输入加权点的凸包中的每个加权点都包含在输入加权点的并集中。因此,对于等于 1 的收缩因子,皮肤表面是输入加权点并集的边界。

        根据皮肤表面的定义,输入球的权重(它们的半径平方)以s为因子缩小,皮肤表面包裹在缩小的输入球周围。为了使皮肤表面包裹在(未缩小的)输入球周围,我们可以首先将输入球的权重乘以因子1/s,然后计算皮肤表面。

3、接口

        皮肤表面包的接口由一个主要功能组成,即获取一组加权点和收缩因子,并输出网格表面。此外,它定义了类和函数,并对用于执行算法的主要步骤进行了分类。存在两个全局类Skin_surface_3和Union_of_balls_3,它们都是概念SkinSurface_3的模型,并且存在从上述类的对象提取皮肤表面的网格(球的并集)的两个函数。最后一个函数获取一个网格和从中构建的Skin_surface_3(Union_of_balls_3)对象,并细化该网格。本节将更详细地描述这些类和函数。

template <class WP_iterator, class Polyhedron_3>
void make_skin_surface_mesh_3(Polyhedron_3 &p,WP_iterator begin, WP_iterator end,FT shrink_factor=.5,int nSubdiv=0,bool grow_balls = true);

        下面是make_skin_surface_mesh_3函数的参数解释:InputIterator points_begin:输入迭代器,指向加权点的起始位置。加权点用于定义皮肤表面的几何形状。InputIterator points_end:输入迭代器,指向加权点的结束位置。WeightedPoint:表示加权点的类型,其中包含点的坐标和权重。double shrink_factor:收缩因子,用于控制生成的皮肤表面的平滑程度。较小的收缩因子将导致更平滑的表面,而较大的收缩因子将使表面更加突出。unsigned int number_of_subdivision_steps:细分步骤数,用于控制生成的网格的精细程度。较大的细分步骤数将生成更精细的网格,而较小的细分步骤数将生成较粗糙的网格。OutputIterator mesh_begin:输出迭代器,指向生成的网格的起始位置。网格将以Polyhedron_3的形式存储。

        皮肤表面包的主要功能是获取加权点的迭代器范围、收缩因子和细分步骤数,并在 Polyhedron_3 中输出网格 

        其中,FT是Weighted_points使用的数字类型。

        为了更好地控制算法,还可以单独执行不同的步骤。首先,从加权点的迭代器范围和收缩因子中创建一个 Skin_surface_3 对象。可选参数是一个布尔值,它指示输入加权点是否应以这样的方式增长,即皮肤表面围绕输入球而不是收缩的输入球。

template <class SkinSurfaceTraits_3>
Skin_surface_3(WP_iterator begin, WP_iterator end,FT shrink_factor,bool grow_balls = true);

         模板参数应实现SkinSurfaceTraits_3概念。类型WP_iterator是SkinSurfaceTraits_3定义的加权点的迭代器,FT是加权点使用的数值类型。

        对于等于一的收缩因子,皮肤表面是输入球的并集的边界。在这种情况下,用于网格化皮肤表面的算法大大简化。这些优化在Union_of_balls_3类中实现。球并集类的构造函数类似,除了缺少收缩因子:

template <class SkinSurfaceTraits_3>
Union_of_balls_3(WP_iterator begin, WP_iterator end,bool grow_balls = true);

        使用概念SkinSurface_3的模型,可以生成与皮肤表面同质的粗网格。使用带有签名的函数mesh_skin_surface_3() 

template <class SkinSurface_3, class Polyhedron>
void mesh_skin_surface_3(const SkinSurface_3 &skin_surface, Polyhedron &p);

         最后一个函数采用(粗略的)网格,通过应用给定数量的1-4分割操作(每个三角形被分割成四个子三角形)并在皮肤表面移动新的顶点,在原地对网格进行细分。如果未指定迭代次数,则执行一次细分步骤。需要使用SkinSurface_3概念的对象来构造粗网格,以在皮肤表面上移动新的点。

template <class SkinSurface_3, class Polyhedron >
void subdivide_skin_surface_mesh_3 (const SkinSurface_3 &skinsurface,Polyhedron &p,int iterations = 1);

4、时间

        粗网格的构建和第一次细分的时间以秒为单位,在具有1Gb内存的Pentium 4、3.5 GHz上完成。

Data setNumber of weighted pointsCoarse meshfirst subdivision step
Caffeine230.2 sec.0.05 sec.
Gramicidin A3185 sec.2 sec.

CGAL 5.6 - 3D Skin Surface Meshing: User Manual 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/213047.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

html通过CDN引入Vue使用Vuex以及Computed、Watch监听

html通过CDN引入Vue使用Vuex以及Computed、Watch监听 近期遇到个需求&#xff0c;就是需要在.net MVC的项目中&#xff0c;对已有的项目的首页进行优化&#xff0c;也就是写原生html和js。但是咱是一个写前端的&#xff0c;写html还可以&#xff0c;.net的话&#xff0c;开发也…

期末速成数据库极简版【查询】(3)

目录 多表查询 【8】多表连接——内连接 &#x1f642;等值连接 &#x1f642;自然连接 &#x1f642;非等值连接 【9】多表连接——外连接 【10】交叉连接不考 【11】联合查询 【12】扩展多表连接 【13】嵌套查询 &#x1f642; 多表查询 【8】多表连接——内连…

OSPF路由协议

随着Internet技术在全球范围的飞速发展&#xff0c;OSPF已成为目前应用最广泛的路由协议之一。OSPF&#xff08;Open Shortest Path First&#xff09;路由协议是由IETF&#xff08;Internet Engineering Task Force&#xff09;IGP工作组提出的&#xff0c;是一种基于SPF算法的…

JS 云服务 Deno Depoly 宣布,推出定时运行功能 Deno Cron

如果需要定时执行 JS 脚本&#xff0c;以后多一个选项。 Web 构建日益复杂。编写现代软件包括利用云基础设施、剖析模板代码和管理复杂的配置&#xff0c;而开发人员只想专注于编写业务逻辑。 Deno 旨在通过删除配置和不必要的模板&#xff0c;从根本上简化 Web 开发。我们将无…

网络攻击(三)--攻击阶段

5. 威胁建模阶段 目标 了解威胁建模阶段的工作内容 工作内容 威胁建模主要使用在情报搜集阶段所获取到的信息&#xff0c;来标识出目标系统上可能存在的安全漏洞与弱点。 在进行威胁建模时&#xff0c;确定最为高效的攻击方法、所需要进一步获取到的信息&#xff0c;以及从…

【前端】CSS浮动(学习笔记)

一、浮动 1、传统网页布局 网页布局的本质&#xff1a;用 CSS 来摆放盒子&#xff0c;把盒子摆放到相应位置。 CSS 提供了三种传统布局方式&#xff08;盒子如何进行排列顺序&#xff09; 普通流&#xff08;标准流&#xff09;浮动定位 实际开发中&#xff0c;一个页面基…

Tomcat头上有个叉叉

问题原因&#xff1a; 这是因为它就是个空的tomcat,并没有导入项目运行 解决方案&#xff1a; war模式&#xff1a;发布模式&#xff0c;正式发布时用&#xff0c;将WEB工程以war包的形式上传到服务器 war exploded模式&#xff1a;开发时用&#xff0c;将WEB工程的文件夹直接…

【网络协议】LACP(Link Aggregation Control Protocol,链路聚合控制协议)

文章目录 LACP名词解释LACP工作原理互发LACPDU报文确定主动端确定活动链路链路切换 LACP和PAgP有什么区别&#xff1f;LACP与LAG的关系LACP模式更优于手动模式LACP模式对数据传输更加稳定和可靠LACP模式对聚合链路组的故障检测更加准确和有效 推荐阅读 LACP名词解释 LACP&…

智能外呼有什么好处?

智能外呼是一种自动化的电话营销方式&#xff0c;利用AI智能外呼技术和大量数据分析&#xff0c;帮助企业实现与客户之间的高效、精准、个性化的客户沟通&#xff0c;还可以在客户服务、市场营销和销售等方面带来助力。那么&#xff0c;智能外呼有什么好处呢&#xff1f; 1. 提…

通过生成模拟释放无限数据以实现机器人自动化学习

该工作推出RoboGen&#xff0c;这是一种生成机器人代理&#xff0c;可以通过生成模拟自动大规模学习各种机器人技能。 RoboGen 利用基础模型和生成模型的最新进展。该工作不直接使用或调整这些模型来产生策略或低级动作&#xff0c;而是提倡一种生成方案&#xff0c;该方案使用…

simulink MATLABFunction模块中实时函数调用函数的使用

样例 function Predyy matlabceshi(input, Time_s) input1 input; Time_s1 Time_s; Predyy ee(input1) mm(Time_s1); end 上面是主要部分&#xff0c;下面是被调用部分 function A ee(input1) A input1 * 100; end function B mm(Time_s1) B Time_s1 * 100; end 模型…

Linux(ubuntu)利用ffmpeg+qt设计rtsp_rtmp流媒体播放器(完全从0开始搭建环境进行开发)

一、前言 从0开始搭建Linux下Qt、ffmpeg开发环境。 从安装虚拟机开始、安装Linux(Ubuntu)系统、安装Qt开发环境、编译ffmpeg源码、配置ffmpeg环境、编写ffmpeg项目代码、完成项目开发。 完全从0开始搭建环境进行开发 完全从0开始搭建环境进行开发 完全从0开始搭建环境进行开…

公务员国考省考小白需知

文章目录&#xff1a; 一&#xff1a;分类 1.国考 2.省考 二&#xff1a;必备途径 1.相关网站 1.1 官网 1.1.1 必须知道的 1.1.2 比较好用的 1.1.3 事业单位的 1.2 机构 ​​1.3 时事 ​​1.4 资源 1.5 题库 1.6 真题 ​2.相关公主号 3.应用 4.群聊如何找 三…

【TwinCAT学习笔记 1】TwinCAT开发环境搭建

写在前面 作为技术开发人员&#xff0c;开启任何一项开发工作之前&#xff0c;首先都要搭建好开发环境&#xff0c;所谓磨刀不误砍材工&#xff0c;一定要有耐心&#xff0c;一次不行卸载再装。我曾遇到过一个学生&#xff0c;仅搭建环境就用了两周&#xff0c;这个过程也是一…

SSD数据在写入NAND之前为何要随机化?-part2

接part1介绍&#xff1a; 如何达到这个目的&#xff1f;业内常用的是对写入数据的数据进行随机化处理&#xff0c;这部分主要在SSD控制器中通过硬件实现。 上图b/c&#xff1a;在控制器芯片通过硬件方式实现随机化的读写流程&#xff0c;这个也是业内通常做法。随机化处理是在写…

【K8S in Action】服务:让客户端发现pod 并与之通信(1)

服务是一种为一组功能相同的 pod 提供单一不变的接入点的资源。当服务存在时&#xff0c;它的 IP 地址和端口不会改变。 客户端通过 IP 地址和端口号建立连接&#xff0c; 这些连接会被路由到提供该服务的任意一个 pod 上。 pod 是短暂&#xff0c;会删除增加&#xff0c;调度…

Android 13 Settings蓝牙列表卡顿问题排查及优化过程

一.背景 此问题是蓝牙列表界面息屏后再点击亮屏蓝牙界面卡住,划不动也不能返回,在人多的时候(附近开启的蓝牙设备过多的时候)会卡住大概四五秒才能滑动. 优化前效果见资源: 二.查找耗时点 根据Android Studio的Profiler工具进行排查,查找主线程时间线比较长的方法,如下:…

IDEA远程调试与JDWP调试端口RCE漏洞

文章目录 前言Docker远程调试Java调试原理远程调试实践 JDWP端口RCE调试端口探测调试端口利用 总结 前言 在对一些 Java CVE 漏洞的调试分析过程中&#xff0c;少不了需要搭建漏洞环境的场景&#xff0c;但是本地 IDEA 搭建的话既麻烦&#xff08;通过 pom.xml 导入各种漏洞组…

Zookeeper系统性学习-应用场景以及单机、集群安装

Zookeeper 是什么&#xff1f; Zookeeper 为分布式应用提供高效且可靠的分布式协调服务&#xff0c;提供了诸如统一命名服务、配置管理和分布式锁等分布式的基础服务。在解决分布式数据一致性方面&#xff0c;ZooKeeper 并没有直接采用 Paxos 算法&#xff0c;而是采用了名为 …

Android Studio Gradle下载慢解决方法

Android Studio Gradle下载慢解决方法 最近在练习模型部署&#xff0c;主要是在手机端部署&#xff0c;所以使用到了Android Studio&#xff0c;但是在创建项目的时候&#xff0c;一致在下载gradle&#xff0c;而且网速还很慢&#xff0c;不对&#xff0c;是极慢哪种&#xff0…