Progressive-iterative approximation method is an iterative method of data fitting with geometric meanings.[1] Given the data points to be fitted, the method obtains a series of fitting curves (surfaces) by iteratively updating the control points, and the limit curve (surface) can interpolate or approximate the given data points. It avoids solving a linear system of equations directly and allows flexibility in adding constraints during the iterative process. Therefore, it has been widely used in geometric design and related fields.
The study of the iterative method with geometric meaning can be traced back to the work of scholars such as Prof. Dongxu Qi and Prof. Carl de Boor in the 1970s. In 1975, Qi et al. developed and proved the "profit and loss" algorithm for uniform cubic B-spline curves,[2] and in 1979, de Boor independently proposed this algorithm.[3] In 2004, Hongwei Lin and coauthors proved that non-uniform cubic B-spline curves and surfaces have the "profit and loss" property.[4] Later, in 2005, Lin et al. proved that the curves and surfaces with normalized and totally positive basis all have this property and named it progressive iterative approximation (PIA). In 2007, Maekawa et al. changed the algebraic distance in PIA to geometric distance and named it geometric interpolation (GI).[5] In 2008, Cheng et al. extended it to subdivision surfaces and named the method progressive interpolation (PI).[6] Since the iteration steps of the PIA, GI, and PI algorithms are similar and all have geometric meanings, we collectively referred to them as geometric iterative methods (GIM).[7]
PIA is now extended to several common curves and surfaces in the geometric design field,[8] including NURBS curves and surfaces,[9] T-spline surfaces,[10] implicit curves and surfaces,[11] etc.
Generally, progressive-iterative approximation can be divided into interpolation and approximation schemes. In interpolation algorithms, the number of control points is equal to that of the data points; in approximation algorithms, the number of control points can be less than that of the data points. Specifically, there are some representative iteration methods, such as local-PIA, implicit-PIA, fairing-PIA, and isogeometric least-squares progressive-iterative approximation (IG-LSPIA), which is specialized for solving the isogeometric analysis problem.[12]
To facilitate the description of the PIA iteration format for different forms of curves and surfaces, we write B-spline curves and surfaces, NURBS curves and surfaces, B-spline solids, T-spline surfaces, and triangular Bernstein–Bézier (B–B) surfaces uniformly in the following form:
For example:
P(t)
t
Bi(t)
Pi
P(t)
nu x nv
t=(u,v)
Bi(t)=Ni(u)Ni(v)
Ni(u)
Ni(v)
P(t)
nu x nv x nw
t=(u,v,w)
Bi(t)=Ni(u)Ni(v)Ni(w)
Ni(u)
Ni(v)
Ni(w)
Given an ordered data set
{Qi,i=1,2, … ,n}
ti,i=1,2, … ,n
t1<t2< …
where the initial control points of the initial fitting curve (surface)
(0) | |
P | |
i |
k
k
P(k)(t)
To construct the
(k+1)
(k+1)
For the B-spline curve and surface fitting problem, Deng and Lin proposed a least-squares progressive–iterative approximation(LSPIA), which allows the number of control points to be less than that of the data points and is more suitable for large-scale data fitting problems.
Assume that the number of data points is
m
n(n\lem)
k
k
P(k)(t)
(k+1)
Difference vectors for data points: and,
Difference vectors for control pointswhere
Ij
j
j
Bj(ti)\ne0
ci,i\inIj
ci=1,i\inIj
Finally, the control points of the
(k+1)
(k+1) | |
P | |
j |
(k) | |
=P | |
j |
(k) | |
+\Delta | |
j |
,
(k+1)
P(k+1)(t)
In the local-PIA, the control points are divided into active and fixed control points, whose subscripts are denoted as and , respectively. Assume that, the th fitting curve (surface) is ,where the fixed control point satisfyThen,on the one hand, the iterative formula of the difference vector corresponding to the fixed control points isOn the other hand, the iterative formula of the difference vector corresponding to the active control points isArranging the above difference vectors into a one-dimensional sequence,the local iteration format in matrix form is,where, is the iteration matrix, and are the identity matrices andThe above local iteration format converges and can be extended to blending surfaces and subdivision surfaces.[17]
The progressive iterative approximation format for implicit curve and surface reconstruction is presented in the following. Given an ordered point cloud and a unit normal vector on the data points, we want to reconstruct an implicit curve (surface) from the given point cloud. To avoid trivial solution, some offset points are added to the point cloud. They are offset by a distance along the unit normal vector of each pointAssume that is the value of the implicit function at the offset point
Let the implicit curve after the th iteration bewhere is the control point.
Define the difference vector of data points asNext, calculate the difference vector of control coefficientswhere is the convergence coefficient. As a result, the new control coefficients areleading to the new algebraic B-spline curveThe above procedure is carried out iteratively to generate a sequence of algebraic B-spline functions . The sequence converges to a minimization problem with constraints when the initial control coefficients .
Assume that the implicit surface generated after the th iteration isthe iteration format is similar to that of the curve case.[18]
To develop fairing-PIA, we first define the functionals as follows:where represents the th derivative of the basis function , (e.g. B-spline basis function).
Let the curve after the th iteration beTo construct the new curve ,we first calculate the st difference vectors for data points,Then, the fitting difference vectors and the fairing vectors for control points are calculated by
Finally, the control points of the
(k+1)
\muj
\omegaj
j
In this way, we obtain a sequence of curves . The sequence converges to the solution of the conventional fairing method based on energy minimization when all smoothing weights are equal (). Similarly, the fairing-PIA can be extended to the surface case.
Given a boundary value problem