System, method and computer program product for modeling at least one section of a curve

Information

  • Patent Application
  • 20040109001
  • Publication Number
    20040109001
  • Date Filed
    December 04, 2002
    22 years ago
  • Date Published
    June 10, 2004
    20 years ago
Abstract
A system, method and computer program product are provided for modeling at least one section of a curve. Each section can be modeled by initially providing a pair of positions (fi, fi+1) of the section of the curve including associated directions (di,di+1) and curvatures (κi,κi+1). Then, points b0,b1,b2,b3 and b4 can be identified based upon the pair of positions (fi,fi+1) and associated directions (di,di+1) and curvatures (κi,κi+1). Thereafter, a quartic interpolant p(t) can be determined over an interval (i≦t≦i+1) based upon points b0,b1,b2,b3 and b4 to thereby model the section of the curve. The quartic interpolant can be determined such that the interpolant p(t) has a position, direction and curvature equal to fi, di and κi, respectively, at t=i, and the interpolant p(t) has a position, direction and curvature equal to fi+1, di+1, and κi+1, respectively, at t=i+1.
Description


FIELD OF THE INVENTION

[0001] The present invention relates generally to systems, methods and computer program products for modeling curves and, more particularly, relates to systems, methods and computer program products for modeling at least one section of a curve according to a quartic Hermite interpolation technique.



BACKGROUND OF THE INVENTION

[0002] In a number of different disciplines, such as computer-aided geometric design (CAGD), it is necessary to model, or approximate, parametric curves from sparse data. Typically, such modeling techniques attempt to model planar curves with high accuracy, while maintaining curvature continuity. In this regard, many conventional techniques model curves based upon interpolation algorithms that are based upon the notion of the curve being twice continuously differentiable with respect to arclength and capable of being constructed locally.


[0003] A planar curve f is said to be twice continuously differentiable if the unit tangent vector f*:=f′/|f′| and the signed curvature f**:=f′×f″/|f′|3 are continuous. Let fi, di and κi be prescribed positions, directions and curvature values, respectively. For example, these data might be thought to have come from a twice continuously differentiable planar curve as:




f


i


:=f
(ti), di:=f*(ti) and κi:=f**(t1)  (1)



[0004] From such data, then, one such interpolation technique, known as Hermite interpolation, can determine a geometric Hermite interpolant p that satisfies:




p
(i)=fi, p*(i)=di and p**(i)=κi  (2)



[0005] where the components of p are polynomials on each parameter interval [i, i+1]. Also, to preserve the convexity of the data, that is, to satisfy the following assumption:




sign
i)=sign(di×(fi+1−f1))=sign(fi−fi−1di), for all i  (3)



[0006] the curvature of the interpolant typically has the same sign throughout.


[0007] As will be appreciated by those skilled in the art, many modeling, or interpolation techniques, operate to model a curve by separately interpolating different sections of the curve, where each section is defined by a set of end points. In this regard, because p can be constructed interval-by-interval, any such piecewise constructed interpolant will necessarily be continuously differentiable. Therefore, the interpolant p can be described as being constructed over the interval [0,1] without any loss of generality. According to one Hermite interpolation technique, developed by de Boor, Hollig and Sabin (referred to herein as the BHS technique), a cubic polynomial is used on each interval. Turning attention to the interval [0,1], then, the interpolant p can be written as:
1p(t)=j=03bjBj(t),(0t1)withBj(t):=(3j)tj(1-t)(3-j).


[0008] Interpolation of position at the given knots implies that


[0009] b0=f0 and b3=f1.


[0010] The remaining interpolation conditions can be simplified by introducing
2b~:=(f1×d1)d0+(d0×f0)d1d0×d1


[0011] Geometrically, {tilde over (b)} is the intersection of the line through f0 parallel to d0, and the line through f1 parallel to d1, as shown in FIG. 1. The tangent interpolation condition is then defined as:




b


1
=(1−ρ0)b00{tilde over (b)} and b2=(1−ρ1)b31{tilde over (b)}



[0012] for some 0<ρ0, ρ1≦1, where ρ0 and ρ1 represent weights in writing b1 and b2 as convex combinations of b0, b3 and {tilde over (b)}. Moreover, the curvature interpolation condition is given by:
3κ0=2d0×(b2-b1)3&LeftBracketingBar;b1-b0&RightBracketingBar;2andκ1=2(b2-b1)×d13&LeftBracketingBar;b3-b2&RightBracketingBar;2.


[0013] Substituting b2−b1=b2−{tilde over (b)}+{tilde over (b)}−b1=(1−ρ1)(b3−{tilde over (b)})+(1−ρ0)({tilde over (b)}−b0) into the last equations for the curvature interpolation condition, κ0 and κ1 can be determined as follows:
4κ0=2(1-ρ1)d0×(b3-b~)3ρ02&LeftBracketingBar;b~-b0&RightBracketingBar;2andκ1=2(1-ρ0)(b~-b0)×d13ρ12&LeftBracketingBar;b3-b~&RightBracketingBar;2(4)


[0014] Defining an R0 and R1 as follows:
5R0:=3κ0&LeftBracketingBar;b~-b0&RightBracketingBar;22d0×(b3-b~)andR1:=3κ1&LeftBracketingBar;b3-b~&RightBracketingBar;22(b~-b0)×d1


[0015] and solving equation (4) for ρ0 and ρ1 gives:


ρ0=1−R1ρ12 and ρ1=1−R0ρ02.


[0016] As will be appreciated by those skilled in the art, the BHS technique may have 0, 1, 2 or 3 solutions with 0<ρ0, ρ1≦1 and a sufficient condition for solvability is that (1−R0)(1−R1)≧0. With respect to techniques such as the BHS technique, it has been suggested that fi and di be prescribed first, with appropriate values for κi selected to satisfy the foregoing condition. However, such a technique of determining fi, di and κi is not always feasible since, for example, there may be predetermined values that κi must have. Also, such a condition, which in terms of the data can be represented as:


[0017] (2(d0×(f1−f0))(d0×d1)2−3κ0((f1−f0)×d1)2).


(2((f1−f0)×d1)(d0×d1)2−3κ1(d0×(f1−f0))2)≧0,


[0018] puts an abstruse restriction on the data. Further, ρ0 and ρ1 cannot be chosen in any manner that will make them continuous functions of the data for all admissible data sets. For example, as shown in FIG. 2, when the data changes in such a way that R1 remains constant at 0.875 while R0 increases to 0.875 (say from 0), then ρ0 =0.1674 and ρ1=0.9755 when R0=R1=0.875. However, if the same data configuration is arrived at in such a way that R0 remains constant at 0.875 while R1 increases to 0.875 (say from 0), then ρ0=0.9755 and ρ1=0.1674 when R0=R1=0.875.



SUMMARY OF THE INVENTION

[0019] In light of the foregoing background, the present invention provides an improved system, method and computer program product for modeling at least one section of a curve. The system, method and computer program product of embodiments of the present invention are capable of modeling each section of a curve f based upon data including a pair of positions (fi, fi+1) of the section of the curve, wherein the pair of positions includes associated directions (di, di+1) and associated curvatures (κi, κi+1). Advantageously, embodiments of the present invention are capable of modeling each section to exactly match the positions, directions and curvatures of data provided for the respective section. The system, method and computer program product of embodiments of the present invention are also capable of modeling each section of the curve to thereby preserve the shape properties of the curve f, such as by maintaining the convexity in the modeled section.


[0020] As indicated above, the system, method and computer program product of embodiments of the present invention are capable of modeling each section of a curve. Advantageously, then, changes in the data only affect the curve locally. That is to say, altering one data position (e.g., f1) only alters the modeled curve up to adjacent data point(s) (e.g., fi+1). As such, a point in one section can be altered without affecting the modeled curve in subsequent sections. In addition, the system, method and computer program product of embodiments of the present invention are capable of modeling the curve such that a change in the model is directly proportional to a change in the data. In other terms, the model depends continuously on the data such that small changes in the data (position, direction and/or curvature) will produce only small changes in the resulting model.


[0021] The system, method and computer program product of embodiments of the present invention are further capable of modeling each section of the curve with sixth-order accuracy. As will be appreciated, due to the finite number of data points that may be provided, no modeled section of the curve can exactly reproduce the respective section of the curve f. In this regard, the accuracy of a model can be defined based upon how much closer the modeled section comes to the respective section of the curve as the number of provided positions from the curve f increase. As such, by modeling each section of the curve with sixth-order accuracy, as the number of provided positions from a section of the curve increase by a factor of g, the modeled section of the curve will move g6 closer to the section of the curve.


[0022] According to one aspect of the present invention, a method is provided for modeling at least one section of a curve. According to one embodiment, a section is modeled by initially providing a pair of positions (fi, fi+1) of the section of the curve, where the pair of positions includes associated directions (di, di+1) and associated curvatures (κi, κi+1). Then, points b0, b1, b2, b3 and b4 are identified based upon the pair of positions (fi, fi+1) and associated directions (di, di+1) and curvatures (κi, κi+1). More particularly, points b0, b1, b2, b3 and b4 can be identified by initially defining a control point {tilde over (b)} based upon the pair of positions (fi, fi+1) and the associated directions (di, di+1). The control point can be defined as a point at the intersection of a line through point f0 parallel to direction d0, and a line through point f1 and parallel to direction d1. In other terms, the control point can be defined according to the following:
6b~:=(f1×d1)d0+(d0×f0)d1d0×d1.


[0023] After defining the control point {tilde over (b)}, points b1 and b3, can be identified. In this regard, point b1 can be identified on a segment {overscore (b0{tilde over (b)})} and point b3 can be identified on a segment {overscore (b4{tilde over (b)})}, where b0 equals fi and b4 equals fi+1. For example, points b1 and b3 can be identified by defining weights (ρ0, ρ1) such that 0<ρ0, ρ1≦1. Thereafter, points b1 and b3 can be identified according to the following:




b


1
=(1−ρ0)b00{tilde over (b)} and b3=(1−ρ1)b41{tilde over (b)}.



[0024] Also after defining the control point {tilde over (b)}, point b2 can be identified such that b2 is disposed within a region bounded by a triangular shape defined by points {tilde over (b)}, b1 and b2, where point b2 is identified based upon the curvatures (κi, κi+1). Advantageously, by so identifying point b2, the convexity of the modeled section can be preserved. For example, point b2 can be identified by defining weights (α0, α1) based upon the curvatures (κi, κi+1), where the weights (α0, α1) are defined such that α0, α1≧0 and α01≦1. Thereafter, point b2 can be identified according to the following:




b


2
0b11b3+(1−α0−α1){tilde over (b)}.



[0025] In one embodiment, weights (α0, α1) can be defined by defining weights (ρ0, ρ1) and thereafter defining weights (α0, α1) according to the following:
7α0=R1ρ121-ρ0andα1=R0ρ021-ρ1,


[0026] where
8R0:=4κi&LeftBracketingBar;b~-b0&RightBracketingBar;23di×(b4-b~)andR1:=4κi+1&LeftBracketingBar;b4-b~&RightBracketingBar;23(b~-b0)×di+1.


[0027] After identifying points b0, b1, b2, b3 and b4, a quartic interpolant p(t) is determined over an interval (i≦t≦i+1) based upon points b0, b1, b2, b3 and b4 to thereby model the section of the curve. More particularly, the interpolant p(t) can be determined according to the following:
9p(t)=j=04bjBj(t),


[0028] where
10Bj(t):=(4j)tj(1-t)(4-j).


[0029] Advantageously, and illustrating that embodiments of the present invention are capable of modeling each section to exactly match the positions, directions and curvatures for the respective section, the interpolant p(t) has a position, direction and curvature equal to fi, di and κi, respectively, at t=i, and the interpolant p(t) has a position, direction and curvature equal to fi+1, di+1, and κi+1, respectively, at t=i+1.


[0030] According to other aspects of the present invention, a system and computer program product are provided for modeling at least one section of a curve f.







BRIEF DESCRIPTION OF THE DRAWINGS

[0031] Having thus described the invention in general terms, reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:


[0032]
FIG. 1 illustrates a Bezier polygon with a corresponding cubic curve segment;


[0033]
FIG. 2 illustrates a situation in which, ρ0 and ρ1 cannot be chosen to be continuous functions of data of planar curve f for all admissible data sets, according to one conventional interpolation technique;


[0034]
FIG. 3 is a flow chart illustrating various steps in a method of modeling each of at least one section of a curve according to one embodiment of the present invention;


[0035]
FIG. 4 illustrates a Bezier polygon with a corresponding quartic curve segment according to one embodiment of the present invention;


[0036]
FIG. 5 illustrates the geometry of data from a circular arc according to one embodiment of the present invention;


[0037]
FIG. 6 illustrates a plot of ρopt(θ)/ρcnt(θ) for −π<θ<π;


[0038]
FIG. 7A illustrates a set of positions including associated directions and curvatures according to one embodiment of the present invention in the context of designing a dimensionless airfoil;


[0039]
FIG. 7B illustrates a curve modeled based upon the set of positions from FIG. 7A according to one embodiment of the present invention; and


[0040]
FIG. 8 is a schematic block diagram of the system of one embodiment of the present invention embodied by a computer.







DETAILED DESCRIPTION OF THE INVENTION

[0041] The present invention now will be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like numbers refer to like elements throughout.


[0042] As indicated above in the background section, a planar curve f is said to be twice continuously differentiable if the unit tangent vector f*:=f′/|f′| and the signed curvature f**:=f′×f″/|f′|3 are continuous. Again, let fi, di and κi be prescribed positions, directions and curvature values, respectively. For example, these data might be thought to have come from a twice continuously differentiable planar curve as:




f


1


:=f
(ti), di:=f*(t1) and κi:=f**(t1)  (1)



[0043] According to one embodiment of the present invention, then, a system, method and computer program product are provided for modeling at least one section of a curve, where each section is modeled by determining a quartic Hermite interpolant p that satisfies:




p
(i)=fi, p*(i)=di and p**(i)=κi  (2)



[0044] where the components of p are polynomials on each parameter interval [i, i+1]. Also as above, the interpolant advantageously preserves the convexity of the data, that is, under the assumption:




sign
i)=sign(di×(fi+1−f1))=sign(fi−fi-1di), for all i  (3)



[0045] the curvature of the interpolant must have the same sign throughout.


[0046] According to one embodiment of the present invention, p is constructed on an interval-by-interval basis. Also, it should be noted that by constructing p on an interval-by-interval basis, the resulting interpolant p is necessarily twice continuously differentiable. The following will describe constructing the interpolant for the interval [0,1], but it should be understood that the interpolant can similarly be constructed for any of a number of other intervals without departing from the spirit and scope of the present invention. Turning attention to the interval [0,1], then, p can be written in its Bezier form as:
11p(t)=j=04bjBj(t),(0t1)


[0047] where Bj(t) is defined as
12Bj(t):=(4j)tj(1-t)(4-j).


[0048] As shown in FIG. 3, then, a method of modeling each of at least one section of a curve begins by providing positions (f0, f1) and associated directions (d0, d1) and curvatures (κ0, κ1), as shown in block 10. Then, points b0, b1, b2, b3 and b4 can be identified, as shown in block 12. In this regard, points b0, b1, b2, b3 and b4 can be identified based upon the provided positions (f0, f1) and associated directions (d0, d1) and curvatures (κ0, κ1). After points b0, b1, b2, b3 and b4 have been identified, then, the quartic interpolant p(t) can be determined over an interval (0≦t≦1) based upon points b0, b1, b2, b3 and b4 to thereby model the section of the curve, as illustrated in block 14. As will be appreciated, the interpolant p(t) has a direction and curvature equal to di and κi, respectively, at t=i. Similarly, the interpolant p(t) has a direction and curvature equal to di+1, and κi+1, respectively, at t=i+1.


[0049] More particularly as to identifying points b0, b1, b2, b3 and b4, the requirements of interpolation of position and tangent can result in relations among the coefficients bj, which can be written as follows:


b0=f0 and b4=f1




b


1
=(1−ρ0)b00{tilde over (b)} and b3=(1−ρ1)b41{tilde over (b)}  (5)



[0050] for some 0<ρ0, ρ1≦1, where ρ0 and ρ1 represent weights in writing b1 and b3 as convex combinations of b0, b4 and {tilde over (b)}. Further, as shown in equation (5), a control point {tilde over (b)} can be defined as a point at the intersection of a line through point f0 parallel to direction d0, and a line through point f1 and parallel to direction d1. More particularly, control point {tilde over (b)} can be defined as follows:
13b~:=(f1×d1)d0+(d0×f0)d1d0×d1


[0051] According to embodiments of the present invention, b2 is identified to preserve convexity in the interpolant. In this regard, b2 is typically identified as a point within a region bounded by a triangular shape defined by points {tilde over (b)}, b1 and b3. As used herein, within a region bounded by a triangular shape, b2 shall lie either within the interior or on the boundary of the triangular shape defined by points {tilde over (b)}, b1 and b3. More particularly, b2 is typically identified such that the following condition is met to preserve convexity:




b


2
0b11b3+(1−α01){tilde over (b)}  (6)



[0052] for some α0, α1≧0 satisfying α01≦1, as shown in FIG. 4. In this regard, α0 and α1 represent weights in writing b2 as a convex combination of b1, b3 and {tilde over (b)}. Now, in order to meet the curvature requirements at the endpoints, κi may be determined as follows:
14κ0=3d0×(b2-b1)4&LeftBracketingBar;b1-b0&RightBracketingBar;2andκ1=3(b3-b2)×d14&LeftBracketingBar;b4-b3&RightBracketingBar;2


[0053] Substituting
15b2-b1=(1-α0)(b~-b1)+α1(b3-b~)=(1-α0)(1-ρ0)(b~-b0)+α1(1-ρ1)(b4-b~)b3-b2=α0(b~-b1)+(1-α1)(b3-b~)=α0(1-ρ0)(b~-b0)+(1-α1)(1-ρ1)(b4-b~)


[0054] into the equations for κ0 and κ1 above, κ0 and κ1 can now be determined according to the following:
16κ0=3α1(1-ρ1)d0×(b4-b~)4ρ02&LeftBracketingBar;b~-b0&RightBracketingBar;2andκ1=3α0(1-ρ0)(b~-b0)×d14ρ12&LeftBracketingBar;b4-b~&RightBracketingBar;2(7)


[0055] Then, R0 and R1 can be defined as follows:
17R0:=4κ0&LeftBracketingBar;b~-b0&RightBracketingBar;23d0×(b4-b~)andR1:=4κ1&LeftBracketingBar;b4-b~&RightBracketingBar;23(b~-b0)×d1(8)


[0056] With R0 and R1 defined according to equation (8), equation (7) can be solved for α0 and α1 such that α0 and α1 can be determined according to the following equation (9):
18α0=R1ρ121-ρ0andα1=R0ρ021-ρ1(9)


[0057] Therefore, on each segment, fi to fi+1, any value of ρ0 and ρ1 may be used, subject to the following conditions:
190<ρ0,ρ1<1andR1ρ121-ρ0+R0ρ021-ρ11(10)


[0058] Then, if the Bezier coefficients are prescribed as above, the resultant spline p will be C2-continuous (with respect to arclength) and will interpolate p(t) over the interval [0, 1], as in equation (2).


[0059] It should be noted that the conditions of (10) always have infinitely many solutions. For example, the sum in the second condition is equal to one when the following is true:
20ρ0=ρ1=ρcnt=1+4(R0+R1)-12(R0+R1)(11)


[0060] And since 0<ρcnt<1, and the sum in the second condition of (10) is increasing in ρ0 and ρ1, any choice satisfying 0<ρ0, ρ1≦ρcnt can result in a valid interpolant p. It should be noted that these are not the only possible solutions and, as such, should not be taken to limit the scope of the present invention.


[0061] As described above, one aspect of the present invention provides a method of interpolating a position, tangent and curvature by a twice continuously differentiable quartic spline. In one advantageous embodiment, the values of ρ0 and ρ1 are defined such that the interpolant p is sixth-order accurate. According to this embodiment, suppose f comprises a smooth parametric curve with non-vanishing curvature, and t, is an increasing sequence of parameter values. Let fi, di and κi be given as in equation (1) above, and define the following:
21hi:=&LeftBracketingBar;fi+1-fi&RightBracketingBar;andh:=maxihi


[0062] where hi represents local step sizes or the distances between adjacent points, and h represents the maximum distance between any two adjacent points over all of i. For each segment, fi to fi+1, then, ρ0 and ρ1 can be defined to achieve sixth-order accuracy of interpolant p(t) if the conditions in (10) are met, and the following equation (12) is satisfied:
22ρ0=ρ1=12+Aihi2+O(hi3)(12)


[0063] where Ai is bounded uniformly in h. Also in equation (12), the term O, often referred to as “big-O,” represents a measure of the difference between ρ0 or ρ1 and the quantity ½+Aihi2, as such is defined by how much closer ρ0 or ρ1 gets to ½+Aihi2 as the number of known data points on f (i.e., fi, fi+1, etc.) increase. As such, the term O(hi3) in equation (12) indicates that ρ0 and ρ1 get g3 times closer to ½+Aihi2 if the number of known data points on f increases by a factor of g. By so defining ρ0 and ρ1, the following conclusion holds:




dist
(f,p)=O(h6).



[0064] In other terms, by defining p0 and p1 to satisfy (10) and (12), the distance between f and the interpolant p(t) is sixth order accurate such that if the number of known data points of f increase by a factor of g, the interpolant will get g6 times closer to f. The distance between f and the interpolant p(t) can be defined in any of a number of different known manners, including according to the Hausdorff technique.


[0065] To illustrate that defining ρ0 and ρ1 as in (12) results in sixth order accuracy of the interpolant p, assume that the curve f is smooth with |κ|≧c>0, where c represents a measure of curvature bounded away from zero. Parameterizing f by arclength s, then, results in the following:
23f(s):=[cosθ(s)sinθ(s)]


[0066] with θ defined as the indefinite integral of the curvature,


θ′(s)=κ(s).


[0067] Again considering only one interval, designated f0 to f1, it can be assumed without loss of generality that f(0) is halfway along the arc from f0 to f 1 so that f0=f(−ε) and f1=f(ε) for some ε>0. Then, If |f1−f0|=2ε+I(ε3) that defining ρ0 and ρ1 to satisfy (10) and (12) results indist(f,pf)=O(ε6). It can also be assumed without loss of generality that θ(0)=0, i.e., that
24f(0)=[10].


[0068] Under such assumptions, the second coordinates of the curve f and the interpolant p can be considered as functions of their first coordinates by the implicit function theorem (for sufficiently small ε). That is, each curve can be parameterized by its first coordinate:
25p:ξ[ξyp(ξ)]andf:ξ[ξyf(ξ)].


[0069] From this point of view, the function yp matches yf to third order at two values of ξ that are O(ε) apart. As such, by the standard error estimate for two-point Hermite interpolation, the error is of order O(ε6) provided that d6yp/dξ6 is bounded uniformly in ε.


[0070] Considering the Bezier form of the quartic polynomial p,
26p(t)=[x(t)y(t)]=j=04bjBj(t),


[0071] dnyp/dξn is a linear combination of the functions:
27{y(i)υ=1n-1x(jυ)(x)2n-1:1i,jυ4;i+υ=1n-1jυ=2n-1}


[0072] for any n≧1, as can be verified by inductively applying the chain rule, as such is known to those skilled in the art. In particular, the terms in d6yp/dξ6 are of the form:
28y(i)υ=15x(jυ)(x)11


[0073] where i+Συjυ=11 and 1≦i, jυ≦4. The boundedness of these expressions can then be determined from the following assertions:
29p(t)=[12ε0]+O(ε2)and&LeftBracketingBar;p(i)(t)&RightBracketingBar;=O(εi)fori=2,3,4(13)


[0074] To illustrate how the assertions hold true, consider that the Bezier coefficients of the derivatives of p are as follows:


[0075] p′: 4(b1−b0) 4(b2−b1) 4(b3−b2) 4(b4−b3)


[0076] p″: 12(b2−2b1+b0) 12(b3−2b2+b3) 12(b4−2b3+b2)


[0077] p′″: 24(b3−3b2+3b1−b0) 24(b3−3b2+3b1−b0)


[0078] p″: 24(b4−4b3+6b2−4b1+b0)


[0079] Each of the Bezier coefficients can be expressed in terms of:


υ0{tilde over (b)}−b0 and υ1=b4−{tilde over (b)}


[0080] by noting that:




b


1


−b


0
=ρυ0,





b


2


−b


1
=(1−ρp)[(1−α001],





b


3


−b


2
=(1−ρ)[α0υ0+(1−α11] and





b


4


−b


3


=ρυ


1
.



[0081] Also, from the definition of {tilde over (b)}, it can be shown that:
30υ0=a×d1d0×d1d0andυ1=d0×ad0×d1d1,


[0082] where α:=f1−f0.


[0083] To expand the coefficients of p(i) in terms of ε, θ is initially expanded to the third order at s=0,


θ(s)=θ1s+θ2s23s3+O(s4),


[0084] where θk:=θ(k)(0)/k! is independent of s. Then, from the definitions, it can be shown that:
31d0=[cosθ(-ε)sinθ(-ε)]=[1-θ122ε2+θ1θ2ε3-θ1ε+θ2ε2-(θ3-θ13/6)ε3]+O(ε4),d1=[cosθ(ε)sinθ(ε)]=[1-θ122ε2-θ1θ2ε3θ1ε+θ2ε2+(θ3-θ13/6)ε3]+O(ε4),a=-εε[cosθ(σ)sinθ(σ)]σ=[2ε-θ123ε32θ23ε3]+O(ε5).


[0085] Thereafter, the following expansions can be determined:
32d0×d1=2θ1ε+(2θ3-4θ133)ε3+O(ε5),d0×a=2θ1ε2-43θ2ε3+(2θ3-23θ13)ε4+O(ε5)anda×d1=2θ1ε2+43θ2ε3+(2θ3-23θ13)ε4+O(ε5).


[0086] Next, the vectors υ0 and υ1 can be determined as follows:
33υ0=a×d1d0×d1d0=[ε+2θ23θ1ε2-θ126ε3-θ1ε2+θ23ε3]+O(ε4),υ1=d0×ad0×d1d1=[ε-2θ23θ1ε2-θ126ε3θ1ε2+θ23ε3]+O(ε4).


[0087] It will be noted that in the above equations for υ0 and υ1, it is presumed that κ≠0, as otherwise the numerator vanishes for some value of s ∈[−ε,ε].


[0088] Now, since κ(S)=θ′(S), κ0 and κ1 can be determined as follows:


κ0=κ(−ε)=θ1−2θ2ε+3θ3ε3+O3), and


κ1=κ(ε)=θ1+2θ2ε+3θ3ε3+O3).


[0089] Based upon the definitions of R0 and R1 in equation (8) and the foregoing expressions for κ0 and κ1, R0 and R1 can be rewritten as follows:
34R0=43κ0(a×d1)2(d0×a)(d0×d1)2=23+2(9θ14-20θ22+18θ1θ3)27θ12+O(ε3),R1=43κ1(d0×a)2(a×d1)(d0×d1)2=23+2(9θ14-20θ22+18θ1θ3)27θ12+O(ε3).


[0090] Combining the foregoing equations for R0 and R1 with the definition of ρ0 and ρ1 from equation (12) gives:
35αi=Riρ1-ρ=13+(2A0+θ123-20θ2227+θ33θ1)ε2+O(ε3)


[0091] In turn, the difference between consecutive points bi can be determined as follows:
36b1-b0=ρυ0=[12ε+θ23θ1ε2+(A0-θ1212)ε3-θ12ε2+θ26ε3]+O(ε4),b2-b1=(1-ρ)[(1-α0)υ0+α1υ1]=[12ε+θ29θ1ε2-(A0+θ1212)ε3-θ16ε2+θ26ε3]+O(ε4),b3-b2=(1-ρ)[α0υ0+(1-α0)υ1]=[12ε-θ29θ1ε2-(A0+θ1212)ε3θ16ε2+θ26ε3]+O(ε4)andb4-b3=ρυ1=[12ε-θ23θ1ε2+(A0-θ1212)ε3θ12ε2+θ26ε3]+O(ε4).


[0092] From the foregoing equations, it follows that
37bj+1-bj=[12ε0]+O(ε2),


[0093] |bj+2−2bj+1+bj|=I(ε2),


|bj+1−3bj+2+3bj+1−bj|=O3) and |bj+4−4bj+3+6bj+2−4bj+1+bj|=O4).


[0094] As shown from the foregoing, then, the foregoing equations satisfy the assertions in (13) above.


[0095] Now suppose that the data came from endpoints of an arc of angle θ<π of some circle of curvature κ. According to another embodiment of the present invention, to preserve the symmetry of such a situation, ρ0 and ρ1 can be defined such that ρ01=:ρ. The heuristic choice of a favorable ρ can force the curvature of the interpolant to be κ at the midpoint, that is, p**(½)=κi. In terms of the spline coefficients, one can verify that
38p(1/2)=b4+2b3-2b1-b02andp(1/2)=3(b4-2b2+b0).


[0096] For any fixed choice of ρ0 and ρ1, the construction devised above is scale-invariant (provided the curvature is scaled by 1/s to correspond to a scaling by s in the relative positions). So without loss of generality, it can be assumed that κ=1. The construction is also invariant under translation and rotation, so it can be assumed that


[0097] f0=(0,0), d0=(1,0), f1=(sinθ,1−cosθ), d1=(cosθ,sinθ) and κ01=1.


[0098] In such a case, as shown in FIG. 5, b0=(0,0), b4=(sinθ,1−cosθ) and {tilde over (b)}=(sinθ/(1+cosθ),0).


[0099] From equations (8) and (9) above, R0=R, =4/3(1+cosθ) and
39α0=α1=α:=4ρ23(1-ρ)(1+cosϑ).


[0100] Defining υ0:={tilde over (b)}−b0 and υ1:={tilde over (b)}−b4, b1 and b3 can be determined as follows: b1=b0+ρυ0, and b3=b4+ρυ1. And since υ0−υ1=b4−b0, b4+2b3−2b1−b0=(3−2ρ)(υ0−υ1).


[0101] From equation (6), then, b2=b−α(1−ρ)(υ01). Therefore, it can be shown that:
40b4-2b2+b0=-(1-2α(1-ρ))(υ0+υ1)=-(1-8ρ23(1+cosϑ))(υ0+υ1).


[0102] Consequently, the first and second derivatives for the interpolant p at t=½ can be determined as follows:
41p(1/2)=(3-2ρ)(υ0-υ1)2andp(1/2)=-(3-8ρ21+cosϑ)(υ0+υ1).


[0103] Since |υ0|=|υ1|, it can also be shown that υ0−υ1 and υ01 are orthogonal, Therefore, (υ0−υ1)×(υ01)=−|υ0−υ1|·|υ01|. It can further be shown that
42p**(1/2)=p(1/2)×p(1/2)&LeftBracketingBar;p(1/2)&RightBracketingBar;3=(3-2ρ2)(3-8ρ21+cosϑ)&LeftBracketingBar;υ0-υ1&RightBracketingBar;&LeftBracketingBar;υ0+υ1&RightBracketingBar;18(3-2ρ)3&LeftBracketingBar;υ0-υ1&RightBracketingBar;3=4(3-8ρ21+cosϑ)&LeftBracketingBar;υ0+υ1&RightBracketingBar;(3-2ρ)2&LeftBracketingBar;υ0-υ1&RightBracketingBar;2.


[0104] By noting that
43ρ32


[0105] and substituting in
44&LeftBracketingBar;υ0-υ1&RightBracketingBar;=2(1-cosϑ)and&LeftBracketingBar;υ0+υ1&RightBracketingBar;=2(1-cosϑ)2(1+cosϑ),


[0106] the above equation for p**(½) can be simplified to the following quadratic equation when p**(½) is set equal to 1:
45(2(1-cosϑ)+81+cosϑ)ρ2-32(1+cosϑ)ρ+(942(1+cosϑ)-3)=0.


[0107] The larger solution of the foregoing quadratic equation can then be denoted by ρopt (θ), where
460<ρopt(ϑ)12


[0108] for all −π<θ<π.


[0109] It is advantageous that ρ0 ρ1opt (θ) for circular data as above, and that the resulting interpolant provides sixth order accuracy in general. Therefore, ρ0 and ρ1 can be defined to continuously depend on the data and meet the circular data requirement (as defined in equation 12). Therefore, for general data, it can be shown that
47ρ0=ρ1=ρ:=ρcrit·(ρopt(ϑ)ρcrit(ϑ))(14)


[0110] where θ is the angle between d0 and d1, and ρcnt (θ) is defined as ρcnt for a circular arc of angle θ. More particularly,
48ρcrit(ϑ)=3(1+323(1+cosϑ)-1)(1+cosϑ)16


[0111] (see equation (11)). The preceding equation results in a favorable choice of ρ for circular data and necessarily satisfies 0<ρ0, ρ1cnt (see FIG. 6 for a plot of ρopt (θ)/ρcnt (θ) for −π<θ<π).


[0112] As indicated above, embodiments of the present invention provide an interpolant with sixth order accuracy. As will be appreciated, many different techniques for choosing ρ can provide the same accuracy, including the particularly simple choice ρ01=min{{fraction (1/2)}, ρcnt}. Empirically, such a choice tends to produce overly flat curves for sparse data sets. The fact that the interpolant is sixth-order accurate follows from the above, and the claim that, supposing f is a smooth parameteric curve with non-vanishing curvature, then ρ as defined in equation (14) satisfies the following equation (15):
49ρ=12+Ah2+O(h3)(15)


[0113] for some A ∈1R independent of h.


[0114] To illustrate how the interpolant is sixth-order accurate by demonstrating that ρ satisfies equation (15), consider that cos θ=<d0,d1>, the inner product of the vectors d0 and d1. As such, from the expansions d0×d1, d0×α and α×d1 described above,


cosθ=1−2θ12h2+O(h4).


[0115] Now, letting a, b and c denote the coefficients in the quadratic equation that defines ρopt (θ), it can be shown that:


[0116] a=6+3θ12h2+O(h4), b=−6+3012h2+O(h4), and
50c=32-94θ12h2+O(h4).


[0117] Therefore,
51ρopt(ϑ)=b2-4ac-b2a=12-12θ12h2+O(h4).


[0118] As above,
52Ri=23+2(9θ14-20θ22+18θ1θ3)27θ12h2+O(h4)


[0119] for any curve, so ρcnt can be defined as:
53ρcrit=57-38+O(h2).


[0120] Since θ=O(h) for any fixed sufficiently smooth curve,


ρcntcnt(θ)=1+O(h2).


[0121] Therefore, continuing with a more rigorous examination, it can be shown that
54ρi=12+O(h2).


[0122] As described above, points b0, b1, b2, b3 and b4 are based upon the pair of positions (f0, f1) and associated directions (d0, d1) and curvatures (κ0, κ1). In turn, the interpolant p(t) is determined over the interval (0≦t≦1) based upon points b0, b1, b2, b3 and b4 to thereby model a respective section of the curve. As such, it will be appreciated that the interpolant depends indirectly on the positions (f0, f1) and associated directions (d0, d1) and curvatures (κ0, κ1). Advantageously, then, a change in the interpolant p(t) is directly proportional to a change in the positions (fi, fi+1), directions (di, di+1) and curvatures (κi, κi+1). In other terms, the interpolant depends continuously on the data (i.e., the positions, directions and curvatures). As such, small changes in any of the data (positions, directions and/or curvatures) will not produce large changes to the interpolant.


[0123] As will also be appreciated, the system, method and computer program product of embodiments of the present invention can have any of a number of different applications. For example, embodiments of the present invention can be utilized to provide a parametric family of curves for use in the design of aircraft, rotorcraft, spacecraft, automobiles, maritime vehicles, or the like. Thus, according to one typical scenario, the system, method and computer program product of embodiments of the pesent invention can be utilized to design an airfoil along a wing of a prospective aircraft. Initially, then, the airfoil can be specified by a plurality of data points, includeing a position, direction and curvature for each point. Thus, presuming the airfoil is specified by ten points, the points according to one exemplar embodiment may appear as in FIG. 7A and Table 1, below, with the curve fit according to embodiments of the present invention shown in FIG. 7B.
1TABLE 1ifid1k10(1.00, 0.00322)(−0.756, 0.655)0.06771(0.552, 0.337)(−0.8577, 0.5141)0.3112(0.220, 0.468)(−1.00, 0.00)4.323(0.0617, 0.350)(−0.433, −0.901)3.164(0.00, 0.00)(0.00, −1.00)0.3915(0.0676, −0.403)(0.537, −0.844)4.736(0.316, −0.539)(1.00, 0.00)5.437(0.514, −0.451)(0.796, 0.605)1.198(0.728, −0.243)(0.676, 0.737)0.009(1.00, 0.00)(0.942, 0.336)−5.23


[0124] Each data point can be represented by a circular arc of the appropriate curvature centered at the appropriate position and tangent to the appropriate direction vector at the respective point. The curve defined by the data points and the interpolation technique of embodiments of the present invention can be considered to be a member of a 40-parameter family of curves. In this regard, the parameters consist of the position (x and y coordinates), direction (a single parameter since |di|=1), and curvature at each point. In fact, not all parameters are active in such a case. Namely, the following parameters can be held in position: x0=x9=1, x4=y0=y4=y9=0, d2=(−1,0), d4=(0, −1), d6=(1, 0) and κ8=0. As such, the number of parameters can be reduced from 40 to 30. It will be noted that it has been found that such a 30-parameter family of curves is sufficiently robust to model airfoils for a wide variety of aircraft. While advantageous to accurately model airfoils, the system, method and computer program product can be utilized to model a wide variety of other surfaces for other applications, including automotive applications and the like.


[0125] In another typical scenario, the curve
55f(t)=[tet](0t1)


[0126] is interpolated to empirically demonstrate the sixth order accuracy of the interpolation technique. The results of such interpolation are shown in Table 2, below.
2TABLE 2PointsρminρmaxError ei56ei-1ei57log2ei-1ei2.508499.5084999.5738 × 10−63.502127.5021501.6097 × 10−759.4765.89425.500531.5005392.5669 × 10−962.7105.97069.500133.5001354.0367 × 10−1163.5895.9907


[0127] As shown in Table 2, the first column specifies the number of knots interpolated at, where the knots were distributed uniformly in t. The next two columns specify the minimum and maximum ρ used on any of the intervals. The fourth column is the maximum error over the interval. Finally, the fifth and sixth columns display (or at least suggest) the sixth-order rate of convergence. Note that
58ρ=12+O(h2)


[0128] was shown above.


[0129] Therefore, embodiments of the present invention are capable of modeling each section of a curve f to exactly match the positions, directions and curvatures for data provided for the respective section. Embodiments of the present invention are also capable of modeling each section of the curve to thereby preserve the shape properties of the curve f, such as by maintaining the convexity in the modeled section. In addition, by modeling sections of a curve, embodiments of the present invention can advantageously model the curve such that changes in the provided data only affect the curve locally. Embodiments of the present invention are further capable of modeling each section such that the model depends continuously on the data, and such that the model has sixth-order accuracy.


[0130] As shown in FIG. 8, the system of the present invention is typically embodied by a processing element and an associated memory device, both of which are commonly comprised by a computer 20 or the like. In this regard, as indicated above, the method of embodiments of the present invention can be performed by the processing element manipulating data stored by the memory device with any one of a number of commercially available computer software programs. The computer can include a display 22 for presenting information relative to performing embodiments of the method of the present invention, including the various distributions, models and/or conclusions as determined according to embodiments of the present invention. To plot information relative to performing embodiments of the method of the present invention, the computer can further include a printer 24.


[0131] Also, the computer 20 can include a means for locally or remotely transferring the information relative to performing embodiments of the method of the present invention. For example, the computer can include a facsimile machine 26 for transmitting information to other facsimile machines, computers or the like. Additionally, or alternatively, the computer can include a modem 28 to transfer information to other computers or the like. Further, the computer can include an interface (not shown) to a network, such as a local area network (LAN), and/or a wide area network (WAN). For example, the computer can include an Ethernet Personal Computer Memory Card International Association (PCMCIA) card configured to transmit and receive information to and from a LAN, WAN or the like.


[0132] According to one aspect of the present invention and as mentioned above, the system of the present invention, such as a processing element typically embodied by a computer, generally operates under control of a computer program product. The computer program product for performing the methods of embodiments of the present invention includes a computer-readable storage medium, such as the non-volatile storage medium, and computer-readable program code portions, such as a series of computer instructions, embodied in the computer-readable storage medium.


[0133] In this regard, FIG. 1 is a flowchart of methods, systems and program products according to the invention. It will be understood that each block or step of the flowchart, and combinations of blocks in the flowchart, can be implemented by computer program instructions. These computer program instructions may be loaded onto a computer or other programmable apparatus to produce a machine, such that the instructions which execute on the computer or other programmable apparatus create means for implementing the functions specified in the flowchart block(s) or step(s). These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the flowchart block(s) or step(s). The computer program instructions may also be loaded onto a computer or other programmable apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the flowchart block(s) or step(s).


[0134] Accordingly, blocks or steps of the flowchart support combinations of means for performing the specified functions, combinations of steps for performing the specified functions and program instruction means for performing the specified functions. It will also be understood that each block or step of the flowchart, and combinations of blocks or steps in the flowchart, can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or combinations of special purpose hardware and computer instructions.


[0135] Many modifications and other embodiments of the invention will come to mind to one skilled in the art to which this invention pertains having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the invention is not to be limited to the specific embodiments disclosed and that modifications and other embodiments are intended to be included within the scope of the appended claims. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.


Claims
  • 1. A method of modeling at least one section of a curve f, wherein modeling a section comprises: providing a pair of positions (fi, fi+1) of the section of the curve, wherein the pair of positions includes associated directions (di, di+1) and associated curvatures (κi, κi+1); identifying points b0, b1, b2, b3 and b4 based upon the pair of positions (fi, fi+1) and associated directions (di, di+1) and curvatures (κi, κi+1); and determining a quartic interpolant p(t) over an interval (i≦t≦i+1) based upon points b0, b1, b2, b3 and b4 to thereby model the section of the curve, wherein the interpolant p(t) has a position, direction and curvature equal to fi, di and κi, respectively, at t=i, and wherein the interpolant p(t) has a position, direction and curvature equal to fi+1, di+1, and κi+1, respectively, at t=i+1.
  • 2. A method according to claim 1, wherein identifying points b0, b1, b2, b3 and b4 comprises: defining a control point {tilde over (b)} based upon the pair of positions (fi, fi+1) and the associated directions (di, di+1); identifying a point b1 and a point b3, wherein point b1 is identified on a segment {overscore (b0{tilde over (b)})} and point b3 is identified on a segment {overscore (b4{tilde over (b)})}, and wherein b0 equals fi and b4 equals fi+1; and identifying a point b2 disposed within a region bounded by a triangular shape defined by points {tilde over (b)}, b1 and b2, wherein point b2 is identified based upon the curvatures (κi, κi+1).
  • 3. A method according to claim 1, wherein defining a control point {tilde over (b)} comprises defining a control point {tilde over (b)} as a point at the intersection of a line through point f0 parallel to direction d0, and a line through point f, and parallel to direction d1.
  • 4. A method according to claim 3, wherein defining a control point comprises determining a control point according to the following:
  • 5. A method according to claim 2, wherein identifying a point b1 and a point b3 comprises: defining weights (ρ0, ρ1), wherein the weights are identified such that 0<ρ0, ρ1≦1; and identifying a point b1 and a point b3 according to the following: b1=(1−ρ0)b0+ρ0{tilde over (b)} and b3=(1−ρ1)b4+ρ1{tilde over (b)}.
  • 6. A method according to claim 2, wherein identifying a point b2 comprises: defining weights (α0, α1) based upon the curvatures (κi; κi+1), wherein the weights (α0, α1) are defined such that α0, α1≧0 and α0+α1≦1; and identifying point b2 according to the following: b2=α0b1+α1b3+(1−α0−α1){tilde over (b)}.
  • 7. A method according to claim 6, wherein defining weights (α0, α1) comprises: defining weights (ρ0, ρ1) such that 0<ρ0, ρ1≦1; and defining weights (α0, α1) according to the following: 60α0=R1⁢ρ121-ρ0andα1=R0⁢ρ021-ρ1,wherein 61R0:=4⁢ ⁢κi⁢&LeftBracketingBar;b~-b0&RightBracketingBar;23⁢di×(b4-b~)andR1:=4⁢ ⁢κi+1⁢&LeftBracketingBar;b4-b~&RightBracketingBar;23⁢(b~-b0)×di+1.
  • 8. A method according to claim 1, wherein determining an interpolant p(t) comprises determining an interpolant p(t) according to the following:
  • 9. A method according to claim 1, wherein identifying points b0, b1, b2, b3 and b4 comprises identifying points b0, b1, b2, b3 and b4 such that the quartic interpolant p(t) is sixth-order accurate over the interval (i≦t≦i+1).
  • 10. A method according to claim 1, wherein determining the quartic interpolant p(t) comprises determining the quartic interpolant p(t) such that a change in the interpolant p(t) is directly proportional to a change in at least one of the provided positions (fi, fi+1), directions (di, di+1) and curvatures (κi, κi+1).
  • 11. A system for modeling at least one section of a curve f comprising: a processing element capable of receiving a pair of positions (fi, fi+1) of a section of the curve to be modeled, wherein the pair of positions includes associated directions (di, di+1) and associated curvatures (κi, κi+1), wherein for each section the processing element is capable of identifying points b0, b1, b2, b3 and b4 based upon the pair of positions (fi, fi+1) and associated directions (di, di+1) and curvatures (κi, κi+1), wherein the processing element is also capable of determining a quartic interpolant p(t) over an interval (i≦t≦i+1) based upon points b0, b1, b2, b3 and b4 to thereby model the respective section of the curve, wherein the interpolant p(t) has a position, direction and curvature equal to fi, di and κi, respectively, at t=i, and wherein the interpolant p(t) has a position, direction and curvature equal to fi+1, di+1, and κi+1, respectively, at t=i+1.
  • 12. A system according to claim 11, wherein the processing element is capable of identifying points b0, b1, b2, b3 and b4 by: defining a control point b based upon the pair of positions (fi, fi+1) and the associated directions (di, di+1); identifying a point b1 and a point b3, wherein point b1 is identified on a segment {overscore (b0{tilde over (b)})} and point b3 is identified on a segment {overscore (b4{tilde over (b)})}, and wherein b0 equals fi and b4 equals fi+1; and identifying a point b2 disposed within a region bounded by a triangular shape defined by points {tilde over (b)}, b1 and b2, wherein point b2 is identified based upon the curvatures (κi, κi+1).
  • 13. A system according to claim 12, wherein the processing element is capable of defining the control point {tilde over (b)} as a point at the intersection of a line through point f0 parallel to direction d0, and a line through point f1 and parallel to direction d1.
  • 14. A system according to claim 13, wherein the processing element is capable of defining the control point according to the following:
  • 15. A system according to claim 12, wherein the processing element is capable of identifying points b1 and b3 by: defining weights (ρ0, ρ1), wherein the weights are identified such that 0<ρ0, ρ1≦1; and identifying a point b1 and a point b3 according to the following: b1=(1−ρ0)b0+ρ0{tilde over (b)} and b3=(1−ρ1)b4+ρ1{tilde over (b)}.
  • 16. A system according to claim 12, wherein the processing element is capable of identifying point b2 by: defining weights (α0, α1) based upon the curvatures (κi, κi+1), wherein the weights (α0, α1) are defined such that α0, α1≧0 and α0+α1≦1; and identifying point b2 according to the following: b2=α0b1+α1b3+(1−α0−α1){tilde over (b)}.
  • 17. A system according to claim 16, wherein the processing element is capable of defining weights (α0, α1) by: defining weights (ρ0, ρ1) such that 0<ρ0, ρ1≦1; and defining weights (α0, α1) according to the following: 65α0=R1⁢ρ121-ρ0andα1=R0⁢ρ021-ρ1,wherein 66R0:=4⁢κi⁢&LeftBracketingBar;b~-b0&RightBracketingBar;23⁢di×(b4-b~)andR1:=4⁢κi+1⁢&LeftBracketingBar;b4-b~&RightBracketingBar;23⁢(b~-b0)×di+1.
  • 18. A system according to claim 11, wherein the processing element is capable of determining the interpolant p(t) according to the following:
  • 19. A system according to claim 11, wherein the processing element is capable of identifying points b0, b1, b2, b3 and b4 such that the quartic interpolant p(t) is sixth-order accurate over the interval (i≦t≦i+1).
  • 20. A system according to claim 11, wherein the processing element is capable of determining the quartic interpolant p(t) such that a change in the interpolant p(t) is directly proportional to a change in at least one of the provided positions (fi, fi+1), directions (di, di+1) and curvatures (κi, κi+1).
  • 21. A computer program product for modeling at least one section of a curve f said computer program product comprising a computer-readable storage medium having computer-readable program code portions stored therein, the computer-readable program portions comprising: a first executable portion for receiving a pair of positions (fi, fi+1) of a section of the curve to be modeled, wherein the pair of positions includes associated directions (di, di+1) and associated curvatures (κi, κi+1); a second executable portion for identifying points b0, b1, b2, b3 and b4 based upon the pair of positions (fi, fi+1) and associated directions (di, di+1) and curvatures (κi, κi+1); and a third executable portion for determining a quartic interpolant p(t) over an interval (i≦t≦i+1) based upon points b0, b1, b2, b3 and b4 to thereby model the section of the curve, wherein the interpolant p(t) has a position, direction and curvature equal to fi, di and κi, respectively, at t=i, and wherein the interpolant p(t) has a position, direction and curvature equal to fi+1, di+1, and κi+1, respectively, at t=i+1.
  • 22. A computer program product according to claim 21, wherein the second executable portion identifies points b0, b1, b2, b3 and b4 by: defining a control point b based upon the pair of positions (fi, fi+1) and the associated directions (di, di+1); identifying a point b1 and a point b3, wherein point b1 is identified on a segment {overscore (b0{tilde over (b)})} and point b3 is identified on a segment {overscore (b4{tilde over (b)})}, and wherein b0 equals fi and b4 equals fi+1; and identifying a point b2 disposed within a region bounded by a triangular shape defined by points {tilde over (b)}, b1 and b2, wherein point b2 is identified based upon the curvatures (κi, κi+1).
  • 23. A computer program product according to claim 21, wherein the second executable portion defines the control point {tilde over (b)} as a point at the intersection of a line through point f0 parallel to direction d0, and a line through point f1 and parallel to direction d1.
  • 24. A computer program product according to claim 23, wherein the second executable portion defines the control point according to the following:
  • 25. A computer program product according to claim 22, wherein the second executable portion identifies points b1 and b3 by: defining weights (ρ0, ρ1) such that 0<ρ0, ρ1≦1; and identifying a point b1 and a point b3 according to the following: b1=(1−ρ0)b0+ρ0{tilde over (b)} and b3=(1−ρ1)b4+ρ1{tilde over (b)}.
  • 26. A computer program product according to claim 22, wherein the second executable portion identifies point b2 by: defining weights (α0, α1) based upon the curvatures (κi, κi+1), wherein the weights (α0, α1) are defined such that α0, α1≧0 and α1+≦1; and identifying point b2 according to the following: b2=α0b1+α1b3+(1−α0−α1){tilde over (b)}.
  • 27. A computer program product according to claim 26, wherein the second executable portion defines weights (α0, α1) by: defining weights (ρ0, ρ1), wherein the weights (ρ0, ρ1) are identified such that 0<ρ0, ρ1≦1; and defining weights (α0, α1) according to the following: 70α0=R1⁢ρ121-ρ0andα1=R0⁢ρ021-ρ1,wherein 71R0:=4⁢κi⁢&LeftBracketingBar;b~-b0&RightBracketingBar;23⁢di×(b4-b~)andR1:=4⁢κi+1⁢&LeftBracketingBar;b4-b~&RightBracketingBar;23⁢(b~-b0)×di+1.
  • 28. A computer program product according to claim 21, wherein the third executable portion determines the interpolant p(t) according to the following:
  • 29. A computer program product according to claim 21, wherein the second executable portion identifies points b0, b1, b2, b3 and b4 such that the quartic interpolant p(t) is sixth-order accurate over the interval (i≦t≦i+1).
  • 30. A computer program product according to claim 21, wherein the third executable portion determines the quartic interpolant p(t) such that a change in the interpolant p(t) is directly proportional to a change at least one of the provided positions (fi, fi+1), directions (di, di+1) and curvatures (κi, κi+1).