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.hqwc.cn/news/264796.html

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

相关文章

Course3-Week1-无监督学习

Course3-Week1-无监督学习 文章目录 Course3-Week1-无监督学习1. 欢迎1.1 Course3简介1.2 数学符号约定 2. K-means算法2.1 K-means算法的步骤2.2 代价函数2.3 选择聚类数量 3. 异常检测3.1 异常检测的直观理解3.2 高斯分布3.3 异常检测算法3.4 选取判断阈值 ε \varepsilon ε…

LV.13 D2 开发板启动流程 学习笔记

一、开发板启动过程 EMMC&#xff1a;相当于电脑的外存&#xff0c;断电不丢失 开发板上电后首先运行SOC内部iROM中固化的代码(BL0)&#xff0c;这段代码先对基本的软硬件环境(时钟等...)进行初始化&#xff0c;然后再检测拨码开关位置获取启动方式&#xff0c;然后再将对应存储…

【Web】SCU新生赛个人wp及完赛感想

目录 一些碎碎念&#xff1a; Web Guideline 2048 ezupload hardupload ezphp ezweb ezsql webbuilder tarit tarit_revenge VipDinner simplespi 一些碎碎念&#xff1a; scu新生赛是我全心全力打的第二场比赛&#xff0c;历时七天&#xff0c;期间不免煎熬&…

PPP协议概述与实验示例

PPP协议概述与实验示例 概述 PPP&#xff08;Point-to-Point Protocol&#xff09;是一种用于在点对点连接上传输多协议数据包的标准方法。它已经成为最广泛使用的互联网接入数据链路层协议&#xff0c;可以与各种技术结合&#xff0c;如ADSL、LAN等&#xff0c;实现宽带接入…

GM 串口图像显示软件 V1.1

GM 串口图像显示软件 V1.1 将串口数据转换成多种格式的图像软件 针对V1.0更新了通信协议 GM 串口图像显示软件 V1.1 by 李锦上功能简介将串口收到的图像数据按图像格式显示出来支持多种格式的图像支持按行更新图像支持多行更新图像占用MCU资源小 通信成功率高通信协议&am…

Landsat7_C2_SR数据集(大气校正地表发射率数据集)

Landsat7_C2_SR数据集是经大气校正后的地表反射率数据&#xff0c;属于Collection2的二级数据产品&#xff0c;空间分辨率为30米&#xff0c;基于Landsat生态系统扰动自适应处理系统&#xff08;LEDAPS&#xff09;&#xff08;版本3.4.0&#xff09;生成。水汽、臭氧、大气高度…

PSO 优化 LQR 权重系数(2)

PSO 优化 LQR 权重系数&#xff08;2&#xff09; 主要编写了 MATLAB 代码&#xff0c;能够正常运行&#xff0c;注释还是比较详细的 %% 清空工作空间并跑一下路径规划 clc; clear all; run(double_lane.m);%% 基本参数设置 % 车辆参数 cf-66900*2; cr-62700*2; m1723; Iz417…

openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup

文章目录 openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup151.1 背景信息151.2 前提条件151.3 语法151.4 示例151.5 从备份文件恢复数据 openGauss学习笔记-151 openGauss 数据库运维-备份与恢复-物理备份与恢复之gs_basebackup 151.1 …

Oracle-pl/sql developer客户端连接报错问题分析

问题一&#xff1a; 用户在windows电脑使用pl/sql developer客户端使用tns方式连接数据库时&#xff0c;出现ORA-12170 TNS连接超时报错 使用ezconnect方式连接可以成功 问题一分析: 首先&#xff0c;查看pl/sql developer软件的Oracle客户端配置configure-->preferences,确…

麒麟系统使用桌面共享远程桌面

客户端安装vinager 服务端 安装 vnc4server xrdp tightvncserver vino 安装完成后 需要重启 在用户的家目录下新建 .xsession 写入xfce4-session防止闪退 雪花屏 开启xrdp服务 远程链接 Vnc只能链接系统登录的用户 Rdp可以链接所有普通用户

晶圆划片机助力LED陶瓷基板高效切割:科技提升产业新高度

博捷芯半导体划片机在LED陶瓷基板制造领域&#xff0c;晶圆划片机作为一种先进的切割工具&#xff0c;正在为提升产业效率和产品质量发挥重要作用。通过精确的切割工艺&#xff0c;晶圆划片机将LED陶瓷基板高效地切割成独立的芯片&#xff0c;为LED产业的快速发展提供了有力支持…

【队列】数据也得排队

目录 引言 队列的概念 队列的实现 单向链表队列 结构 初始化 入队 出队 取队头 取队尾 求个数 判空 内存释放 总结 引言 队列&#xff0c;这个看似普通的数据结构&#xff0c;其实隐藏着无尽的趣味和巧思。就像单向链表这把神奇的魔法钥匙&#xff0c;它能打开队…