Three dimensional (3D) model processing for additive manufacturing and rapid prototyping may use a Non Uniform Rational B-Spline (NURBS) model. A NURBS model may be a mathematical model used in computer graphics to generate and represent curves and surfaces of a computer generated object. For instance, NURBS models may be used in computer aided design, computer aided manufacturing, or other 3D modeling and animation programs. Surfaces of NURBS models may typically be functions of two parameters mapping to a surface in 3D space. The shapes of the surfaces may directly be determined by the positioning of the control points of the surfaces and weights and this relation may be described parametrically through the use of rational functions. This kind of modeling may represent various types of geometrical shapes from simple geometrical shapes, such as triangles and quadrics all the way to high-degree free form surfaces.
Features of the present disclosure are illustrated by way of example and not limited in the following figure(s), in which like numerals indicate like elements, in which:
For simplicity and illustrative purposes, the present disclosure is described by referring mainly to examples. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present disclosure. It will be readily apparent however, that the present disclosure may be practiced without limitation to these specific details. In other instances, some methods and structures have not been described in detail so as not to unnecessarily obscure the present disclosure.
Throughout the present disclosure, the terms “a” and “an” are intended to denote at least one of a particular element. As used herein, the term “includes” means includes but not limited to, the term “including” means including but not limited to. The term “based on” means based at least in part on.
A challenge in three dimensional (3D) printing processes may arise from scenarios in which 3D printing systems are distributed over local and/or global networks and models and printing files are to be shared over these networks. In these scenarios, the sizes of the models and printing files may be a bottleneck on the network. For instance, when converting a 3D model of an object, such as a NURBS model, to a tessellated mesh for slicing and printing using a traditional pipeline, the converted mesh may not be memory-friendly and even a simple object may reach many megabytes in size.
Another issue in mesh generation may be that the generated mesh in a traditional pipeline (traditional flat triangles mesh-based representation) may also be unable to adjust the 3D model outside of the 3D model producer. As a result, the generated mesh may not be able to deal with many processes. For instance, scale changes may not be performed without precision loss or may not improve a NURBS approximation by sampling more points on the slice.
The apparatuses and methods disclosed herein may overcome or reduce the issues discussed above by slicing NURBS models without relying on the tessellation approximation or any other approximation of the surface except for the approximations imposed by a precision of a 3D printing system. In addition, the apparatuses and methods disclosed herein may produce more accurate versions of the NURBS models because approximations of the NURBS models may be based on interpolated curves generated from sampled surface points rather than on approximations of curves using other shapes such as meshes or triangles. Moreover, the versions of the NURBS models generated through implementation of the apparatuses and methods disclosed herein may consume less memory because, instead of storing three coordinates for each flat triangle vertex, for a large number of triangles, the method may store a reduced number of control points and weights.
According to examples, disclosed herein are apparatuses and methods for adaptively determining sample points of a non-uniform rational B-spline (NURBS) model of an object, arranged in layers. Particularly, for a given NURBS model of an object (which is also referenced herein as a NURBS model), a slice height for direct slicing of the NURBS model may be identified. Although the slice height may be any suitable slice height, in some examples, the slice height may be equivalent to the height of a layer of printing material that a 3D printing system may apply during successive printing operations to form an object. By way of example, the slice height may be a height ranging from about 0.1 mm to about 1 mm.
The NURBS model may be sliced to produce slices having the identified slice height along a horizontal direction. The slicing operation may determine a set of curves, in which each of the curves is the intersection between a slicing plane and a surface of the NURBS model object. The slicing plane may be parallel to a printing bay of a 3D printing system and may contain a certain number of sampled points from an intersecting curve. The certain number of sampled points may directly be proportional to a desired precision level, e.g., the maximum distance between consecutive sampled points. As a result, the number of sampled points may affect the quality of an object printed from the sampled points.
Generally speaking, the apparatuses and methods disclosed herein may employ three major phases to directly slice a NURBS model. The three major phases may be identified as an initialization phase, an adaptive subdivision phase, and a slice generation phase. In the initialization phase, a projective version of the NURBS model is generated, which is a regular polynomial B-spline surface in projective space. The projective NURBS model provides properties that are needed to effectively slice NURBS objects, such as the separability or tensorial property of B-Spline Models. For example, the disclosed method may slice the NURBS model in projective space by continuously subdividing the surface of the NURBS model through a curve-based (tensorial) subdivision algorithm. The disclosed method may use the mathematical modeling of the projective 3D model to properly calculate the slices. A first bounding box for the NURBS model may also be identified during the initialization phase.
In the adaptive subdivision phase, the intersections between the surface of the NURBS model and slicing planes may be determined through adaptive subdivision of the NURBS surface recursively into smaller patches. The subdivision may be carried out by a curve-based subdivision algorithm that may be applied to the rows of the control points first, followed by application of the algorithm on the columns of the control points, or alternatively, to the columns of the control points first, followed by the rows. This procedure may produce the control points of the patches that may then be used to compute the bounding boxes of the patches. According to examples, the intersections may be determined in parallel to reduce computation time. In the slice generation phase, from the adaptively subdivided patches whose bounding boxes met a stop criterion, sampled points on the surface of the NURBS model belonging to particular slices may be computed and organized in sequence from which a final parametric curve may be produced. In addition, the final parametric curve may be mapped from projective space to Euclidean space or, alternatively, the sampled points may be individually mapped into the Euclidean space and then the final parametric curve may be inferred.
By way of particular example, the apparatuses and methods disclosed herein may apply an adaptive subdivision of NURBS model surfaces consecutively until their computed bounding boxes meet a precision criterion. That is, bounding boxes of continually smaller sizes for the NURBS model surfaces may be generated until the bounding boxes meet the precision criterion. The bounding boxes may meet the precision criterion when the bounding boxes (which contain a portion of the NURBS model surface) intersect at least one plane and have sufficiently small dimensions that meet predefined dimensions. For the bounding boxes that meet the precision criterion, a point may be sampled. In an example, a centroid of the bounding box may be used to represent a sampled point on the surface of the NURBS model. The disclosed apparatuses and methods may then aggregate the sampled points either as a polygon or as curves to form an accurate version of the NURBS model that a 3D printing system may use to print an object.
In examples, the apparatuses and methods disclosed herein may aggregate the sampled points by connecting the sampled points for one layer (2D shape), which may be printed by 3D printing systems. In other examples, the apparatuses and methods disclosed herein may use the sampled points to infer a parametric curve with control points that may be used to draw the curves belonging to the surface of the NURBS model. Processing of the points and generating the curves may be implemented outside of a 3D printing system, but the 3D printing system may interpret the curves.
Through implementation of the apparatuses and methods disclosed herein, NURBS models may directly be sliced within a parametric 3D printing pipeline. As a result, the NURBS models may directly be sliced while achieving at least as good as or improved precision on traditional 3D printing pipelines regardless of the NURBS model geometry and topology, reducing model and 3D printing file sizes in disk/network for the general case of objects containing at least one curved surface, maintaining parametric information natively throughout the printing pipeline, maintaining precision regardless of object scale, making NURBS slicing process feasible and scalable (covering all curves randomness/complexity present in any ordinary part) in a software implementation stand point, or the like.
The apparatus 100 may be a computing device, a tablet computer, a server computer, a smartphone, or the like, and may include a processor 104, which may be a semiconductor-based microprocessor, a central processing unit (CPU), an application specific integrated circuit (ASIC), a field-programmable gate array (FPGA), and/or another hardware device. Although a single processor 104 is depicted, it should be understood that the apparatus 100 may include multiple processors, multiple cores, or the like, without departing from a scope of the apparatus 100.
The apparatus 100 may also include a non-transitory computer readable medium 110 that may have stored thereon machine-readable instructions 112-120 executable by the processor 104. Examples of the non-transitory computer readable medium 110 may include an electronic, magnetic, optical, or other physical storage device that contains or stores executable instructions. For example, the non-transitory computer readable medium 110 may be a Random Access memory (RAM), an Electrically Erasable Programmable Read-Only Memory (EEPROM), a hard disk, an optical disc, or other type of storage device.
The processor 104 may fetch, decode, and execute the machine-readable instructions 112 to identify a slice height for direct slicing of a Non-Uniform Rational B-Spline (NURBS) model formed of surfaces by slicing planes of any given orientation. According to examples, the slice height may be equivalent to the thickness of a layer of a printing material to be used by a 3D printing system in printing the NURBS model. That is, the slice height may be equivalent to a height of each of the layers of printing material that a 3D printing system applies during an object printing operation. In other examples, the slice height may be a user-defined height, a height corresponding to another feature, or the like.
The processor 104 may fetch, decode, and execute the machine-readable instructions 114 to slice the NURBS model to produce slices, in which each of the slices has the identified slice height. In examples, some or all of the slicing planes used to intersect with the NURBS model may lie between respective pairs of the produced slices. Equivalently, some or all of the slices of the NURBS model may lie between respective pairs of the slicing planes.
The processor 104 may fetch, decode, and execute the machine-readable instructions 116 to adaptively subdivide the surfaces of the NURBS model (which may be based on an algorithm that works on the control points of the surfaces of the NURBS model) that intersect at least one of the slicing planes and meets a predefined criterion. In addition, a corresponding bounding box may be generated at each time that the surfaces are subdivided. A bounding box may be defined as a box canonically oriented that minimally bounds the control points of at least a portion of the NURBS model, e.g., a portion of a surface of the NURBS model. In this regard, a larger bounding box may contain a larger portion of the surface. As discussed herein, smaller and smaller bounding boxes may be generated through adaptively subdividing the NURBS model surface's control points until the respective bounding box meets the predefined criterion. Particularly, larger surfaces may be split into patches, and each of the patches may further be split into sub-patches and so forth until the bounding boxes built from the control points of the patches that intersect at least one of the slicing planes, meet the predefined stop criterion.
In examples, the predefined criterion may pertain to a predefined size, such that the bounding box may be determined to meet the predefined size when a largest dimension of the bounding box meets the predefined size. For instance, the predefined size may be equivalent to the slice height. As other examples, the predefined size may be smaller than the slice height, may correspond to another user-defined size, may correspond to a 3D printing system printing property, a printing material to be used to fabricate the NURBS model, or the like.
The processor 104 may fetch, decode, and execute the machine-readable instructions 118 to, for each of the generated bounding boxes that respectively intersect at least one of the slicing planes and meet a predefined stop criterion, determine a sample point of the surface inside the bounding box. Any arbitrarily chosen point inside the bounding box may correspond to a single point on the surface of the NURBS model. That is, for instance, as the predefined criterion may be a relatively small value, a bounding box that meets the predefined criterion may also be relatively small. In this regard, any point in the interior of the bounding box that meets the predefined criterion may be considered a point on the surface of the NURBS model, up to that predefined criterion. In particular, the centroid of the bounding box may be construed as corresponding to the sampled point of the NURBS model surface.
By tracking the relative locations of the bounding boxes that met the stop criterion with respect to each other and/or another reference position, the shapes of the slicing curves of the NURBS model may be identified. The processor 104 may fetch, decode, and execute the machine-readable instructions 120 to store the determined sample points ordered in such a way that the interconnection of the sample points may provide the correct shape of the slicing curve. The so determined sample points may correspond to a slice of the NURBS model and may be used for printing the NURBS model.
According to examples, the processor 104, which may include multiple processors and/or multiple cores, may adaptively subdivide and generate multiple control points of the patches and their bounding boxes in parallel. In addition, the processor 104 may track the bounding boxes to ensure that the bounding boxes are not processed more than once. As such, for instance, the processor 104 may perform the adaptive subdivision and generation of the control points of the patches and the bounding boxes corresponding to the patches in a relatively quick and efficient manner.
Turning now to
With reference first to
In the three-dimensional projective space, with the representation of the NURBS model through homogeneous coordinates, a control point with negative weight may simply be a point underneath the hyperplane w=0, the so called “plane at infinity”. If some control points are above this plane while others are underneath this plane, the resulting surface may intersect this plane at infinity and may produce discontinuities when the surface is projected back into Euclidean space. However, discontinuity may not occur provided the NURBS model is kept in projective space. In addition, a B-splines surface in any space may be separable, which may not be the case of NURBS models in the 3D-Euclidean space (rational form). That means that any algorithm designed to work with curves may work with surfaces in a tensorial fashion. According to examples, the methods disclosed herein may operate entirely in projective space and may convert back to the Euclidean space when the sampled points are ready to be output.
The representation through homogeneous coordinates may be implemented through the addition of a fourth coordinate to each 3D control point and by multiplying all of the first three coordinates of the 3D control point by an associated weight of the 3D control point, and considering the weight itself as the fourth coordinate of the 3D control point. In other words, if:
in homogeneous coordinates, the
where w is the weight of the 3D control point.
At block 204, the processor 104 may identify slicing planes to be intersected with the NURBS model.
At block 206, the processor 104 may adaptively subdivide the surfaces of the NURBS model into patches and may generate control points for the patches. The processor 104 may also generate bounding boxes for the respective patches that respectively intersect at least one of the slicing planes. A more detailed description of a manner in which the processor 104 may adaptively subdivide and generate the patches' control points and their bounding boxes is discussed herein below with respect to
At block 208, the processor 104 may, for each of the produced bounding boxes that respectively intersects at least one of the slicing planes and meets the predefined criterion (herein called the final bounding box), determine a sample point of the patch with which the bounding box corresponds. As discussed herein, each of the bounding boxes may include a portion (e.g., a patch) of a surface of the NURBS model 400. The sample point of the surface may be the centroid of a final bounding box or may be another point within the final bounding box as discussed herein.
At block 210, the processor 104 may output the determined sample points of the surfaces of the NURBS model. The determined sample points may correspond to a set of surface points on the surface of the NURBS model sampled on horizontal planes that divide the layers that represent the print material deposition. In addition, the processor 104 or another processing component may process the sample points to interpolate or otherwise identify polygons or curves of the surface of the NURBS model, in which the polygons or curves may be used to print an object from the NURBS model as discussed below. In some examples, the processor 104 may output the determined sample points to another computing device, a 3D printer, a data store, or the like.
Each of the sample points may be defined by a pair of parameter values that accompany the respective sample point. For instance, each of the determined sample points may include six floating point numbers: a pair of parameter values (ui, vi) and four coordinate values (xi, yi, zi, wi) corresponding to the sample points in the 3D projective space. A pair of parameter values may constitute a form of identifying each point on the surface of the NURBS model. One real value may be sufficient to identify each of the points of a curve, which is a 1D object. A surface is a 2D object and a sample point of the surface may be identified by two independent values. The processor 104 may project the acquired surface points into the Euclidean space by dividing each coordinate (xi, yi, zi, wi) by the fourth coordinate (wi), thereby transforming the point onto the Euclidean Space defined as (xi/wi, yi/wi, zi/wi). The processor 104 may use a tree structure induced by a depth search for sorting of the points in each plane. The processor 104 may use the points to produce an interpolating curve representing the intersection between the surface of the NURBS model and the slicing plane. Solving the intersections in this manner may optimize memory usage.
The processor 104 may perform a traversal in a depth search to enumerate each tree leaf as the tree leaf is visited to produce a sorted sequence of surface points throughout the set of planes intersecting the NURBS model. For any given slicing plane, there may be a set of subsequences of numbers indexing adjacent points that may be sorted and concatenated. The geometric coherence held by subsequent points may be guaranteed by their common ancestry in the traversal. In one regard, guaranteeing the common ancestry of the subsequent points may solve ambiguities in the sorting and concatenation of the sample points when separate parts of the intersecting curve approach each other to near self-intersection, up to a precision threshold. Therefore, surface points may be aggregated in the same slicing plane through sorting and concatenation of subsequences of indices. The ambiguities may be resolved by considering their common ancestry in the tree structure. In addition, parametric curves that interpolate the points may be built. The guaranteed precision may be sufficient to produce parametric curves that preserve the NURBS model's features up to a predefined precision threshold.
The parametric curves may also be rational splines and the degree of each projective polynomial curve segment may be the addition of the degrees of the projective subdivided patch in each direction. The interpolating process may use the curve parameter values associated to the sampled points in order to find the control points and their weights by solving the appropriate linear system. The information identifying the end points of each curve segment may be stored. As there may be no direct relation between the degree of the intersecting curve and the slicing phase, the number of sample points may or may not be much greater than the degree of the curve. The linear system may be used to find the control points of the interpolating rational curve having 3*(n−1) degrees of freedom, where n is the degree of the interpolating curve. Considering that the end points of each curve may represent the control points, the end points may have weight 1.0. The curve is rational but planar. As a result, a minimum of n−1+(n−1)/2 points may be used to solve the linear system. The minimum number of point may be used as an additional stop criteria (e.g., predefined criterion) if the slices produce interpolating rational Bezier curves. In an example, an approximating rational Bezier curve may be determined according to the least squares criterion. In this case, there may be no additional constraints on the minimum number of surface points produced per curve segment.
Reference is now made to
At block 302, the processor 104 may identify a first bounding box 406 that encompasses the surfaces of the NURBS model 400. The dimensions of the first bounding box 406 may be selected based on the control points of the NURBS model. In other words, the first bounding box 406 may have each of its dimensions to be large enough to minimally encompass the NURBS model.
At block 304, the processor 104 may subdivide the surface of the NURBS model 400 inside the first bounding box 406 into a plurality of patches 408-414. For example, the processor 104 may use the extended De Boor's sub-division algorithm that subdivides the first bounding box 406 into four patches 408-414. In other examples, the processor 104 may use another sub-division algorithm to subdivide the first bounding box 406 into two or more patches. In any regard, the processor 104 may store the patches 408-414 in a list, e.g., a list that identifies the patches 408-414.
According to an example, the processor 104 may apply de Boor's Knot Insertion Algorithm for B-spline curves extended to subdivide the surfaces. In this example, de Boor's Knot Insertion Algorithm for B-spline curves is extended to work with surfaces with G. Farin's notation (Farin, G., Curves and Surfaces for Computer Aided Geometric Design: A Practical Guide—4th Edition—Academic Press, 1997) on page 148, generalized for NURBS surfaces through the use of its tensorial property, which may only be valid in projective space). In this example, a NURBS surface has degrees n and m, parametrized by (u, v) with knot sequences: u0, u1, . . . , uL+2n−2 and v0, u1, . . . , vP+2m−2, where L and P determine the amount of domain intervals in u and V directions, respectively (up to the amount of multiplicities of the knots). In addition, di,j0,0=(xi,j, yi,j, zi,j) are the control points and wi,j are their weights, with iϵ{0, 1, 2, . . . , L+n−1} and jϵ{0, 1, 2, . . . , P+m−1}. These points, seen in IP3 (projective space), may be written in homogeneous coordinates as follows: {tilde over (d)}i,j0,0=(xi,j·wi,j, yi,j·wi,j, zi,j·wi,j, wi,j), for iϵ{0, 1, 2, . . . , L+n−1} and jϵ{0, 1, 2, . . . , P+m−1}.
The adaptive subdivision includes a sequence of knot insertions, producing new B-spline control points that form four sub-meshes, and each sub-mesh may be tested for intersection against the slicing plane. In the affirmative case, the sub-mesh may be subdivided and the previous phase may be repeated until a desired precision level is met. In the first subdivision the knot to be inserted is (u*, u*)=½(un−1+uL+n−1), ½(vn−1+vP+m−1)) Suppose the domain in which the knot (u*, v*) lies is [ul, ul+1]×[vj, vj+1], where lϵ{n−1, . . . , L+n−1} and Jϵ{m−1, . . . , P+m−1}. The control points produced by these insertions are computed in a tensor form:
In the left patch, we get:
In the right patch, we get:
Notice that the four patches share a control point with which the control mesh clamps on the surface: A{tilde over (d)}l+1,J+10,0=B{tilde over (d)}i+1,00,0=C{tilde over (d)}0,J+10,0=D{tilde over (d)}0,00,0={tilde over (d)}l+1,J+1n,m. Whenever the parameter space of a patch becomes a subset of a domain interval, the surface becomes a Rational Bezier (tensorial). Each patch can be seen as a different surface, with its own parameterizing rectangles, knot sequences and index bounds. Therefore a subdivision just like the one described above can be applied to them recursively.
At block 306, the processor 104 may build a next bounding box 416 (
At block 314, the processor 104 may select one of the sub-patches 418 that includes a portion of the NURBS model 400 surface. In addition, the processor 104 may build a next bounding box 434 (
In addition, at block 316, the processor 104 may determine a sampled point 442 of the bounding box 440. The sampled point 442 may correspond to an intersection of a surface of the NURBS model 400 and a slicing plane 402. In addition, the sampled point 442 may correspond to a centroid of the bounding box 440. At block 318, the processor 104 may store the sampled point 442 in a memory or data store (not shown). The processor 104 may also remove the patch (or sub-patch) from which the sampled point was determined and stored from the list of patches. The processor 104 may also remove patches or sub-patches that do not contain a portion of the NURBS model 400 surface from further processing.
With reference back to the determination at block 308 that a next bounding box does not intersect a slicing plane 402 (e.g., does not contain a portion of the NURBS model 400) or after block 318, the processor 104 may determine whether there is an additional patch in the list of patches to be processed as indicated at block 320. As discussed above, when the processor 104 subdivided the first surface into the patches 408-414, the processor 104 may have stored the patches 408-414 in a list. In addition, during a first iteration of block 306, the processor 104 may have built a bounding box for one of the patches 408 in the list. As such, based on a determination that an additional patch 410 in the list has yet to be processed, e.g., there is an additional patch in the list, the processor 104 may move to the next patch in the list as indicated at block 322. That is, the processor 104 may select a next patch in the list to process. In this regard, the processor 104 may implement blocks 306-322 on the next patch 410 until another sample point is determined at block 316 and stored at block 318. Additionally, at block 320, based on a determination that all of the patches in the list have been processed, e.g., that there are no additional patches in the list, the processor 104 may end the method 300 as indicated at block 324. The end of the method 300 may be the end of block 208 in the method 200.
Through implementation of the methods 200 and 300, the processor 104 may determine and store sample points corresponding to the surface of the NURBS model 400. In addition, as discussed above, the processor 104 or another processing device may interpolate the curves of the surface from the sample points, for instance, when the NURBS model is to be printed. According to examples, the determined sample points may require relatively less data than the NURBS model and thus, the determined sample points may be copied and/or manipulated relatively more easily than data corresponding to the NURBS model itself.
Some or all of the operations set forth in the methods 200 and 300 may be contained as utilities, programs, or subprograms, in any desired computer accessible medium. In addition, the methods 200 and 300 may be embodied by computer programs, which may exist in a variety of forms. For example, the methods 200 and 300 may exist as machine readable instructions, including source code, object code, executable code or other formats. Any of the above may be embodied on a non-transitory computer readable storage medium.
Examples of non-transitory computer readable storage media include computer system RAM, ROM, EPROM, EEPROM, and magnetic or optical disks or tapes. It is therefore to be understood that any electronic device capable of executing the above-described functions may perform those functions enumerated above.
Reference is now made to
Although described specifically throughout the entirety of the instant disclosure, representative examples of the present disclosure have utility over a wide range of applications, and the above discussion is not intended and should not be construed to be limiting, but is offered as an illustrative discussion of aspects of the disclosure.
What has been described and illustrated herein is an example of the disclosure along with some of its variations. The terms, descriptions and figures used herein are set forth by way of illustration only and are not meant as limitations. Many variations are possible within the spirit and scope of the disclosure, which is intended to be defined by the following claims—and their equivalents—in which all terms are meant in their broadest reasonable sense unless otherwise indicated.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2018/016263 | 1/31/2018 | WO | 00 |