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,一经查实,立即删除!

相关文章

力扣labuladong——一刷day70

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、力扣814. 二叉树剪枝二、力扣1325. 删除给定值的叶子节点 前言 这道题的难点在于要一直剪枝&#xff0c;直到没有值为 0 的叶子节点为止&#xff0c;只有从…

RecursionError: maximum recursion depth exceeded in comparison

诸神缄默不语-个人CSDN博文目录 这个bug的产生原因是运行rouge包时句子太长&#xff0c;所以递归次数过多了。完整的报错信息懒得粘了&#xff0c;总之很长&#xff0c;解决方案就是手动在程序开始处就增大递归次数&#xff1a; import sys sys.setrecursionlimit(100000)具体…

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

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

K8S学习指南-minikube的安装

简介 Minikube 是一个用于在本地开发环境中运行 Kubernetes 集群的工具。它允许开发人员在单个节点上体验 Kubernetes&#xff0c;无需配置复杂的生产环境。本指南将详细介绍在 Windows、CentOS 和 Ubuntu 系统上安装 Minikube 的步骤。 1. Windows 系统安装 1.1 &#xff1…

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

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

HIVE学习(hive基础)

HIVE基础介绍 一、HIVE简介二、hive的数据类型1、基本数据类型2、复合数据类型 三、HIVE的DDL操作四、创建一个表1. 建表语句 五、修改表结构1.修改表名2. 列修改或增加3. 修改分区 五、常见函数六、一对一关联left join左关联right join 右关联内连接全连接查询只有A表的数据 …

计算机视觉-机器学习-人工智能顶会 会议地址

计算机视觉-机器学习-人工智能顶会 会议地址 最近应该要整理中文资料的参考文献&#xff0c;很多会议文献都需要补全会议地点&#xff08;新国标要求&#xff09;。四处百度感觉也挺麻烦的&#xff0c;而且没有比较齐全的网站可以搜索。因此自己整理了一下计算机视觉-机器学习…

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;一个页面基…

Go 反射技术判断结构体字段数据为空

Api介绍 在Go语言中&#xff0c;反射API用于在运行时检查类型信息、获取和修改变量的值以及调用对象的方法。反射API包含了一组函数和类型&#xff0c;可以在程序运行时动态地操作对象。 以下是一些常用的反射API&#xff1a; reflect.TypeOf&#xff1a;返回一个值的类型信息。…

并查集基础模板

题目我上面有人儿 代码 #include <bits/stdtr1c.h> using namespace std; const int N 1005; int f[N]; int n; int siz[N]; // 初始化并查集 // void init() // { // for (int i 1; i < n; i) // { // f[i] i; // 初始化所有的节点都是自己的父节点 //…

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&…

day11 前k个高频元素

// 小顶堆 class mycomparison { public: bool operator()(const pair<int, int>& lhs, const pair<int, int>& rhs) { return lhs.second > rhs.second; } }; vector<int> topKFrequent(vector<int>& nums, int k) { // 要统计元素出现…

智能外呼有什么好处?

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

spring IOC bean为什么默认是单例的

首先解释一下什么是单例 bean&#xff1f; 单例的意思就是说在 Spring IoC 容器中只会存在一个 bean 的实例&#xff0c;无论一次调用还是多次调用&#xff0c;始终指向的都是同一个 bean 对象 用代码来解释单例 bean public class UserService {public void sayHello() {Syst…

交叉编译工具链makefile

linux系统默认搜索头文件地址&#xff1a;/usr/include/文件夹&#xff1b; Windows系统默认搜索头文件地址&#xff1a;不同软件好像可以设置不同的地址&#xff1b;例如visual studio好像可以设置附加包含目录&#xff0c;包含目录等 Linux系统库文件路径&#xff1a;/lib文…

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

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