CA2212394A1 - Arc-length reparameterization - Google Patents

Arc-length reparameterization

Info

Publication number
CA2212394A1
CA2212394A1 CA002212394A CA2212394A CA2212394A1 CA 2212394 A1 CA2212394 A1 CA 2212394A1 CA 002212394 A CA002212394 A CA 002212394A CA 2212394 A CA2212394 A CA 2212394A CA 2212394 A1 CA2212394 A1 CA 2212394A1
Authority
CA
Canada
Prior art keywords
length
arc
curve
along
path
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
CA002212394A
Other languages
French (fr)
Inventor
David P. Simons
Scott S. Snibbe
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Adobe Inc
Original Assignee
Adobe Systems Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Adobe Systems Inc filed Critical Adobe Systems Inc
Publication of CA2212394A1 publication Critical patent/CA2212394A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/20Drawing from basic elements, e.g. lines or circles
    • G06T11/203Drawing of straight lines or curves
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T13/00Animation

Abstract

A computer-implemented method and apparatus for reparameterizing a parametric function representing an animation feature in an animation system where the parametric function is represented by a curve having unequal arc-length per unit parameter. The system samples at intervals of the parameter along the length of the curve and then calculates the arc-length over each interval. Thereafter, one or more differentiable curves are fitted to the parameter, arc-length pairs.

Description

CA 022l2394 l997-08-06 PATENT
ATTORNEY DOCKET NO: 07844/099001 ARC-LENGTH REPARAMETERIZATION
Background The present invention relates generally to methods and apparatus for animation in a movie system and more particularly to a method and apparatus for smoothing animation effects by compensating for arc-length variations in motion as an object travels along a path.
Programmed computers can be used to edit and create movies. For example, a computer program product called After Effects, available from Adobe Systems Incorporated of Mountain View, California, is licensed for used on a variety of personal computers and provides its user the ability to edit and create movies by integrating and arranging pieces of footage. In such programs, the process of creating a movie typically occurs in two major stages: modeling and rendering.

Modeling is the process of creating the structure for a movie project, commonly called a "composition", by defining the arrangement and timing of imported footage. A composition is essentially a set of instructions that define the processing of footage pieces in space and time in the formation of a movie. Each composition typically includes the definition of one or more layers, which are place holders for 25 pieces of footage. Modeling includes the sub-processes of importing footage into the layers in a composition, editing the footage, arranging or ~compositing" the various pieces of footage, and adding animation or other effects to the composition layers.
Imported footage may be in the form of video, pictures, animations, drawings, stills, photographs or computer generated images. Each piece of imported footage is CA 022l2394 l997-08-06 assigned to a layer. Compositing integrates or combines the footage of the respective layers by using geometry masks, transparency information and effects. As the layers of the composition are integrated in the composition, animation and other effects are applied to each layer.
To create a final output, such as a film or videotape for viewing, the composition must be rendered. The rendering process transforms the footage and instructions associated with each layer into finished video frames. During the rendering process, corresponding pixels from each layer are composited on top of each other to create a final image, a frame at a time, in the output format requested by the user.
The frames may then be written for either analog or digital storage on a recording device such as a video tape recorder, 15 photographic film recorder or digital disk recorder. In this way a movie is produced.
Animation, as described above, is a subprocess of the modeling stage. Animation techniques allow a user to create apparently spontaneous, lifelike movement of objects in the composition. Most movie systems allow a user to animate an object (i.e., a layer) by specifying a path of the object as it moves through a two- or three-dimensional space. The path is typically represented as a spline curve Q. Motion along this spline curve Q may then be described by a single function (e.g., u as a function of time, where u is the natural parameter of the function defining Q).

Summary of the Invention In general, in one aspect, the invention provides a computer-implemented method and apparatus for reparameterizing a parametric function representing an animation feature in an animation system where the parametric function is represented CA 022l2394 l997-08-06 by a curve having unequal arc-length per unit parameter. The system samples at intervals of the parameter along the length of the curve and then calculates the arc-length over each interval. Thereafter, one or more differentiable curves are fitted to the parameter, arc-length pairs.
In one embodiment, the reparameterization method may be used for smoothing animation of an object as it moves along a path in a display space in an animation system.
Advantages of embodiments of the invention include the following. Application of the present invention requires a minimum of storage space for mapping the parameter value u to an arc-length s. In addition, first order continuity is provided by the reparameterization function A-1, which maps a continuous function to the (u,s) pairs.
Other advantages and features will be apparent from the following description and from the claims.

Brief Description of the Drawings Figure 1 is a flow chart for a reparameterization method according to the present invention.
Figure 2a is a graph of an illustrative spline curve Q
having even parametric intervals defining the motion of an object in a display area.
Figure 2b is a graph of parameter value u versus actual distance traveled along the curve Q of Figure 2a.
Figure 2c is a graph of the velocity of an object along curve Q.
Figure 3 is a flow chart of a method of determining the position of an object along a path Q for a time t.
Figure 4 is a flow chart of a method of fitting a 30 plurality of curves to data entries in a table according to the present invention.

CA 022l2394 l997-08-06 Figure 5 is a schematic block diagram of a programmable computer suitable for executing computer programs according to the present invention.

Detailed Description Referring to Figure 1, in a process of animating an object in a composition, a user selects (100) an object, such as a layer in a movie composition, for animation. The user then designates (102) the particular object property to be animated. Object properties that may be animated include layer position, anchor point, effect point controls and color selection. For example, the animation of a layer's position property allows a user to move the layer across the display area. For the sake of clarity, the present invention will be described in terms of animating a single property, namely 15 position. However, the reparameterization process may also be applied to the animation of other properties having separate temporal control such as anchor point, effect point controls and color selection.
The user defines (104) an initial object property state and a final object property state, such as starting and ending positions of the object as it travels in the display area. The starting or ending positions may reside outside the display area to allow for the entry or exit of the object into or from the display area.
The user defines (106) a path Q in the property space, that the object will follow between the starting and ending property states. In one embodiment, the path is defined by a curve function Q(u) which determines the location of the object on path Q. The curve may be of the form of a cubic spline, a fourth-order spline, a Bezier spline, a Hermite spline, or a concatenation of splines. For two-dimensional CA 022l2394 l997-08-06 position space, function Q(u) can be expressed in the following form:

Q(u) = (x(u),y(u)) (1) Normally, the user specifies such a function by manipulating control points of a graph of the function through a graphical user interface. For example, the function may be of the form of a Bezier curve having associated therewith control points for manipulating the curve between starting and ending property states in the display space.
However, equal steps in the parameter u may result in unequal distances s traveled along the spline curve Q.
Referring to Figure 2a, a graph of a 3 point spline curve Q is shown with tick marks at even parametric intervals. Figure 2b, is a graph of parameter value u versus actual distance s (measured in display space) along the spline curve Q. Figure 2c, is a graph of the motion along the path Q expressed as arc-distance versus time. An object traveling along path Q
(Figure 2a) according to the motion graph (Figure 2c), will appear to have velocity changes at points 10, 12 and 14 (Figure 2a). This is due to the unequal steps of arc-length s along the curve Q with respect to the parameter u.
Accordingly, the shape of the curve Q and the spacing of its control points may result in apparent motion (in the case of a position parameter, apparent velocity) to a viewer. This 25 problem is addressed by reparameterizing the spline Q by arc length, where equal steps of an arc-length parameter s map to equal distance measured in display space along a spline curve Q-It is generally desirable to decouple motion along CA 022l2394 l997-08-06 path Q from spatial position. Motion is generally described in a motion graph S which maps a time to a distance traveled on path Q. For example, where the motion along the path is expressed in terms of velocity (for animation of a position 5 parameter), the user may choose to have a linear velocity along all points of path Q. Alternatively, a user may desire that the object's velocity vary over the length of the path (e.g., slow at the beginning of the path and then fast at the end of the path so as to simulate acceleration of the object along the path). In one embodiment, the motion graph is a one dimensional function S over time, where the distance s (arc distance or arc-length) traveled along the path Q may be described for any time t as:

s = S(t) (2) The path Q is parameterized by its natural parameter u. The motion graph S defines a distance traveled in terms of an arc length s. In order to parameterize a spline curve Q by arc-length, a formulation for the arc-length s along the original curve Q(u) with respect to the original parameter u is derived. The arc-length s for the curve Q(u)is formally expressed as:

s = A(u) (3) where A is a function for determining the arc-length at all parameter values u.
A segment of arc-length ds between points Q(u) and Q(u + du) is defined by the equation:

CA 022l2394 l997-08-06 ds = 1¦dX 2 + dy 2 '\ ( du) ( du) To determine the arc-length from the start of the curve to a point at parameter value u, equation (4) is integrated resulting in:

ds = ~ ~--) + (--) d (5) There is no general analytic expression for this integral, so it is evaluated using numerical techniques.
The system constructs a table TA comprising (u,s) pairs by sampling at even intervals of u along the entire curve Q (110). For a given value of u, the system calculates an arc length s measured from the beginning of curve Q (u=0) by summing arc-length segments calculated using Equation 4.
In one embodiment, a recursive sub-division algorithm is used to determine the sampling points along the spline as opposed to an even sampling interval. In a recursive sub-division process, the spline is divided recursively into smaller sections until the arc distance between sample points falls beneath a user specified arc-distance threshold level.
Accordingly, portions of the spline may include a higher density of sample points than others.
As described above the function A may be used to determine the arc-length s at all points u according to Equation (3). The system fits (112) a curve to the data points stored in table TA to derive an approximation for CA 022l2394 l997-08-06 function A. In one embodiment, the curve is a 2-dimensional curve, and more particularly a Bezier curve, evaluated as a one-dimensional function. Alternatively, a series of Bezier curves may be used to approximate function A as is described 5 below in association with Figure 4.
The curve derived from table TA of (u,s) pairs is used to map a value of u to an arc-length s. The curve represents the reparameterizing of spline Q by arc-length. Now, equal steps of the arc-length parameter s, map to equal distance traveled along the curve Q.
For every value of u, there exists a singular value s, as defined by the function A. Function A is one-to-one and the inverse function A-1 is determinable. The inverse function A-1 is determined (114) and stored (116) for use in determining the position of an object on path Q for any time t. The inverse function A-1 is referred to as the reparameterization function. Table TA may be used to construct either function A or A-1 depending on the application (either mapping the parameter value u to an arc-length s, or alternatively mapping an arc-length s to a parameter value u). In one embodiment, a single approximation of either function A or A-1 is stored, from which the inverse is derived.
Referring to Figure 3, the position on the path Q at a time t is determined by using the reparameterization function A-1 to compensate for arc-length variations and achieve motion in accordance with the motion defined by a motion graph S.
In a process for controlling the motion of an object along path Q, the user defines a motion graph S (201).
Thereafter, the system determines the position of an object on path Q at a time t by calculating (202) an arc-length s (traveled from a start point on path Q) according to the CA 022l2394 l997-08-06 formula:

5 = S(t) (6) The system retrieves (204) the reparameterization function and applies (206) it to the calculated arc-length s to calculate a parameter value u according to the formula:

u = A ~(s) (7) The system then calculates (208) the position along path Q for the parameter u according to the formula:

Q(u) = (x(U),y(u)) (8) 10The object may then be moved to its appropriate position on path Q for the designated time t. The process may be repeated for any time t as the object travels between starting and ending points along path Q. Accordingly, the system may check (210) to determine if any other time values 15 need to be processed (210)(e.g. has the object reached the end point yet). If so, then a next time value is determined (212), and the next position for the object on path Q is determined by repeating steps 202 through 208. Alternatively, the process ends (214).
This technique requires a minimum of storage space for mapping the parameter value u to an arc-length s. In addition, first order continuity is provided by the reparameterization function A-1, which maps a continuous CA 022l2394 l997-08-06 function to the (u,s) pairs. In one embodiment, by using the reparameterization function an accurate graph of velocity vs.
time (velocity graph) may be provided to the user. An editable velocity graph is a simple tool for controlling the 5 motion of an object along a path which allows the user to directly manipulate the speed of the object at various points along the path. The use of a continuous function to approximate the mapping from a parameter value u to an arc-length s, allows for accurate editable control of object 10 motion that accounts for arc-length variances per unit parameter. Accordingly, when the user animates a position parameter (as described above), the velocity of the object as it travels along a path Q is based on a smooth function resulting in animation that appears smooth to the viewer. The 15 use of a smooth function is necessary to accommodate the sensitivities of human visual perception to movement in visual display applications.
As was described above, fitting a curve to the (u,s) pairs provides an approximation of function A which maps a 20 value of u to an arc-length s. Alternatively, a more exact approximation for function A may be derived by fitting multiple contiguous curves to the (u,s) pairs stored in table A. Referring now to Figure 4, in a method for fitting a plurality of curves to data entries in a table, the system retrieves (400) the first three entries in table A. The system fits (402) a curve (curve1) to the three data entries ((u,s) pairs). In one embodiment, the curve is a 2-dimensional curve, and more particularly a Bezier curve, evaluated as a one-dimensional function.
Thereafter, the system checks (404) to determine if more data entries are to be processed. If not, the process is complete (416). If so, then the system retrieves (406) a next CA 022l2394 l997-08-06 data entry (new data) from table A. The system checks (408) the accuracy of the approximation curve (in this case curvel) for the new data. If the new data falls on the curve or within a predetermined error distance from the curve, then the curve approximation is valid for the new data, and a check at step 404 is repeated to determine if there are anymore data entries to process. If not, then the process is complete. If so, then the next table entry is retrieved repeating steps 406 and 408 for the new data.
If the new data does not fall on the curve or within a predetermined error distance from the curve, then a new curve segment is constructed. First, the system stores (410) the old curve (in this case curvel). The system then checks (412) to determine if two more data entries in table A need to be 15 processed. If so, the system retrieves (414) the next two data entries from table A for a total of three data entries, and continues the process at step 402 until done.
If less than two data entries are available, the process terminates. Alternatively, if one more data point is available, a final curve (straight line) may be constructed from the last two data points.
Alternatively, a recursive multiple curve approximation process may be used. Specifically, a single curve is fitted to the table TA of (u,s) pairs. The system then checks to determine the maximum difference between the sample points (the (u,s) pairs) and the generated curve. If the maximum difference between any of the pairs and the generated curve does not exceed a predetermined threshold, then the single curve approximation is sufficiently accurate, and the curve is stored. Alternatively, the data entries in the table TA are subdivided at the point of greatest difference and a curve is fitted to each portion of the CA 022l2394 l997-08-06 subdivided table TA entries. The system again checks for each sub-division for the maximum difference between any of the pairs in the sub-division and the generated curve. The process may be repeated as required dividing the table TA into smaller and smaller sub-divisions, until the maximum difference for all the fitted curves applied to their respective sub-division is less than the predetermined threshold. Thereafter, the sequence of curves may be stored.

The invention may be implemented in hardware, firmware or software, or a combination of the three. Preferably the invention is implemented in a computer program executed on a programmable computer having a processor, a data storage system, volatile and non-volatile memory and/or storage elements, at least one input device and at least one output device.
By way of example, Figure 5 shows a block diagram of a programmable processing system 10. Programmable processing system (computer) 10 preferably includes a processor 20, random access memory (RAM) 21, a program memory 22 (preferably a writable read-only memory (ROM) such as a flash ROM), a hard drive controller 23, video controller 31 and an input/output (I/O) controller 24 coupled by a CPU bus 25.
Hard drive controller 23 is coupled to a hard disk 30, 25 which may be used for storing application programs, such as After Effects, and data. Video controller 31 is coupled to video recorder 32, which may be used for storing and importing video footage and for writing final output. I/O controller 24 is coupled by means of an I/O bus 26 to an I/O interface 27.
I/O interface 27 receives and transmits data in analog or digital form over communication links such as a serial link, local area network, wireless link, and parallel link. Also CA 022l2394 l997-08-06 coupled to I/O bus 26 is a display 28 and a keyboard 29.
Alternatively, separate connections (separate buses) may be used for I/O interface 27, display 28 and keyboard 29.
Programmable processing system 10 may be preprogrammed or it 5 may be programmed (and reprogrammed) by downloading a program from another source (e.g., a floppy disk, CD-ROM, or another computer).
Each computer program is preferably stored in a storage media or device (e.g. program memory 22 or magnetic disk) readable by a general or special purpose programmable computer, for configuring and operating a computer when the storage media or device is read by the computer to perform the procedures described herein. The inventive system may also be considered to be implemented as a computer-readable storage 15 medium, configured with a computer program, where the storage medium so configured causes a computer to operate in a specific and predefined manner to perform the functions described herein.
The present invention has been described in terms of specific embodiments. The invention, however, is not limited to these specific embodiments. Rather, the scope of the invention is defined by the following claims, and other embodiments are within the scope of the claims. For example, the present invention has been described in terms of animating the position of an object in display space. The principles of the present invention are equally applicable to other animation features including mask shape, 3D object transformation and animatable n-dimensional properties, such as color selection, layer anchor point and effect point controls. In addition, the present invention has been described in terms of two-space representations. The principles of the present invention are equally applicable to CA 022l2394 l997-08-06 three- or more space representations. In another example, the present invention has been described in one embodiment as a method of determining the position of an object along a path at a time t. Alternatively, the principles of the present invention may be used to precisely locate objects at even distances along a path for use in drawing or pixel-layout programs. In these systems, rather than solving Equation for u using the reparameterization function A 1, we solve for s and use the approximation of function A for a given parameter 10 value of u. Similarly, other uses of the reparameterization function A~1 and its inverse A, may be found. For example, the reparameterization function A~1 may be used in conjunction with the principles of the present invention to measure arc-lengths (distance) traveled along a spline in a computer-aided design or architecture program.

What is claimed is:

Claims (25)

1. A computer-implemented method of reparameterizing a parametric function of a formal parameter that defines a curve representing an animation feature in a animation system, comprising the steps of:
sampling the parameter along the length of the curve;
at each parameter sample point, calculating the arc-length to determine a (sample, arc-length) pair; and fitting a differentiable curve to the (sample, arc-length) pairs.
2. The method of claim 1 wherein the differentiable curve is a 2-dimensional Bezier curve evaluated as a one dimensional function.
3. The method of claim 1 wherein said differentiable curve is comprised of a plurality of Bezier curves.
4. The method of claim 3 wherein the step of curve fitting further comprises the steps of characterizing a first set of pairs using a first Bezier curve to approximate the changes in arc-length over time for a series of contiguous pairs until the first Bezier curve approximation exceeds a predetermined error, and curve fitting over a next set of pairs by using a second Bezier curve to approximate the change in arc-length over time for a second series of contiguous pairs until the second Bezier curve approximation exceeds a predetermined error.
5. The method of claim 3 wherein the step of curve fitting further comprises the steps of:
characterizing the changes in arc-length over time for all (sample, arc-length) pairs using a first Bezier curve;
determining the maximum difference between the first Bezier curve and any of the (sample, arc-length) pairs;
if the maximum difference exceeds a predetermined difference level, dividing the (sample, arc-length) pairs at the point of greatest difference and characterizing the changes in arc-length over time for each sub-divided portion of (sample, arc-length) pairs using a second Bezier curve.
6. The method of Claim 1 where the parametric function is selected from the group consisting of a cubic spline, a fourth-order spline, a Bezier spline, a Hermite spline, and a concatenation of splines.
7. The method of claim 1 where the animation feature is motion in a space selected from the group consisting of a two-dimensional position space, a three-dimensional position space, and color space.
8. The method of claim 1 where the animation feature is selected from the group of mask shape, 3D object transformation and animatable n-dimensional properties.
9. The method of claim 1 where the arc-length of the curve is not proportional to the formal parameter.
10. The method of claim 1 where the sampling is done at regular intervals of the formal parameter.
11. The method of claim 1 where the sampling is done by recursive sub-division until the arc-length between samples is less than a predetermined distance.
12. A computer-implemented method of smoothing animation of an object as it moves along a path in a display space in an animation system, where the path is described by a parametric function that defines a curve representing an animation feature, comprising the steps of:
defining the motion along the path as a function of distance along the path versus time;
reparameterizing the curve to derive an arc-length sensitive function for determining the motion along the curve where equal steps of arc-length of the arc-length sensitive function map to equal distance traveled along the curve; and determining the position of the object along the path for any time t according to the arc-length sensitive function.
13. The method of claim 12 wherein the reparameterization step further includes the steps of:
sampling the parameter along the length of the curve;
at each parameter sample point, calculating the arc-length to determine a (sample, arc-length) pair; and fitting a differentiable curve to the (sample, arc-length) pairs.
14. The method of claim 12 where the animation feature is motion in a space selected from the group consisting of a two-dimensional position space, a three-dimensional position space, and color space.
15. The method of claim 1 where the animation feature is selected from the group of mask shape, 3D object transformation and animatable n-dimensional properties.
16. A computer program, residing on a computer-readable medium, comprising instructions for causing a computer to:
receive two end points in a display space and a definition of a path between the end points represented by a curve wherein the path defines a parametric function representing an animation feature in an animation system;
define the motion between the two points as a function of distance traveled along the path versus time;
reparameterize the curve to derive an arc-length sensitive function for determining the motion between the two end points along the curve where equal steps of arc-length of the arc-length sensitive function map to equal distance traveled along the curve; and determine the position of the object for any time t according to the arc-length sensitive function.
17. A computer-implemented method of determining the location of an object at a time t as it travels along a path Q
in an animation system comprising the steps of:
defining the path Q between two end points represented by a curve wherein the path defines a parametric function Q(u) representing an animation feature in an animation system;
defining the motion between the two points as a function S of time;

reparameterizing the curve to derive an arc-length sensitive function A for determining the motion between the two end points along the curve where equal steps of arc-length s of the arc-length sensitive function map to an equal distance traveled along the spline curve such that s=A(u);
inverting the arc-length function A to derive A-1;
calculating the arc length traveled for a time t by function S;
calculating a parameter u according to the formula u=A-1(s); and calculating the position on path Q using the calculated parameter u according to the parametric function Q(u).
18. The method of claim 17 wherein the reparameterization step further includes the steps of:
sampling the parameter along the length of the curve;
at each parameter sample point, calculating the arc-length to determine a (sample, arc-length) pair; and fitting a differentiable curve to the (sample, arc-length) pairs.
19. A computer-implemented method of placing objects along a path in a display space in an animation system, where the path is described by a parametric function that defines a curve representing an animation feature, comprising the steps of:

reparameterizing the curve to derive an arc-length sensitive function for determining the position along the curve where equal steps of arc-length of the arc-length sensitive function map to equal distance traveled along the curve; and placing objects at equal distances along the path according to the arc-length sensitive function.
20. The method of claim 19 wherein the reparameterization step further includes the steps of:
sampling the parameter along the length of the curve;
at each parameter sample point, calculating the arc-length to determine a (sample, arc-length) pair; and fitting a differentiable curve to the (sample, arc-length) pairs.
21. The method of claim 19 where the step of placing objects includes the steps of determining the position along the path of each object by defining the arc-length spacing between objects and determining the position in display space according to the arc-length sensitive function.
22. The method of claim 19 where the objects are printed text.
23. A computer-implemented method of measuring arc-length along a path in a display space in an animation system, where the path is described by a parametric function that defines a curve representing an animation feature, comprising the steps of:
reparameterizing the curve to derive an arc-length sensitive function for determining the position along the curve where equal steps of arc-length of the arc-length sensitive function map to equal distance traveled along the curve; and determining the arc-length of the curve for a given position on the path according to the arc-length sensitive function.
24. The method of claim 23 wherein the reparameterization step further includes the steps of:
sampling the parameter along the length of the curve;
at each parameter sample point, calculating the arc-length to determine a (sample, arc-length) pair; and fitting a differentiable curve to the (sample, arc-length) pairs.
25. The method of claim 23 where the step of determining the arc-length of the curve includes the steps of calculating a parameter value u from the position and determining the arc-length according to the arc-length sensitive function.
CA002212394A 1996-08-07 1997-08-06 Arc-length reparameterization Abandoned CA2212394A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/693,942 US6115051A (en) 1996-08-07 1996-08-07 Arc-length reparameterization
US08/693,942 1996-08-07

Publications (1)

Publication Number Publication Date
CA2212394A1 true CA2212394A1 (en) 1998-02-07

Family

ID=24786769

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002212394A Abandoned CA2212394A1 (en) 1996-08-07 1997-08-06 Arc-length reparameterization

Country Status (4)

Country Link
US (1) US6115051A (en)
EP (1) EP0827116A3 (en)
JP (1) JP4131993B2 (en)
CA (1) CA2212394A1 (en)

Families Citing this family (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6683613B1 (en) * 1998-12-23 2004-01-27 Adobe Systems Incorporated Multi-level simulation
US7031538B2 (en) * 1999-12-17 2006-04-18 Level Set Systems, Inc. Method and apparatus for feature-based quantization and compression of data
US7362331B2 (en) 2000-01-05 2008-04-22 Apple Inc. Time-based, non-constant translation of user interface objects between states
WO2001055971A1 (en) * 2000-01-31 2001-08-02 Ivast, Inc. Textual format for animation in multimedia systems
AU2001292202A1 (en) * 2000-09-19 2002-04-02 Technion Research And Development Foundation Ltd. Method and apparatus for shape deformation and placement
US6548784B2 (en) * 2001-04-05 2003-04-15 Illinois Tool Works Inc. Controlled output for welding
US20040205518A1 (en) * 2001-09-21 2004-10-14 Ming-Chih Shih System and method of measuring a distance between two points of a layout
US6923079B1 (en) 2001-10-31 2005-08-02 Scott S. Snibbe Recording, transmission and/or playback of data representing an airflow
US6750427B1 (en) * 2002-11-27 2004-06-15 Illinois Tool Works Inc Controlled welding output with fused electrode detection
US7656406B1 (en) 2003-10-28 2010-02-02 Adobe Systems Incorporated Representing and animating paint strokes
US7129950B2 (en) * 2004-02-20 2006-10-31 Pixar Sawtooth spline display
US7969440B1 (en) * 2007-05-02 2011-06-28 Evernote Corporation Method and system for curve fitting using digital filtering
US8014630B1 (en) * 2007-05-02 2011-09-06 Evernote Corporation Method and apparatus for representing image data using digital filtering and adaptive parameterization
US8521484B2 (en) * 2010-06-02 2013-08-27 Livermore Software Technology Corp. Curve matching for parameter identification
US9070224B1 (en) * 2012-10-11 2015-06-30 Google Inc. Accurate upper bound for bezier arc approximation error
CN105046059B (en) * 2015-06-24 2017-09-29 深圳市腾讯计算机系统有限公司 Play sport track determines method and device
US11387729B2 (en) 2016-04-15 2022-07-12 Emerson Climate Technologies, Inc. Buck-converter-based drive circuits for driving motors of compressors and condenser fans
US10320322B2 (en) 2016-04-15 2019-06-11 Emerson Climate Technologies, Inc. Switch actuation measurement circuit for voltage converter
US10277115B2 (en) 2016-04-15 2019-04-30 Emerson Climate Technologies, Inc. Filtering systems and methods for voltage control
US10305373B2 (en) 2016-04-15 2019-05-28 Emerson Climate Technologies, Inc. Input reference signal generation systems and methods
US10656026B2 (en) 2016-04-15 2020-05-19 Emerson Climate Technologies, Inc. Temperature sensing circuit for transmitting data across isolation barrier
US10763740B2 (en) 2016-04-15 2020-09-01 Emerson Climate Technologies, Inc. Switch off time control systems and methods
US9965928B2 (en) * 2016-04-15 2018-05-08 Emerson Climate Technologies, Inc. System and method for displaying messages in a column-by-column format via an array of LEDs connected to a circuit of a compressor
US9933842B2 (en) 2016-04-15 2018-04-03 Emerson Climate Technologies, Inc. Microcontroller architecture for power factor correction converter
US10075065B2 (en) 2016-04-15 2018-09-11 Emerson Climate Technologies, Inc. Choke and EMI filter circuits for power factor correction circuits
US10515665B1 (en) 2016-08-31 2019-12-24 Dataclay, LLC System and method for automating the configuration and sequencing of temporal elements within a digital video composition
US10564989B2 (en) * 2017-11-28 2020-02-18 Microsoft Technology Licensing Thread independent parametric positioning for rendering elements
US10424041B2 (en) 2017-12-11 2019-09-24 Microsoft Technology Licensing, Llc Thread independent scalable vector graphics operations
WO2019136365A1 (en) 2018-01-08 2019-07-11 Immersion Networks, Inc. Methods and apparatuses for producing smooth representations of input motion in time and space
US11016643B2 (en) 2019-04-15 2021-05-25 Apple Inc. Movement of user interface object with user-specified content
CN111368420A (en) * 2020-03-02 2020-07-03 厦门大学 GPU accelerated parameter curve arc length calculation and arc length parameterization method
CN113515091B (en) * 2021-04-02 2022-05-20 华中科技大学 Real-time track interpolation method and device for corner smoothing spline

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4674058A (en) * 1981-12-07 1987-06-16 Dicomed Corporation Method and apparatus for flexigon representation of a two dimensional figure
KR930002339B1 (en) * 1989-04-20 1993-03-29 가부시기가이샤 도시바 Method for fitting third-degree bezier curves to series of data points
EP0461577B1 (en) * 1990-06-11 1998-12-02 Hitachi, Ltd. Apparatus for generating object motion path
JPH0458378A (en) * 1990-06-28 1992-02-25 Mitsubishi Heavy Ind Ltd Method for dividing and developing bezier curve
JP2522108B2 (en) * 1990-10-17 1996-08-07 株式会社精工舎 Curve fitting method
AU9015891A (en) * 1990-11-30 1992-06-25 Cambridge Animation Systems Limited Animation
US5408598A (en) * 1991-05-23 1995-04-18 International Business Machines Corporation Method for fast generation of parametric curves employing a pre-calculated number of line segments in accordance with a determined error threshold
US5317650A (en) * 1991-07-29 1994-05-31 Xerox Corporation Determination of the arc length of a curve
US5363479A (en) * 1992-07-02 1994-11-08 Microsoft Corporation System and method for rendering bezier splines
JPH06110992A (en) * 1992-09-25 1994-04-22 Agency Of Ind Science & Technol Shape deformation input operation method in cad system
US5500927A (en) * 1993-03-18 1996-03-19 Macromedia, Inc. System and method for simplifying a computer-generated path
US5473742A (en) * 1994-02-22 1995-12-05 Paragraph International Method and apparatus for representing image data using polynomial approximation method and iterative transformation-reparametrization technique
US5638503A (en) * 1994-07-07 1997-06-10 Adobe Systems, Inc. Method and apparatus for generating bitmaps from outlines containing bezier curves
US5694535A (en) * 1995-03-24 1997-12-02 Novell, Inc. Direct interactive, constant-time curve apparatus and method

Also Published As

Publication number Publication date
EP0827116A3 (en) 1999-07-28
JPH10134203A (en) 1998-05-22
EP0827116A2 (en) 1998-03-04
JP4131993B2 (en) 2008-08-13
US6115051A (en) 2000-09-05

Similar Documents

Publication Publication Date Title
US6115051A (en) Arc-length reparameterization
US5929867A (en) Floating keyframes
US6097396A (en) Method and apparatus for creating lifelike digital representation of hair and other fine-grained images
EP2043049B1 (en) Facial animation using motion capture data
Orzan et al. Diffusion curves: a vector representation for smooth-shaded images
US5611036A (en) Apparatus and method for defining the form and attributes of an object in an image
US6268865B1 (en) Method and apparatus for three-dimensional painting
US20030001834A1 (en) Methods and apparatuses for controlling transformation of two and three-dimensional images
US20020027555A1 (en) Method of rendering motion blur image and apparatus therefor
US9501811B2 (en) Resizing an image
US20040024575A1 (en) Method and apparatus for shape deformation and placement
US7420574B2 (en) Shape morphing control and manipulation
US5566282A (en) Apparatus and method for the visualization of a three-dimensional scene by means of maximum intensity projection
JP2009526335A (en) Digital image self-adaptive brush
Browning et al. Stylized keyframe animation of fluid simulations
US8358311B1 (en) Interpolation between model poses using inverse kinematics
Sheng et al. Controllable shadow generation using pixel height maps
US6339433B1 (en) Creating a blend of color and opacity between arbitrary edges
EP1190393B1 (en) Method and apparatus for rendering images
US6693646B1 (en) Method and system for iterative morphing
Froumentin et al. A Vector‐based Representation for Image Warping
US8902233B1 (en) Driving systems extension
US20190340806A1 (en) Noise reduction on g-buffers for monte carlo filtering
JP2837514B2 (en) Image editing device
EP3401881A1 (en) Editing device for three-dimensional shape data, program, and method

Legal Events

Date Code Title Description
FZDE Discontinued
FZDE Discontinued

Effective date: 20000807