B样条曲线(记录)

news2025/1/12 1:59:10

        B样条曲线的生成靠的两点:

                1、控制点

                2、基函数

        B样条曲线的基函数是一个De Boor的递归表达式[1]:

                B_{i},_{0}(u)=\left\{\begin{matrix} 1, u_{i}\leqslant u\leqslant u_{i+1}\\0, otherwise \end{matrix}\right.                                                                (1)

                B_{i},_{d}(u)=\frac{u-u_{i}}{u_{i+d}-u_{i}}B_{i},_{d-1}(u)+\frac{u_{i+d+1}-u}{u_{i+d+1}-u_{i+1}}B_{i+1},_{d-1}(u)                    (2)

        其中B_{i},_{d}(u)是第id阶基函数。

        而B样条曲线可以表示为[2]:

                P(u)=\sum_{i=0}^{n}p_{i}B_{i},_{d}(u)                                                                        (3)

        如何理解上式?首先,我们知道,如果一个函数在定义域内处处可微(处处连续),则可以通过被泰勒展开成一个多项式级数。换言之,只要阶数足够,对于任意的连续可微曲线,都可以用一个多项式去逼近。B样条曲线的表达式就是一个d阶多项式。它的定义域通过节点区间来表示[1][2]。

        接下来,我们通过一个简单的例子来逐步理解B样条曲线。

        我们以3个控制点的B样条曲线为例。其表达式为:

                P(u)=p_{0}B_{0},_{d}(u)+p_{1}B_{1},_{d}(u)+p_{2}B_{2},_{d}(u)

        现在我们来看一下上式的3个基函数。由式(2),我们可知d-1阶的基函数如下图:

d-1阶基函数的个数为:3\cdot 2-2=4,简单归纳一下:

        设N为控制点的个数,则d阶的基函数个数也为N,而d-1阶的基函数个数为:N\cdot 2-(N-1)=N+1。即低一阶的基函数个数是高一阶加一。则0阶的基函数的个数为:

\left ( \left ( \left ( \left ( \left ( N \right )+1 \right )+1 \right )+1 \right )+...+1 \right )=N+d

        另外,对于多项式的阶,必须小于已知数据点数的个数。于是我们设d=N-1。则0阶的基函数个数为2N-1,为奇数。

        接下来,我们来看看节点区间。对于0阶基函数,一个基函数对应一个节点区间。所以节点区间的个数,我们以3个0阶基函数为例:

为3个区间,共计4个节点,也即节点数为0阶基函数个数加一,即2N个节点。

        另外,当我们选取一个参数u时,由于节点区间不相交,所以我们由式(1)可知0阶基函数,由且只有一个基函数的值为1。其余皆为0。考虑如下情况:

u取在区间[u_{i},u_{i+1})时,我们可以发现在1阶基函数,所有基函数相机等于1。因为0阶基函数只有一个起作用,而其余基函数的值为0.递推到1阶,所有1阶基函数,变为2个基函数起作用。而这两个基函数相加:B_{i-1},_{1}(u)+B_{i},_{1}(u)=\frac{u_{i+1}-u}{u_{i+1}-u_{i}}B_{i},_{0}(u)+\frac{u-u_{i}}{u_{i+1}-u_{i}}B_{i},_{0}(u)=B_{i},_{0}=1

        同理,到了2阶基函数,我们可以得到:

B_{i-2},_{2}(u)+B_{i-1},_{2}(u)=B_{i-1},_{1}(u)           B_{i-1},_{2}(u)+B_{i},_{2}(u)=B_{i},_{1}(u)

也即2阶基函数相加也等于1。以此类推,我们得出一个结论,d阶基函数相加等于1。

        现在来考虑如下的递归过程。假设我们有4个控制点,阶数d=3。于是基函数的传递如下:

假如我们把u取在[u_{0},u_{1})内,则B_{0},_{0}=1,而其余0阶基函数为0。按照以上的结论,我们知道

B_{0},_{0}(u)=B_{-1},_{1}(u)+B_{0},_{1}(u)=1,而实际上,没有B_{-1},_{1}(u)。于是到了1阶,基函数之和不等于1。而且每进一阶,基函数之和都会有损失。

        同时,我们还希望,当u取u=u_{0}或者u=u_{2n-1}时,曲线与控制点0或者控制点n重合。换句话说,就是曲线在端点处与控制点重合,也即B_{0},_{3}(u)=1,而其余3阶基函数等于0。很明显,u=u_{0}无法使以上条件成立。为了实现以上条件,必须解决基函数之和损失的问题。那么u就必须取在区间[u_{3},u_{4})内。当u=u_{3}时,递归到3阶可得B_{0},_{3}(u)=1,而其余为0。当u=u_{4}时,递归到3阶可得B_{3},_{3}(u)=1,而其余为0。因此为了满足基函数之和为1。而且当u取在区间端点时,曲线与控制点重合。我们必须舍弃[u_{3},u_{4})之外的区间。这个操作叫“重复度”。具体的操作是令u_{3}之前的节点都等于u_{3}。而u_{4}之后的节点都等于u_{4}。也即[u_{d},u_{d+1})区间之外,其余区间节点都分别赋值u_{d},u_{d+1}

        例如,原本各区间为[u_{0}=0,u_{1}=1),[u_{1}=1,u_{2}=2),[u_{2}=2,u_{3}=3),[u_{3}=3,u_{4}=4),[u_{4}=4,u_{5}=5),[u_{5}=5,u_{6}=6),[u_{6}=6,u_{7}=7]。进行“重复度”操作后,节点区间变为:[u_{0}=3,u_{1}=3),[u_{1}=3,u_{2}=3),[u_{2}=3,u_{3}=3),[u_{3}=3,u_{4}=4),[u_{4}=4,u_{5}=4),[u_{5}=4,u_{6}=4),[u_{6}=4,u_{7}=4],甚至干脆,我们取u_{3}=0,u_{4}=1

        接下来,我们设\alpha =\frac{u_{i+1}-u}{u_{i+1}-u_{i}},\beta =\frac{u-u_{i}}{u_{i+1}-u_{i}},我们可以得到如下的基函数系数传递图:

则我们可以得到d阶第i个基函数为B_{i},_{d}(u)=Q_{i},_{d}\alpha ^{d-i}\beta ^{i}B_{d},_{0}(u)=Q_{i},_{d}\alpha ^{d-i}\beta ^{i},其中Q_{i},_{d}为如下分布的系数:

以上三角序列为杨辉三角序列,因此Q_{i},_{d}=C^{i}_{d},i\in [0,d]

参考:

1、样条曲线曲面-3:BSpline的原理

2、详解B样条曲线

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

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

相关文章

高端的电子画册,手机打开你见过吗?

手机阅读的高端电子画册,你见过吗?随着移动互联网的发展,越来越多的人选择在手机上阅读电子画册,而不是传统的纸质画册。这种趋势不仅节省了纸张资源,还提升了阅读体验。用户可以通过触摸屏幕、放大缩小、翻页等操作与…

【Blockchain】区块链浏览器 | 以太坊Etherscan比特币Blockchain门罗币Monero

区块链浏览器概述 区块链浏览器是一种软件,它使用API(应用程序编程接口)和区块链节点从区块链中提取各种数据,然后使用数据库来排列搜索到的数据,并以可搜索的格式将数据呈现给用户。 用户的输入是资源管理器上的可搜索项,然后通过数据库上…

empdll文件安装在哪里,详细的修复教程分享

在我们运行《荒野大镖客2》游戏的时候,有些玩家在游玩过程中可能会遇到emp.dll文件丢失的问题。此文件作为游戏运行过程中不可或缺的动态链接库(DLL)组件之一,丢失会导致游戏无法正常运行。小编将介绍5种解决emp.dll文件丢失的方法…

linux安装Zookeeper的详细步骤

1.Java环境确认 确保已经安装了Java环境,没有的自行安装 2.官网下载包 Apache ZooKeeper 3.安装 3.1上传到linux,解压 我的目录为/root/apache-zookeeper-3.8.4-bin 进入到/root/apache-zookeeper-3.8.4-bin/conf目录下,执行命令复制zoo…

C++2D原创我的世界1.00.3版本上市!!!

我很郁闷,为什么就是整不了昼夜交替啊喂!!!!!!!! 虽然这看上去很简单,但做起来要我命!!! 优化过后总共1312行&#xff0c…

微信公众号迁移公证书在哪?

公众号迁移有什么作用?只能变更主体吗?很多小伙伴想做公众号迁移,但是不知道公众号迁移有什么作用,今天跟大家具体讲解一下。首先公众号迁移最主要的就是修改公众号的主体了,比如我们公众号原来是A公司的,现…

指针强化练习(详解)

更多学习内容 结构体内存对齐 和 位段-CSDN博客指针初级(基础知识)-CSDN博客指针进阶(深入理解)-CSDN博客 目录 1.sizeof与strlen的区别 2.一维数组 3.字符指针 4.二维数组 5.指针运算(笔试题) 6.函数指针 1.sizeof与strlen的区别 请思考以下运行结…

第1章.提示词:开启AI智慧之门的钥匙

什么是提示词? 提示词,是引导语言模型的指令,让用户能够驾驭模型的输出,确保生成的文本符合需求。 ChatGPT,这位文字界的艺术大师,以transformer架构为基石,能轻松驾驭海量数据,编织…

Chrome浏览器隐藏的截图功能配置及使用

来自实用又方便,轻松打开Chrome浏览器隐藏的截图功能!​​​​​​​ 一、通过谷歌Chrome浏览器 现在直接通过谷歌Chrome浏览器内置功能,免安装扩充插件也可以实现Chrome的截图和长截图功能了! 也不需要额外安装任何截图工具 &a…

【C++航海王:追寻罗杰的编程之路】priority_queue(优先队列) | 容器适配器你知道哪些?

目录 1 -> priority_queue的介绍和使用 1.1 -> priority_queue的介绍 1.2 -> priority_queue的使用 1.3 -> priority_queue的模拟实现 2 -> 容器适配器 2.1 -> 什么是适配器 2.2 -> STL标准库中stack和queue的底层结构 2.3 -> deque的介绍 2.…

吐丝的蜘蛛-第15届蓝桥第5次STEMA测评Scratch真题精选

[导读]:超平老师的《Scratch蓝桥杯真题解析100讲》已经全部完成,后续会不定期解读蓝桥杯真题,这是Scratch蓝桥杯真题解析第176讲。 如果想持续关注Scratch蓝桥真题解读,可以点击《Scratch蓝桥杯历年真题》并订阅合集,…

MySQL面试必备一之索引

本文首发于公众号:Hunter后端 原文链接:MySQL面试必备一之索引 在面试过程中,会有一些关于 MySQL 索引相关的问题,以下总结了一些: MySQL 的数据存储使用的是什么索引结构B 树的结构是什么样子什么是复合索引、聚簇索…

嵌入式第一部分-第一集:ARM那些你得知道的事

ARM:Advanced RISC Machine,先进精简指令集机器 ARM公司只做设计,不生产。 国内IC生产厂商:华为海思、全志、瑞芯微、MTK(联发科) 扩展:ARM的商业模式了解。 使用三星S5PV210开发板进行视频的讲…

红黑树介绍及插入操作的实现

🎉个人名片: 🐼作者简介:一名乐于分享在学习道路上收获的大二在校生 🙈个人主页🎉:GOTXX 🐼个人WeChat:ILXOXVJE 🐼本文由GOTXX原创,首发CSDN&…

CubeIDE 下如何将版本号和日期关联。

1. 使用__DATE__ 和__TIME__获取编译日期和时间。 2. 将__DATE__ 和__TIME__转换成UINT 3. 将转换后的数赋值给版本号。 4. 设置工程保证每次都会重新编译对应文件。 对应函数如下&#xff1a; uint8_t VER_MAIN; uint8_t VER_SUB; uint8_t VER_MIN; #include <stdlib.…

原子类 AtomicReference 详解

通过对 AtomicInteger、AtomicBoolean 和 AtomicLong 分析我们发现&#xff0c;这三个原子类只能对单个变量进行原子操作&#xff0c;那么我们如果要对多个变量进行原子操作&#xff0c;这三个类就无法实现了。那如果要进行多个变量进行原子操作呢&#xff1f;操作方式就是&…

node.js的错误处理

当我打开一个不存在的文件时&#xff0c;错误如下&#xff1a; 在读取文件里面写入console.log&#xff08;err&#xff09;&#xff0c;在控制台中可以看到我的错误代码类型&#xff1a;文件不存在的错误代码 ENOENT。见更多错误代码---打开node.js官方API文档Error 错误 | N…

AtCoder Beginner Contest 347 A - E

A - Divisible 大意 给定个数&#xff0c;对于其中能被整除的数&#xff0c;输出商。 思路 直接计算即可。 代码 #include<iostream> using namespace std; int main(){ios::sync_with_stdio(0);cin.tie(0), cout.tie(0);int n, k;cin >> n >> k;while…

IDEA 详细设置

详细设置 如何打开详细配置界面 1、显示工具栏 2、选择详细配置菜单或按钮 系统设置 默认启动项目配置 启动IDEA时&#xff0c;默认自动打开上次开发的项目&#xff1f;还是自己选择&#xff1f; 如果去掉Reopen projects on startup前面的对勾&#xff0c;每次启动IDEA就会…

OSCP靶场--Access

OSCP靶场–Access 考点( 文件上传[黑名单apache.htaccess绕过] Kerberoasting SeManageVolume滥用提权) 1.nmap扫描 ┌──(root㉿kali)-[~/Desktop] └─# nmap 192.168.216.187 -sV -sC -Pn --min-rate 2500 -p- Starting Nmap 7.92 ( https://nmap.org ) at 2024-03-3…