Implicit curve

Cassini ovals:
(1) a=1.1, c=1 (above),
(2) a=c=1 (middle),
(3) a=1, c=1.05 (below)
implicit curve: sin(x+y)-cos(xy)+1=0
implicit curve \sin(x+y)-\cos(xy)+1=0 as level curves of the surface z=\sin(x+y)-\cos(xy)+1

In mathematics an implicit curve is a plane curve which is defined by an equation

F(x,y)=0.

Hence an implicit curve can be considered as the set of zeros of a function of two variables. Implicit means, that the equation is not solved for either x or y.

If F(x,y) is a polynomial in two variables, the corresponding curve is called an algebraic curve, and specific methods are available for studying it.

The graph of a function is usually described by an equation y=f(x) and is called an explicit representation. The third essential description of a curve is the parametric one: (x(t), y(t)), where the x- and y-coordinates of curve points are represented by two functions x(t)\, , y(t) dependent on a common parameter t. The change of representations is unusually simple only, when the explicit representation y=f(x) is given: y-f(x)=0 (implicit),  (t,f(t)) (parametric).

Examples of implicit curves:

  1. a line: x+2y-3=0\ ,
  2. a circle: x^2+y^2-4=0 \ ,
  3. the Semicubical parabola: x^3-y^2=0 \ ,
  4. Cassini ovals (x^2+y^2)^2-2c^2(x^2-y^2)-(a^4-c^4)=0 (see picture),
  5. \sin(x+y)-\cos(xy)+1=0 (see picture).

The first four examples are algebraic curves, but the last one is not algebraic. The first three examples possess simple parametric representations, which is not true for the 4th and 5th example. Especially the 5th example shows the possible complicated geometric structure of an implicit curve.

The implicit function theorem describes conditions, under which an equation F(x,y)=0 can be solved (theoretically) for x and/or y. But in general the solution may be not conducted. This theorem is the key for the computation of essential geometric features of the curve: tangents, normals, curvature (see below). In praxis implicit curves have an essential drawback: their visualization is difficult (see below). But there are computer programs, enabling to display an implicit curve (see weblinks). Special properties of implicit curves make them essential tools in geometry and computer graphic (see below).

An implicit curve with an equation F(x,y)=0 can be considered as the level curve of level 0 of the surface z=F(x,y) (see third picture).

Formulas

For the following formulas the implicit curve will be defined by an equation F(x,y)=0 , where function F meets the needed mathematical requirements. The partial derivatives of F are F_x, F_y, F_{xx}.

Tangent and normal vector

A curve point (x_0, y_0) is regular, if

The equation of the tangent at a regular point (x_0,y_0) is

 \mathbf n(x_0,y_0)=(F_x(x_0,y_0),F_y(x_0,y_0))^T is a normal vector.

Curvature

Due to clarity of the formulas the arguments (x_0,y_0) are omitted:

the curvature at a regular point..

Derivation of the formulas

The implicit function theorem guarantees within a neighborhood of a point (x_0,y_0) the existence of a function f such that F(x,f(x))=0 The derivatives of function f are (s. chain rule):

 f''=\frac{-F_y^2F_{xx}+2F_xF_yF_{xy}-F_x^2F_{yy}}{F_y^3} (The arguments were omitted.)

Inserting the derivatives of function f into the formulas for a tangent and curvature of the graph (x,f(x)):

 \kappa(x_0)=\frac{f''(x_0)}{(1+f'(x_0)^2)^{3/2}} (curvature)

one gets the formulas above

Advantage and disadvantage of implicit curves

Disadvantage

The essential disadvantage of an implicit curve is the lack of an easy possibility to calculate single points which is necessary for visualization of an implicit curve (s. next section).

Advantages

  1. Implicit representations facilitates the computation of intersection points: In case that one curve is represented implicitly and the other parametrically the computation of intersection points needs only a simple (1-dimensional) Newton iteration which is contrary to the cases implicit-implicit and parametric-parametric (see intersection).
  2. An implicit representation F(x,y)=0 gives the possibility to separate points not on the curve by the sign of F(x,y). This may be helpful for example applying the false position method instead of a Newton iteration.
  3. It is easy to generate curves which are geometrically similar to the given implicit curve F(x,y)=0. Add just a small number: F(x,y)-c=0 (see section smooth approximations).

Applications of implicit curves

smooth approximation of a convex polygon
smooth approximation of 1)one half of a circle, 2) an intersection of two circles

Within mathematics implicit curves play a prominent role as algebraic curves. Besides these classical field implicit curves are used for designing curves of desired geometrical shapes. Here are two examples.

Smooth approximation of convex polygons

A smooth approximation of a convex polygon can be achieved in the following way: Let g_i(x,y)=a_ix+b_iy+c_i=0, \ i=1,\dotsc,n be the equations of the lines containing the edges of the polygon such that for an inner point of the polygon g_i is positive than the implicit curve

F(x,y)=g_1(x,y)\cdots g_n(x,y)-c=0

with suitable parameters c are smooth (differentiable) approximations of the polygon. For example, the curves

F(x,y)=(x+1)(-x+1)y(-x-y+2)(x-y+2)-c=0 for c= 0.03, \dotsc, 0.6

are smooth approximations of a polygon with 5 edges (s. picture)

Remark 1:

In case of two lines

F(x,y)=g_1(x,y)g_2(x,y)-c=0

one gets

a pencil of parallel lines, if the given lines are parallel or
the pencil of hyperbolas, which have the given lines as asymptotes.

For example: The product of the coordinateaxes xy-c=0, \ c\ne 0, yields the pencil of hyperbolas, which have the coordinateaxes as asymptotes.

Remark 2:

If one starts with simple implicit curves other than lines (circles, parabolas,...) one gets a wide range of interesting new curves. For example

F(x,y)=y(-x^2-y^2+1)-c=0

(product of a circle and the x-axis) yields smooth approximations of one half of a circle (s. picture) and

F(x,y)=(-x^2-(y+1)^2+4)(-x^2-(y-1)^2+4)-c=0

(product of two circles) are smooth approximations of the intersection of two circles (s. picture).

Blending curves

blending curve (red) of two circles

In CAGD one uses implicit curves for the generation of blending curves, which are special curves establishing a smooth transition between two given curves. For example

F(x,y)=(1-\mu)f_1f_2-\mu (g_1g_2)^3 =0

generates blending curves between the two circles

f_1(x,y)=(x-x_1)^2+y^2-r_1^2=0 ,
f_2(x,y)=(x-x_2)^2+y^2-r_2^2=0

The method guarantees the continuity of the tangents and curvatures at the points of contact. (s. picture). The two lines

g_1(x,y)=x-x_1=0 , \ g_2(x,y)=x-x_2=0

determine the points of contact at the circles. Parameter \mu is a design parameter. For the picture: \mu= 0.05, \dotsc, 0.2 .

Visualization of an implicit curve

For visualizing an implicit curve one usually determines a polygon on the curve and displays the polygon. For a parametric curve this is an easy task: You just compute the points of a sequence of parametric values. For an implicit curve one has to solve two subproblems:

  1. determination of a first curve point to a given starting point in the vicinity of the curve,
  2. determination of a curve point starting from a known curve point.

In both cases it is reasonable to assume \operatorname{grad} F \ne (0,0) . It seems a strong restriction. But in practice the assumption is not met in single points only.

Point algorithm

For the solution of both tasks mentioned above it is essential to have a computer program \mathsf{CPoint}, which determines to a start point Q_0=(x_0,y_0) in the vicinity of the curve a point P on the curve:

(P1) for the start point is j=0
(P2) repeat
(x_{j+1},y_{j+1})= (x_j,y_j)- \frac{F(x_j,y_j)}{F_x(x_j,y_j)^2+F_y(x_j,y_j)^2}\, \left( F_x(x_j,y_j),F_y(x_j,y_j)\right)
( Newton step for function g(t)=F\left(x_j+tF_x(x_j,y_j),y_j+tF_y(x_j,y_j)\right) \ . )
(P3) until the distance between the points (x_{j+1},y_{j+1}),\, (x_j,y_j) is small enough.
(P4) P=(x_{j+1},y_{j+1}) is the curve point near the start point Q_0.

Tracing algorithm

to the tracing algorithm: starting points are green

In order to generate a nearly equally spaced polygon on the implicit curve one chooses a step length  s and

(T1) chooses a suitable starting point in the vicinity of the curve
(T2) determines a first curve point P_1 using program \mathsf{CPoint}
(T3) determines the tangent (s. above), chooses a starting point on the tangent using step length s (s. picture) and determines a second curve point P_2 using program \mathsf{CPoint} .
 \cdots

Because the algorithm traces the implicit curve it is called tracing algorithm. The algorithm traces only connected parts of the curve. If the implicit curve consists of several parts it has to be started several times with suitable starting points.

rasteralgorithm for implicit curves

Raster algorithm

If the implicit curve consists of several or even unknown parts, the following raster algorithm is more convenient visualizing the curve:

(R1) Generate a net (raster) on the area of interest of the x-y-plane .
(R2) choose any point of the raster as starting point for the point algorithm \mathsf{CPoint} and mark the determined curvepoint.

If the net is dense enough one gets the impression of connected parts of the implicit curve. If for further applications polygons on the curves are needed one can trace parts of interest by the tracing algorithm.

Example: Given the implicit curve

F(x,y)=(3x^2-y^2)^2y^2-(x^2+y^2)^4=0

In order to demonstrate the algorithm the raster was widely spaced. The picture shows the single curve points determined by the raster algorithm. In order to accelerate the algorithm not every raster point was used as starting point.[1]

Free Software

The following free software packages allow the visualization of implicit curves:

Additional software is mentioned in section Weblinks.

Implicit space curves

Any space curve which is defined by two equations

\begin{matrix}
F(x,y,z)=0, \\
G(x,y,z)=0 \end{matrix}

is called implicit space curve.

A curve point (x_0,y_0,z_0) is called regular,if the cross product of the gradients F and G is not (0,0,0) at this point:

\mathbf t(x_0,y_0,z_0)=\operatorname{grad}F(x_0,y_0,z_0)\times \operatorname{grad}G(x_0,y_0,z_0)\ne (0,0,0)

otherwise singular. Vector \mathbf t(x_0,y_0,z_0) is a tangent vector of the curve at point (x_0,y_0,z_0).

Intersection curve between a sphere and a cylinder

Examples:

  (1)\quad x+y+z-1=0 \ ,\ x-y+z-2=0

is a line.

(2)\quad  x^2+y^2+z^2-4=0 \ , \ x+y+z-1=0

is a plane section of a sphere, hence a circle.

 (3)\quad x^2+y^2-1=0 \ , \ x+y+z-1=0

is an ellipse (plane section of a cylinder).

(4)\quad x^2+y^2+z^2-16=0 \ , \ (y-y_0)^2+z^2-9=0

is the intersection curve between a sphere and a cylinder

For the computation of curve points and the visualizition of an implicit space curve see intersection.

See also

External links

Wikimedia Commons has media related to Implicit curves.

References

  1. G. Taubin: Distance Approximations for Rastering Implicit Curves. ACM Transactions on Graphics, Vol. 13, No. 1, 1994.
This article is issued from Wikipedia - version of the Sunday, November 15, 2015. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.