当前位置: 首页 > news >正文

【3维视觉】网格细分Mesh Subdivision算法介绍(Loop, Catmull-Clark, Doo-Sabin)

引言

介绍了Loop, Catmull-Clark, Doo-Sabin细分。

算法介绍

1. Loop细分

Loop细分是Charles Loop在1987年在硕士论文中提出的一种对三角网格的细分算法。
Loop细分是递归定义的,每一个三角形一分为四,对于新生成的点和旧点以不同的规则更新。

点的更新规则:

2. Catmull-Clark细分

Catmull-Clark细分是Edwin CatMull和Jin Clark在1978年提出的一种可以对任意拓扑的网格进行细分的一种算法,是递归定义的,在每一次递归中:

  • 计算面点,是面的顶点的平均值
  • 计算边点,是边的顶点和相邻的面点的平均值
  • 计算旧的顶点,n是与点相邻的边数量, Q是相邻的面点的平均值,R是相邻的边点的平均值,v是本来的顶点
    在这里插入图片描述
  • 生成新的拓扑

3. Doo-Sabin细分

Doo-Sabin细分是Dainel Doo和Malcolm Sabin在1978年提出的一种可以对任意拓扑的网格进行细分的一种算法,是递归定义的,在每一次递归中:

  • 计算面的中心点和边的中心点,对于每一个点P,计算一个新的点P’, 是点,相邻的边的中心点和面的中心点的平均值。

  • 对于每一个面,连接面内的新点生成新的面

    在这里插入图片描述

  • 对于每一个点,连接点周围的新点生成新的面

    在这里插入图片描述

  • 对于每一条边,连接边相邻的新点生成新的面

参考资料

[1] Mesh-Subdivision(Github)

[2] loop曲面细分算法c++实现 https://blog.csdn.net/suian0424/article/details/86371383

[3] Doo-sabin曲面 http://graphics.cs.ucdavis.edu/education/CAGDNotes/Doo-Sabin/Doo-Sabin.html

[4] 细分曲面Catmull-Clark Subdivision算法 https://blog.csdn.net/tspatial_thunder/article/details/5938771

http://www.lryc.cn/news/38771.html

相关文章:

  • 自学大数据第六天~HDFS命令
  • maven仓库的配置
  • 医院信息管理云平台源码 云HIS系统源码 4级电子病历系统
  • JS学习第9天——ES6中面向对象(类class、constructor构造函数、类的继承extends、super关键字、面向对象tab栏切换案例)
  • K8S核心秘术学习总纲
  • 【PTA-训练day27】L2-038 病毒溯源 + L2-039 清点代码库 + L2-040 哲哲打游戏
  • 新一代跨平台云备份工具Duplicacy
  • 考研复试——概率论
  • Web学习4_JavaScript常用库
  • C++回顾(二十)—— vector容器 和 deque容器
  • httpd使用记录
  • .vue 组件打包成 .js
  • Java 代码分享(第11篇)编程解决数学问题:“计算3个10以内的数字,与合计值相除后,商的第3位小数大于4,共有多少个数的组合满足条件”类似问题
  • 面试题 17.05. 字母与数字
  • 解决Win10图片/文件右键单击自动退出并刷新桌面问题
  • 【代码随想录训练营】【Day39】第九章|动态规划|62.不同路径|63. 不同路径 II
  • 【Linux】linux | 修改系统编码 |  增加字体处理 | 图片处理字体变成方块
  • R语言介绍及安装教程
  • Linux 练习九 (IPC 消息队列)
  • 在Win 11下使用Visual Studio 2019和cygwin编译JBR(Java SDK 17)源码
  • java基础学习 day51 (匿名内部类)
  • Spring MVC程序开发(三大功能)
  • stack,queue
  • shiro反序列化
  • 【GoF 23 概念理解】IoC/DI(控制反转/依赖注入)
  • stm32外设-GPIO
  • AfxMessageBox 自定义封装
  • 登入vCenter显示503,证书过期解决办法
  • 设计模式(十九)----行为型模式之命令模式
  • 【数据库】数据库基础架构