B樣條系列(1)


B樣條曲線

定義

B樣條的形式與Bezier曲線的定義方式相同,是B-樣條基函數的線性組合。

給定n+1個控制點\(P_i(i=0,1,...,n)\)和一個節點向量\(U=\{u_0,u_1,..., u_m\}\),且\(m=n+p+1\),依次連接這些控制點可以構成一個特征多邊形,k+1階(k次)B樣條曲線的表達式為

\[p(u)=\sum_{i=0}^nP_iN_{i,k}(u) \]

其中\(u_i\)稱為節點(knots)\(u_0 <= u_1 <= u_2 <= ... <= u_m\), 半開區間\([u_i, u_i+1)\) 是第i個節點區間。。如果基函數的節點是允許存在重復的,如果\(u_i\)出現了k次(k>1),那么稱其為k重節點。如果\(u_i\)僅出現一次,那么稱其為簡單節點。節點等間距(\(u_i+1 - u_i\)是一個常數,對\(0<=i<=m-1\)),節點向量或節點序列稱為均勻的;否則它是非均勻的。

基函數

B樣條的基函數由三個參數決定:階數p,參數u,第i個基函數,Cox-de Boor遞歸定義如下:

\[N_{i, 0}(u) =\begin{cases} 1, \ if \ u_i \leq u < u_{i+1}\\ 0, \ otherwise \end{cases} \\ N_{i, p}(u) = \frac{u - u_i}{u_{i+p}-u_i}N_{i,p-1}(u) + \frac{u_{i+p+1} - u}{u_{i+p+1}-u_{i+1}}N_{i+1,p-1}(u) \]

B樣條基函數\(N_{i,p}\)的作用范圍是局部的,因此與Bezier曲線不同,移動控制點\(N_{i,p}\)對B樣條的影響是局部的。其導數為

\[\frac{d}{du}N_{i,p}(u)=N'_{i,p}(u)=\frac{p}{u_{i+p}-u_i}N_{i,p-1}-\frac{p}{u_{i+p+1}-u_{i+1}}N_{i+1,p-1} \]

曲線形狀

由控制點的位置(n+1),節點位置(m+1),和曲線的次數p決定。

  • 開B-樣條曲線:產生的曲線不會與控制折線的第一邊和最后一邊接觸。
  • clamped B-樣條曲線:強制第一個節點和最后一個節點的重復度為p+1,那么產生的曲線就會分別與第一個控制點和最后一個控制點的第一邊和最后一邊相切,首尾點分別與首尾控制點相同。
  • 閉B-樣條曲線:通過重復某些節點和控制點,產生的曲線會是閉曲線。會產生閉環

擬合

給定已知點集\(\{F_0,F_1,…,F_t\}\)\(t+1\)個點,求B樣條曲線。其中要求必須經過所有點稱為插值擬合,否則稱為近似擬合,近似擬合必經\(F_0\)\(F_t\),其他點可以不經過。下面是點集相同時兩種擬合對應的曲線。

近似擬合

近似擬合

插值擬合

插值擬合

插值擬合

由已知條件可知

\[\left[\begin{matrix} N_0(u_0) & \cdots & N_i(u_0) & \cdots & N_p(u_0) \\ N_0(u_1) & \cdots & N_i(u_1) & \cdots & N_p(u_1) \\ \vdots & & \vdots & & \vdots\\ N_0(u_t) & \cdots & N_i(u_t) & \cdots & N_p(u_t) \\ \end{matrix} \right] \left[ \begin{matrix} P_0 \\ \vdots \\ P_i \\ \vdots\\ P_n \end{matrix} \right] = \left[ \begin{matrix} F_0 \\ F_1 \\ \vdots\\ F_t \end{matrix} \right] \tag 1 \]

1. 參數化

\(F_i\)確定\(u_i\)的過程,稱之為參數化(Parameterization)。常見的參數化方法有三種:弦長累加法(chord length),向心參數法(也稱平方根法),統一節點法。其中前兩種最為常用。

  1. 弦長累加法:指的是,當前型值點\(Fi\)的參數,等於之前所有型值點長度的累加\(∑_{j=1}^i|F_{j−1}F_j|\)。這種方法是“Arc-Length”參數法的一種近似,選用弦長代替弧長,因此具有比較好的效果。
  2. 向心參數法:這個方法由波音公司的技術人員提出。指的是當前型值點的參數是由之前所有型值點長度的平方根累加的值\(∑_{j=1}^i\sqrt{|F_{j−1}F_j|}\),通常情況下,這個方法的效果要好於弦長累加法,尤其是在節點分布不均勻的情況下。
  3. 統一節點法:顧名思義,每個節點的間隔都是相等的。這種方法不怎么在實踐中獲得應用。

2.階次

B-Spline的三個要素是節點(序列)、階次、控制點。階次由我們確定。樣條曲線的性質是n階B樣條在節點處有n-1階連續性。這里選擇p=3,進而得出曲線的節點序列為(clamped B樣條曲線):

\[\{0,0,0,0,u_1,\cdots,u_i,\cdots,u_t,u_t,u_t,u_t\} \]

這樣就確定了每個節點對應的基函數的值,從而N已知,F已知,但前面方程\((1)\)是一個欠定方程,節點數為t+7個,對應控制點為m-p-1=t+3個,沒有唯一解,所以至少還需要與t有關的兩個邊界條件。

3.邊界條件

一般來說,最常用或者說最實用的邊界條件通常是兩條:曲線在首尾點的切矢量。常用的切矢量推導算法是”Bessel Tangents“。再結合B樣條的求導,可以知道首尾處的導數為

\[\begin{cases} C'(0)=\frac{p}{u_{p+1} - u_1}(P_1 - P_0); \\ C'(u_t)=\frac{p}{u_{p+n} - u_n}(P_n - P_{n-1}); (n = t + 2) \end{cases} \]

\[\left[ \begin{matrix} -1 & 1 & 0 & \cdots & 0 \\ 0 & \cdots & 0 & -1 & 1 \end{matrix} \right] \left[ \begin{matrix} P_0 \\ \vdots \\ P_i \\ \vdots\\ P_n \end{matrix} \right] = \left[ \begin{matrix} C'(0)\frac{u_{p+1} - u_1}{p} \\ C'(u_t)\frac{u_{p+n} - u_n}{p} \end{matrix} \right] \tag2 \]

聯合(1)(2)式,即可求解出所有的控制點。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM