The geometry of AD is handled by a constraint solver that arranges primitives such as points, lines and curves in a state that satisfies a given list of requirements. The requirements can be for example a specific location of a point, length of a line or angle between two lines. The constraint approach is particularily useful in the feature modelling paradigm: constraints can be set in any order and in a context free fashion. For example a feature can mark some elements as symmetrical along an axis before even knowing where they will be located in a product.
The solver is guided by a weighting scheme that prioritises some constraints over others; for low weight constraints the system finds the best possible compromise relative to others and for high weight ones only an exact solution is accepted. For example a side seam ending to a hem panel should be in roughly 90° angle relative to the hem, but in most cases small deviations are acceptable. On the other hand a point on the center front plane of a symmetrical product should always stay strictly on the plane.
The system of constraints is solved with an iterative conjugate gradient method.
CONSTRAINTS
data:image/s3,"s3://crabby-images/5ae76/5ae76a5bf71e7c2b36f4fb0566d4363f575cc804" alt=""
Point can be moved to coincide with another point, a circle or a sphere. In the case of the sphere, if the point is inside the sphere, it won't be moved to the surface.
data:image/s3,"s3://crabby-images/83aa0/83aa02895d6f394af31dc85d973ccb9990a61e0d" alt=""
An edge length of an object can be set to an exact value or to a even multiply of a given length.
data:image/s3,"s3://crabby-images/3f700/3f70088d0758bc85bf6d22563b2f4bc51af6dfa2" alt=""
Corner angle between two edges can be fixed to a given value.
data:image/s3,"s3://crabby-images/124aa/124aa85d02900759c2c87d54c74226312c9be003" alt=""
Bending constraint tries to minimise the bending energy of an internal edge, i.e. straighten a shape to a plane if no other constraints are present. Bending takes an optional stiffness argument that determines how strongly the straightening works against other constraints.
data:image/s3,"s3://crabby-images/aa98b/aa98b5accbd20f621084c631dbc614c4719df89d" alt=""
A point can be locked into a plane, or to a signed direction relative to a plane, i.e. once the point is on the desired side of the plane, not further motion is applied.
Planes can also be used to set a pair of points in a mirrored state relative to the plane.
data:image/s3,"s3://crabby-images/9e7a7/9e7a7c4e73382fadc2cfdec5993aacd39a67e310" alt=""
Graph theoretic distance can be used to embed geometryless graphs into n-dimensions or to untangle random embeddings into a form that is informed by their topology. Every node is moved to a position that matches their distance from every other node, in the graph theoretic sense.
APPENDIX 1: primitives
The geometric primitives used in the processing are mostly points, lines and NURBS curves.
data:image/s3,"s3://crabby-images/756f5/756f58badbc2045129a1220b38c3cec6ef311284" alt=""
Points are defined by n number of coordinates, most often with 3.
A line is a directed pair of points.
data:image/s3,"s3://crabby-images/7bf74/7bf74b0d9baf79d8366ecbd871ec235964e21c9b" alt=""
Non-rational cubic beziers (i.e. curves with exactly 4 unweighted control points), can be used directly when rendering data into SVG, so they are treated as a special case.
Other types of beziers are given as lists of (weighted or unweighted) control points and converted into short line segments for rendering.
data:image/s3,"s3://crabby-images/5b778/5b7783b9bf0e99de548fb616a20e1550fde0e38f" alt=""
NURBS (Non-Uniform Rational Basis Spline) curves are defined with control points, a knot vector and a degree.
data:image/s3,"s3://crabby-images/2962f/2962f3337c35e50867f98cdbb65257b698cccf5e" alt=""
Curve's degree determines how many control points influence the curvature at a given point.
data:image/s3,"s3://crabby-images/eb1c4/eb1c43c72bcb933bee2dfec6836532906884032d" alt=""
Control point's weight can be used to alter the "pull" towards it.
data:image/s3,"s3://crabby-images/f5bac/f5baca295e728a8d3feee307a29eb914074e8adf" alt=""
Knot vector can be used to shift the relative influence of control points.
data:image/s3,"s3://crabby-images/d6ec1/d6ec15f01cf8ae3edd532ffca705a842112a5426" alt=""
The same control points can be used to construct either clamped, open or closed curves.
data:image/s3,"s3://crabby-images/e15c2/e15c27f4feef619c92203a72169de850ee51cb0b" alt=""
Circles can be used as exact constructs in calculations and rendered as approximations.
left: degree 3 NURBS, center: degree 2 NURBS (with (√ 2 / 2) corner weights), right: piecewise bezier circle.
data:image/s3,"s3://crabby-images/a6bab/a6babde616db7ef5cb76e3d2a6f5194931777a20" alt=""
Ellipses behave mostly the same way as circles. Left: 8 control point degree 3 NURBS, right: piecewise beziers ellipse.
data:image/s3,"s3://crabby-images/ec484/ec484f19b72e4ba069c3b1b0ba7acd4e192fb566" alt=""
Spheres are mostly used in constraint solving calculations, but can be also visualised in different ways if needed.
data:image/s3,"s3://crabby-images/051a0/051a0848f59e6eeef2f5ed9996d7014c482ea9c0" alt=""
Paths are mixed lists of lines, beziers and NURBS curves. Compound paths have multiple sub-paths. In the case of a closed compound path, there is one clockwise outer boundary and one or more counterclockwise hole boundaries.
data:image/s3,"s3://crabby-images/8393e/8393edb2823fb7dd818187cb0d8bb6843fd60c74" alt=""
Rounded paths are defined by corner points, accompanied by corresponding corner radius values.
Arcs are drawn from a given center point and 2 ending points.
data:image/s3,"s3://crabby-images/0303b/0303b6214c4ab4de5530e243187e0dc4c6860d28" alt=""
data:image/s3,"s3://crabby-images/75a29/75a292daa3b7fcb97b167ef1ef4ca8ca04635af2" alt=""
Surfaces can be represented as NURBS surfaces of any degree or as Coons patches.
If at least one of the NURBS surface's degrees is 1, the surfaces is a ruled surface.
Coons patches interpolate a given set of either three or four curves.
query
data:image/s3,"s3://crabby-images/48e5e/48e5e11c738c89dbeb12dfbc1c1d76a7fe69e12f" alt=""
A point at a given t value of a bezier, i.e. between its start and end points, can be derived with De Castejau's algorithm.
data:image/s3,"s3://crabby-images/b9a9c/b9a9c8cfc3462aa9f7e127d23c61d5bc02c39ce1" alt=""
A point at knot u value of a NURBS can be derived with De Boor's algorithm.
data:image/s3,"s3://crabby-images/5d4d3/5d4d317eecc9995b1b75b6a23cccea702f73ec01" alt=""
Curve length is calculated by segmenting it first into short lines and adding the lines' individual lengths together.
Curve's relative curvature can be calculated from an osculating circle's radius at a given point.
data:image/s3,"s3://crabby-images/50bf1/50bf1c028c8880a33fcc32fb0c6b371e2fce65e0" alt=""
Binary search can be used to find a position on a curve that fulfils some requirement, e.g. the closest position to a given point, the position where tangent of the curve matches a given direction etc.
data:image/s3,"s3://crabby-images/1c818/1c818fec5328d78fc99346834d9e904f328d019a" alt=""
Curve interpolation through a given list of points can be created by solving a linear system of coefficients created from the points.
APPENDIX 2: affine transformations
Affine transformations are parallelism preserving geometric transformations, given in a matrix form. Lists of affines can be merged with matrix multiplication before the are all applied at once.
data:image/s3,"s3://crabby-images/e6c65/e6c65dc71b7c3de1317eec79771f7d87822aaf31" alt=""
Translation moves an object into a new position. Translation values are given separately for every axis (x, y, z).
Rotation is also calculated separately for each axis (x, y, z) and then combined into a single matrix.
data:image/s3,"s3://crabby-images/04e03/04e03fb500f558bf4eae04b173c0c3641c7e3f3a" alt=""
Scaling can be done uniformly, or with separate value for every axis.
Mirroring needs a mirror plane as an additional input.
data:image/s3,"s3://crabby-images/fbff6/fbff6ea9c62a2a1538efb94f3586a9b413f3c18f" alt=""
Rotation matrix that matches A vector's direction to B vector's direction.
APPENDIX 3: Curve transformations
data:image/s3,"s3://crabby-images/180b2/180b25f562921c533fa5e4cafaa886dd05fe0dbf" alt=""
Inserting a knot retains curve geometry.
data:image/s3,"s3://crabby-images/fce27/fce2714193658887ed6423408b1f7c25c64ce0b3" alt=""
Take a NURBS segment between t0 and t1.
data:image/s3,"s3://crabby-images/98924/9892412f7d6198e034169b250ef00a8eed218c00" alt=""
NURBS degree elevation happens by first subdividing it into beziers, elevating their degrees and then merging them back into a single NURBS.
data:image/s3,"s3://crabby-images/53739/5373980f58dcb71e4f07b3303342fd3e17ab2328" alt=""
Naive NURBS offset is done by by moving controls points of each knot span separately in a 90° angle. Not 100% accurate, but good enough for where it's used at the moment.
data:image/s3,"s3://crabby-images/b2807/b2807b0101f6e9feabf2eb7495084e2a92f7b609" alt=""
Curves can be segmented into lines / points either by using exact mm value (red) or by using fixed t-value step (blue).