Systems for parametric modeling of three dimensional objects

Information

  • Patent Grant
  • 9786096
  • Patent Number
    9,786,096
  • Date Filed
    Wednesday, March 13, 2013
    11 years ago
  • Date Issued
    Tuesday, October 10, 2017
    6 years ago
Abstract
A system for parametric modeling of a three-dimensional object has a processor running a software program operable to configure the object by defining a zone comprising a root of a tree hierarchy, the zone having a three-dimensional region defining an outer dimension of the object to be modeled; a part comprising a child of the zone, the part also having a component object to be modeled, wherein the component object is an element of the object; and a variable comprising a child of the part, wherein variable has data defining characteristics of the zone or part. A user interface can display a representation of the three-dimensional object.
Description
TECHNICAL FIELD

Embodiments of the present invention relate generally to parametric three-dimensional object modeling and more particularly to computer implemented methods and systems for creating parametric three-dimensional design and model data that can be used in various design application environments.


BACKGROUND

In the field of computer aided design, three dimensional parametric modeling is used to design a variety of objects, predominantly mechanical parts, but also building products, furniture, animation characters and other objects that can have multiple variations of a model. Applying this method to define parametric behaviors of three dimensional objects, it is possible to develop generalized parametric data models that can be used to generate 3D objects within various three dimensional design application environments.


One potential benefit of parametric modeling is the ability to encapsulate all variations of an object without explicitly enumerating each instance. For example, a model of a simple passage door consisting of just nine parts can have several billion enumerations, all of which can be encapsulated within a single parametric model.


While parametric modeling has obvious benefits, commercially available parametric modeling systems require extensive training, even for expert users. These systems use tool sets that are often difficult to learn for less technical users such as architects, designers and students. These systems can export static geometry that is accessible to a wider user base, but the parametric model intelligence is often lost on export.


Companies invest significant resources in creating their parametric engineering models, and are rightfully concerned about disseminating this valuable information. Proprietary product configurators are increasingly used to present parametric models to end users in a user-friendly way that also protects the company's data. This often forces end users to learn a multitude of configuration systems with limited usefulness in their work flow.


SUMMARY

In one embodiment, a system for parametric modeling of a three-dimensional object may comprise a processor running a software program that is configured to define a zone comprising a root of a tree hierarchy. The zone can comprise a three-dimensional region defining an outer dimension of the three-dimensional object to be modeled. The software program may also define a part comprising a child of the zone. The part may further comprise a component object to be modeled, wherein the component object is an element of the three-dimensional object. Further, the software program may define a variable comprising a child of the part. The variable may further comprise data defining characteristics of the zone or the part. The software program may also define a user interface operable by the software program for displaying a representation of the three-dimensional object.


In another embodiment, a computer-implemented method for modeling a three-dimensional product may comprise defining a zone, in at least one storage device accessible to the computer processor, as a root of a tree hierarchy, wherein the zone comprises a three-dimensional space establishing the boundaries of the product. The method may further comprise defining a part, in at least one storage device accessible to the computer processor, as a child of the zone, the part defining a three-dimensional element of the product. The method may further comprise defining a variable, in at least one storage device accessible to the computer processor, as a nested child of the product or the part, the variable comprising data relating to the product or the part. And the method may also comprise modeling, on a display associated with the computer, the three-dimensional product based on the defined zone, part, and variable.


In yet another embodiment, a computer-implemented method for modeling a three-dimensional object may comprise receiving first input data representing an outer dimension of the three-dimensional object. The method may further comprise receiving second input data representing a component of the three-dimensional object. Additionally, the method may comprise receiving third input data representing variables of the component or the three-dimensional object, wherein a change to the third input data is reflected by a corresponding change to a dimension of the component or the three-dimensional object. Also, the method may further comprise rendering an image of the three-dimensional object on a graphical user interface.


In yet another embodiment, a system for representing a three-dimensional object may comprise a computer processor for processing parameters of the three-dimensional object. The system may further comprise a first element representing in at least one storage medium accessible to the computer processor a region that contains the three-dimensional object. The system further may comprise a second element in the at least one storage medium accessible to the computer processor representing a dimensions of a component of the three-dimensional object. The system may yet comprise a third element in the at least one storage medium accessible to the computer processor representing a first variable associated with the region and a second variable associated with the component. Additionally, the system may comprise a graphical user interface in communication with the computer processor for displaying a representation of the three-dimensional object based on the first, second, and third elements retrieved by the computer processor.


In another embodiment, a computer program product comprises a computer usable medium having computer readable program code embodied therein for modeling a three-dimensional object. The computer readable program code means in the computer program product has computer readable program code for defining a zone as a root of a tree hierarchy, the zone comprising a three-dimensional space establishing the boundaries of the object; computer readable program code for defining a part as a child of the zone, the part defining a three-dimensional element of the object; computer readable program code for defining a variable as a nested child of the object or the part, the variable comprising data relating to the object or the part; and computer readable program code for causing a computer to draw a three-dimensional object based on the defined zone, part, and variable.





BRIEF DESCRIPTION OF THE DRAWINGS


FIGS. 1A-1B illustrate differences between a parametric product and a non-parametric product, to set the stage for more detailed discussions.



FIGS. 2A-2C show a code-level definition of a parametric product, using methods according to embodiments of the present invention, and showing how the same product can be represented in several different formats.



FIG. 3 shows another parametric product, with a tree hierarchy of all of the elements that comprise it, to show a nested relationship between the top level elements, according to embodiments of the present invention.



FIG. 4A-B illustrates how the “include” element functions with an example of using an Include to add a part to an existing product via a World Wide Web connection, according to embodiments of the present invention.



FIG. 4C illustrates the use of dot notation and some example of variable formulas, according to embodiments of the present invention.



FIGS. 5-12 show examples of building parametric products according to embodiments of the present invention.



FIG. 13 is an example of a computer system, with which embodiments of the present invention may be utilized.





While the invention is amenable to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and are described in detail below. The intention, however, is not to limit the invention to the particular embodiments described. On the contrary, the invention is intended to cover all modifications, equivalents, and alternatives falling within the scope of the invention and the present disclosure.


DETAILED DESCRIPTION

Embodiments of the present invention include improved ways to generate and publish useful parametric product design and engineering information for use in a variety of industries, including but not limited to the construction industry. These and other needs are addressed by embodiments of the present invention by providing a lightweight, powerful and accurate method for presenting parametric products in an easy to use 3D format.


Parametric products are collections of typically 3-dimensional entities that contain embedded rules describing how they behave when the product itself is changed. Almost any object in the physical world could be represented as a parametric product. As the “parameters” of the model are altered, the individual parts that make up that model react as instructed by their embedded rules.


One example of a parametric product is a fence that automatically adds vertical slats as the overall fence is made longer. As the “length” parameter is increased, the vertical slats inside the product react appropriately. The resulting 3D model can then be used to generate pricing, output cutting lists, and to create CNC manufacturing programs for that object. FIG. 1A-1B illustrate this simple example, showing how a parametric product performs more intelligently than its non-parametric equivalent.


Another example is a kitchen cabinet that can be built with glued dowels, rabbets, or nails. If doweled construction is selected, then the parts inside the cabinet change themselves to include the appropriate drilled holes where the dowels are inserted. Instead of maintaining dozens or even hundreds of product drawings to represent these variations, the manufacturer can maintain a single parametric drawing that encapsulates all possible iterations.


Embodiments of the present invention include systems and methods for efficiently defining such parametric models across a wide range of fields, using a library of elements and variables with standardized meanings. Embodiments of the present invention are easy and flexible to use, particularly when compared with existing parametric technologies that are often extremely complicated, difficult to implement, and often focused on a particular field (i.e. metalworking, home construction, etc.)


Once a parametric product is defined using embodiments of the present invention, it becomes usable by a wide variety of persons and computer systems. It can be shared from product designer to consumer and on to the manufacturer. It can be imported into software tools to perform processing including, but not limited to, rendering the product in 3D, calculating material needs for manufacturing, purchasing the configured product over the web, generating sales orders, etc.


Data Format Independence

XML (eXtensible Markup Language) is one data exchange format that can be used, according to embodiments of the present invention, to describe a parametric product. XML is an industry-wide standard for moving data between computer systems. Although XML illustrates concepts and features of the present invention, one of ordinary skill in the art, based on this disclosure, will recognize that other existing or future languages and/or data exchange formats may be used according to embodiments of the present invention.


Many other languages besides XML can also be used. These include, but are not limited to: JSON object notation, a relational database of tables, object definitions in Ruby, C programming language STRUCTS, etc. Any data format that can accurately store the hierarchy of elements defined is usable. Embodiments of the present invention are “format neutral.”



FIG. 2A-2C illustrates the same parametric product defined using embodiments of the present invention. Each figure shows a shelf unit made up of 3 parts, as represented in a different format. FIG. 2A shows how the product is described in XML, FIG. 2B is in JSON, and FIG. 2C is a 3D drawing as rendered by a CAD system. It is important to note how the same information is contained in all three formats.


Also, it is important to note that embodiments of the present invention enable a great variety of software tools to consume and/or create parametric products. Though these examples show the creation of parametric products using “hand-coding” of interfaces that expose raw XML, the typical end user will interact with “drag and drop” software tools that require little or no code-level knowledge, according to embodiments of the present invention.


The Six Elements

Some embodiments of the present invention include six elements that describe a parametric product. These elements relate to one another in a tree hierarchy. The root of the tree is always an element known as a zone. Beneath the root zone there can be any number of other nested elements, forming branches and leaves. FIG. 3 shows an exemplary tree of top level elements, as viewed inside a CAD tool, with a root zone containing several child zones, child parts, and child variables.



FIG. 2A shows an XML representation of a shelving unit product, containing a root zone element (represented by the opening ZONE tag at the beginning of the text) and two child parts, as well as a number of child variable (i.e., VAR) elements inside both the zone and the parts.


As is standard with XML, child elements in the tree are represented as nested XML tags. As FIG. 2A demonstrates, the name of the XML tag corresponds with the type of element it represents.


Following is a description of the six element types:


Zone Element

A zone is an imaginary 3-dimensional box. Functionally, it is an invisible region inside the product that contains parts. It has a particular size, location, and rotation in space. (These are defined by a series of child variables with particular names. See VARIABLE below.)


Every parametric product contains at least one zone (the bounding box that contains the entire product, which is also the root of the tree hierarchy.)


For example, if one were defining a parametric stool that was 36 inches tall and 18 inches in diameter, there would be an imaginary, 6-sided zone 36 inches tall, 18 inches wide, and 18 inches deep, forming a perfect wrapper around the entire product. This would be its root zone.


Complex products might include several zones. Each zone in a product is given a name. This name provides a way of referring to that zone when writing variable formulas. (See Variable Formulas below.)


The following is an example of how a zone is defined in XML:

















<zone name=“MyZone”>



... child elements appear here...



</zone>










Zones can be nested, meaning any zone can contain other zones. In such a case, the containing zone is known as the “parent” and the others are known as “children.”


Part Element

A part is a 3-dimensional object inside the product, such as a board, a plastic panel, a screw, a hinge, etc. Anything that one would think of as a “part” of the product in the real world will have a corresponding part in the parametric representation of it. Most products contain many parts. Parts have a particular size and location in space, as well as a shape, color, material, rotation, behavior, etc. (These are defined by a series of child variables with particular names. See VARIABLE below.)


Each part in a product is given a name. This name provides a way of referring to that part when writing variable formulas. (See Variable Formulas below.) The following is an example of how a part is defined in XML:

















<part name=“MyPart”>



... child elements appear here...



</part>










Each part is contained inside a zone. The zone is known as the “parent” and the part is known as the “child.” A zone can contain any number of child parts.


Variable (aka VAR) Element

Variables (also known by the shorthand “var”) are elements that are nested inside a part or a zone. Functionally they are similar to variables in any computer programming environment, in that they have a name and a value.


Variables are contained inside zones, parts, or arrays (see ARRAY below). The containing element is known as the “parent” and the variable is known as a “child”. Each variable represents one piece of data that defines something about its parent.


A zone or part element can have any number of variables. When authoring a parametric product, one may create as many variables as needed to fully represent its variations and behaviors. Simple parts might have only a handful of variables that define everything about them, while complex parts might contain dozens.


Embodiments of the present invention define a library of variable names that have a particular meaning and usage. These variables are known as “reserved” variables. By convention, the names of reserved variables are often written in all capital letters to help delineate them from non-reserved variables.


The variable “L” for example, is a reserved variable used to define a part's length. If one creates a variable named “L” inside a part and gives it a value of “10”, then that part will assume a length of 10 inches. (All linear measurements according to the examples in this document are defined in inches by default, but any other unit can be used, including but not limited to millimeters, miles, meters, etc.).


In certain embodiments, non-reserved variables can be named almost anything the author desires, with the following restrictions: variable names may contain any combination of letters and numbers, but not spaces or special characters, according to embodiments of the present invention. One could create a variable called “TireSize1” for example, but not one called “Tire Size #1”, because the spaces and pound character are not allowed.


The following is an example of how a variable is defined in XML:

<var name=“MyVariable” value=“10”/>


Variables are case-insensitive. The variable “SHOESIZE” is the same variable as “ShoeSize”. In programming parlance, variables are “loosely typed.” They can contain integers, floating point numbers, or strings.


Option Element

Option elements are children of a variable, according to embodiments of the present invention. They define a set of specific values that the parent variable can be set to when an end user configures a parametric product.


This is a simple and effective way of providing interactivity within a parametric product. The manufacturer could, for example, provide a parametric model with options that show all of the colors that their product is available in. Here is an example of how a list of options may be defined in XML:

















<var name=“ChairSize” value=“20 ”>



   <option name=“Small” value=“16” />



   <option name=“Medium” value=“20” />



   <option name=“Large” value=“24” />



</var>










In this example, a computer aided interior design application would allow a room designer to choose from three sizes of available chair and see a 3D model of it “on the fly” or in substantially “real time.”


Like variables, options have a name and a value. Unlike variables, there are no restrictions on what the name of the option can be. One could create an option named “Sized Medium #6, 24 inches in height, with red trim” without a problem. When an end user selects an option from the list, the value stored inside that option is applied to the value of the parent variable.


Array Element

Arrays are collections of variables that can be contained inside a part or a zone. They are similar to arrays in any computer programming environment. They have one name but can contain multiple values.


Arrays in the present invention can be associative or linear. Associative arrays contain a set of values that are accessed using string names, whereas linear arrays contain a series of values that are accessed via an integer index.


The following is an example of defining an array in XML:

















<array name=“dragChanges”>



   <var value=“TopBoard.x” />



   <var value=“BottomBoard.x” />



</array>










When authoring a parametric product, one may create as many non-reserved arrays as desired. Like variables, array names may contain any combination of letters and numbers, but not spaces or special characters.


Also like variables, there are certain array names that are reserved, meaning that they have a particular meaning in the realm of parametric modeling and thus cannot be used for defining arbitrary data. An exhaustive list of reserved array names is provided below.


Include Element

The include element provides the ability to reuse and share parametric data across multiple parts, products, or even entire product lines.


The include element can be contained anywhere inside the product's hierarchy tree. When it is encountered by a computer system, its “leaf” on the tree is automatically replaced with a leaf (or entire branch) of data that is contained in an external file or data store. Specifically, the data is loaded from a URL (Uniform Resource Locator) address. This URL points to any properly-structured data source on the World Wide Web, a corporate intranet, the computer user's hard drive, etc.



FIGS. 4A-4B illustrates how an include is replaced within a hierarchy tree. By using include elements, one can create extremely flexible product catalogs that exist on the world wide web, allowing manufacturers and designers to host up-to-date versions of their parametric products, use common parts and construction standards across multiple products, and greatly ease the challenge of sharing complex catalogs with other people and computer systems.


Variable Formulas

As has been described, variables have a name and a value. This value can be in the form of a number, such as “10” or a string, such as “Steel Case®”. Variables can also have an attribute called a “formula” that can change the variable's value. Such formulas provide a means to create “intelligent” behaviors inside parametric products, according to embodiments of the present invention.


Formulas are mathematical expressions. They can contain operators including, but not limited to, addition, subtraction, multiplication, division, and boolean comparison to arrive at predictable results based on the product's current state. These operators act upon static values contained in the formula or on dynamic values that are pulled from variables anywhere inside the product's hierarchy tree. Often, the operands in a formula are themselves derived from the results of other formulas elsewhere in the parametric product.


For example, the following snippet of XML defines a variable without a formula:

<var name=“myAge” value=“32”/>


This variable is “static”, meaning its value is set at 32 and will never change. Here is another example, this time using a simple formula:

<var name=“price” formula=“180+12”/>


At run time, this variable's formula will be executed, arriving at the mathematical result of “192” (180+12=192).


One can also refer to other variables within the hierarchy tree to arrive at much more complex interactions. Here are three variables that interact:

















<var name=“leg” value=“48” />



<var name=“stooltop” value=“3” />



<var name=“H” formula=“leg+stooltop” />










Here, the computer system reading the parametric model would calculate the variable “H” as 51 (48+3=51). The variable H is a reserved variable that controls the height of a part or zone. Thus, if the example code above were nested into a zone, it would dynamically change the total height of the zone to 51 inches.


The order of operations in variable formulas follows normal algebra rules. As in algebra, parentheses can be used to force a particular order of operations.


In addition to numeric values, literal string values can be used in a formula by delineating the string with single quote marks. Here is an example of this:

<var name=“SKU” value=“‘POP’+6/2+‘B’”/>


After this formula is executed, the variable name “SKU” will contain a string value of “POP3B”. The “6/2” operation is performed first, then it is concatenated with the string literals;


Referring to variables elsewhere in the hierarchy tree requires use of dot notation. Dot notation is a way to locate something inside a tree using the names of each branch or leaf one is trying to reference. (Dot syntax is common in C, C++, and Java programming environments, among others.)


For example, the following snippet of dot notation refers to the “H” variable's value that is contained inside the FrontLeg element, which is turn is contained in the MyTable zone. Each dot (.) represents one level deeper into the tree.


MyTable.FrontLeg.H

There are a few “shortcuts” provided in the present invention to shorten the formulas. The term “thisPart” refers to the parent part of the current variable. So instead of writing:

    • MyTable.Drawer.DrawerFront.Pull.X


One could use the following shortcut for any variable formula that is contained inside the Pull part:

    • thisPart.X


Another shortcut is “thisZone” which refers to the parent zone of the variable, or in the case of a variable that is nested in a part, to the part's parent zone.


A computer system that reads a parametric product will execute these formulas at run time to determine each variable's current value. As the end user chooses options to configure their product, the various formulas throughout will “fire” or execute in sequence, allowing the product to dramatically alter its construction and appearance in whatever fashion the original author intended.



FIG. 5 shows a product with several formulas in place. FIG. 5 illustrates a screen shot of an exemplary parametric modeling application environment 100 that provides three simultaneous views of the parametric model: a 3D View 101, a Tree View 102 and a Text View 103. The text block contains an exemplary root level element called “TheBox” 104 with width, height and depth variables and a part element called “BottomBoard” 105 with part dimensions expressed as width, length, and thickness variables; part position expressed as x, y and z coordinates, and an orientation expressed as a predefined Cartesian plane, or as one or more rotations around the x, y and/or z axes. When the text block has been entered by the user, it is simultaneously displayed in the 3D View, as shown, the first part 106 is visible in the 3D View and in the Tree View 107.



FIG. 6 illustrates a screen shot showing a new part called “LeftBoard” 108 added in the Text View, and appearing in the 3D View 109 and the Tree View 110. Note that the orientation and x, y, and z coordinates have been changed to position and rotate the part in space. Notice also that all of the numerical data are expressed as values.



FIG. 7 illustrates a screen shot showing a new part called “RightBoard” 111a added in the Text View, and appearing in the 3D View 112 and the Tree View 113. The orientation and x, y, and z coordinates have been changed to position and rotate the part in space. All of the numerical data are expressed as values except for the x position of the RightBoard part, which is expressed as a formula 111b that relates its x position to the length of the adjacent BottomBoard part.



FIG. 8 illustrates a screen shot showing a new part called “TopBoard” 114a added in the Text View, and appearing in the 3D View 115 and the Tree View 116. Again, the orientation and x, y, and z coordinates have been changed to position and rotate the part in space. Notice that the x position of the TopBoard part is expressed as a formula 114b that relates its x position to its own length.



FIG. 9 illustrates a screen shot showing an Operation 117 for “TopHole” 118, using a token (which is an example of an operation type and should be recognized as such when referred to below) called BORE 119 added in the Text View, and appearing in the 3D View 120. The Tree View 121 does not display the added operation, which is by example, but not by limitation. If the user chose to visualize the lower-level elements in the Tree View, such as formulas, operations and the like, the user can do so.



FIG. 10 illustrates the addition of a part variable called “Chord” 122a and an array called “edges” 122b, which consists of a START token 123 followed by a sequence of LINETO 124 and ARCTO 125 statements. The ARCTO block contains the special variables “isConcave” 126 and “isMajorArc” 127. These variables determine which side of the start and end points the arc bulges toward, and whether the arc is major or minor within the included angle of the arc. The 3D View 128 is updated, while once again, the Tree View 129 presents only the high-level elements.



FIG. 11 illustrates the addition of a rectangular cutout called “RightCutout” 130, which has been added to the RightBoard part. The cutout uses the POCKET token 131 which is oriented on the INSIDE face 132 with a depth 133 of 0.75″ 133. The cutout is visible in the 3D View 134 but the RightBoard does not display the lower-level operations 135.



FIG. 12 illustrates the addition of two internal zones shown in Text View 136 and 137 and in 3D View 143 and 144 and in the Tree View 146 and 147. Also a new part called “TheShelf” has been added 138, 145 and 148. Each of the zones makes use of the ParentZone system variable, which enables a zone or part to look up a value from the next higher level zone or part in the tree hierarchy. In this case the size and position of the zones refer to the size and position of the parent zone that contains them. In this manner, changes to the overall size and configuration of the parent can be used to drive the subsidiary zones and parts.


Also shown is a “drag Rule” 139 which changes the size and position of the specified elements when a part is dragged in the 3D View with a mouse pointing device. The “dragAxis” 140 determines the direction along which the part can be dragged. The “dragChanges” 141 array allows the user to specify the zones, parts and dimensions that a drag event will change and the “dragMultipliers” 142 are optionally used to cause a proportional or inverse change in the magnitude of the drag. In the example, the “TopZone.h” has a dragMultiplier of −1, with the result that as the Shelf part is dragged up along the dragAxis, Z, the height of the TopZone will decrease by the distance of the drag, while other dragChanges elements will increase as the Z value of the Shelf increases.


Exemplary Computer System Overview

Embodiments of the present invention include various steps a variety of which may be performed by hardware components or may be embodied in machine-executable instructions, which may be used to cause a general-purpose or special-purpose processor programmed with the instructions to perform the steps. Alternatively, the steps may be performed by a combination of hardware, software, and/or firmware. As such, FIG. 13 is an example of a computer system 1300, with which embodiments of the present invention may be utilized. According to the present example, the computer system includes a bus 1301, at least one processor 1302, at least one communication port 1303, and a main memory 1304. System 1300 may also include a removable storage media 1305, a read only memory 1306, and/or a mass storage component/device 1307.


Processor(s) 1302 can be any known processor, including, but not limited to, an Intel® Itanium® or Itanium 2® processor(s), or AMD® Opteron® or Athlon MP® processor(s), or Motorola® lines of processors. Communication port(s) 1303 can be any of an RS-232 port for use with a modem based dialup connection, a 10/100 Ethernet port, or a Gigabit port using copper or fiber. Communication port(s) 1303 may be chosen depending on a network such a Local Area Network (LAN), Wide Area Network (WAN), or any network to which the computer system 1300 connects.


Main memory 1304 can be Random Access Memory (RAM), or any other dynamic storage device(s) commonly known in the art. Read only memory 1306 can be any static storage device(s) such as Programmable Read Only Memory (PROM) chips for storing static information such as instructions for processor 1302.


Mass storage 1307 can be used to store information and instructions. For example, hard disks such as the Adaptec® family of SCSI drives, an optical disc, an array of disks such as RAID, such as the Adaptec family of RAID drives, or any other mass storage devices may be used.


Bus 1301 communicatively couples processor(s) 1302 with the other memory, storage and communication blocks. Bus 1201 can be a PCI/PCI-X or SCSI based system bus depending on the storage devices used.


Removable storage media 1305 can be any kind of external hard-drives, floppy drives, IOMEGA® Zip Drives, Compact Disc-Read Only Memory (CD-ROM), Compact Disc-Re-Writable (CD-RW), Digital Video Disk-Read Only Memory (DVD-ROM). Display 1308 may be any device operable to present visual representations of parametric models and permit users to view, change, and interact with parametric models according to embodiments of the present invention, including but not limited to graphical web interfaces and computer monitors.


The components described above are meant to exemplify some types of possibilities. In no way should the aforementioned examples limit the scope of the invention, as they are only exemplary embodiments.


Reserved Library

The tables below are an exemplary list of reserved variable names and how they function, according to embodiments of the present invention. By adding these arrays and/or variables to a part or zone, one can create interactive, parametric products of almost any kind imaginable.


Various modifications and additions can be made to the exemplary embodiments discussed without departing from the scope of the present invention. For example, while the embodiments described above refer to particular features, the scope of this invention also includes embodiments having different combinations of features and embodiments that do not include all of the described features. Accordingly, the scope of the present invention is intended to embrace all such alternatives, modifications, and variations as fall within the scope of the present disclosure, together with all equivalents thereof.


Sizing and Positioning















Reserved Name
Element
Contained in
Description







W
VAR
PART or ZONE
These 3 related vars define the width, height, and depth


H
VAR
PART or ZONE
of their parent element.


D
VAR
PART or ZONE
XML Example:





<zone name=“MyZone”>









<var name=“W” value=“24” />



<var name=“H” value=“24” />



<var name=“D” value=“24” />













</zone>


L
VAR
PART or ZONE
These 3 related vars are an alternate to W/H/D for


W
VAR
PART or ZONE
defining the size of a part or zone. They refer to


T
VAR
PART or ZONE
Length, Width, and Thickness, which is a common way





that manufacturers define sheet products.


X
VAR
PART or ZONE
These 3 related variables define the x, y, and z position


Y
VAR
PART or ZONE
of the parent element's origin point in space, as


Z
VAR
PART or ZONE
measured from the root zone's origin point.





XML Example:





<part name=“MyPanel”>









<var name=“X” value=“0” />



<var name=“Y” value=“12” />



<var name=“Z” value=“−5” />













</part>


ROTX
VAR
PART or ZONE
These 3 related variables define the rotation in degrees


ROTY
VAR
PART or ZONE
of the parent element about each of the three axes.


ROTZ
VAR
PART or ZONE
Since rotation transformations will provide a different





result based on the order one applies them, these





rotations are always performed in the same order: first





rotation is about the X axis, second is about the Y axis,





and third is about the Z axis.





XML Example:





<part name=“MyPanel”>









<var name=“ROTX” value=“0” />



<var name=“ROTY” value=“90” />



<var name=“ROTZ” value=“−45” />













</part>


ORIENTATION
VAR
PART or ZONE
ORIENTATION can contain any of the following





string values: TOPPANEL, BOTTOMPANEL.





LEFTPANEL, FRONTPANEL, RIGHTPANEL, or





BACKPANEL. These are a shortcut method of





positioning sheet panel parts into a useful





transformation in space without having to figure out





the ROTX, ROTY, and ROTZ manually.


ROUGHL
VAR
PART or ZONE
These 3 related variables can be used to define the


ROUGHW
VAR
PART or ZONE
“rough” Length, Width, and Thickness of a part. Useful


ROUGHT
VAR
PART or ZONE
for manufacturers who cut a rough piece of material to





a slightly larger size than the finished part, then





machine it down from there to a finished size. These





values, if defined, will show up on cut lists generated





for this product.









Types















Reserved Name
Element
Contained in
Description







TYPE
VAR
ZONE
The TYPE of a zone can contain any string the author





desires. It is used by some software systems to determine





libraries of “drag and drop” parts that can be added to a





product at configure time, such as a stack of drawers that





can be dragged into a empty cell of a cabinet product.





XML Example:





<zone name=“UnderTheCounter”>









<var name=“TYPE” value=“HoleForDrawers” />













</zone>


TYPE
VAR
PART
The TYPE of a part can contain any of the following strings:





PANEL, EXTRUSION, TURNING, or DIMENSION.





These determine how other reserved variables and arrays





define the part. (For example, the reserved variable





DISPLAYVALUE only has meaning inside a part of type





DIMENSION.)





XML Example:





<part name=“HeightOfProduct”>









<var name=“TYPE” value=“DIMENSION” />



<var name=“DISPLAYVALUE” formula=“thisZone.H”









/>



</part>










General















Reserved Name
Element
Contained in
Description







ISHIDDEN
VAR
PART or
A numerical variable. If it contains a value that is greater




OPERATION
than zero, the parent part or machining operation will be




ARRAY
“hidden” from view. Typically defined as a formula,





allowing the part to hide itself based on the state of the





product.





XML Example (if the width of the product is less than 50





inches, then no support bracket is needed. But once the





product is made wider than 50 inches, the bracket is shown):





<part name=“ExtraMetalBracket”>









<var name=“ISHIDDEN” formula=“thisZone.W<50” />













</part>


MATERIAL
VAR
PART
Contains a string describing the material that the part is





made of. This string can have functional meanings





depending on the software consuming the product, but any





value is allowed.


COST
VAR
PART or ZONE
Contains a numerical value or formula that calculates the





monetary cost for a given part or product. By definition, the





cost of a product is the sum of all of its parts' costs.


NOTES
VAR
PART
Contains any manufacturing note about the part that the





author wants to appear on a bill of materials report.


BOMGROUP
VAR
PART
Contains a string describing a “group” that the part is placed





inside of when a bill or material is generated. Useful for





organizing lists of parts into a series of meaningful groups.





XML Example:





<part name=“TopHinge”>









<var name=“BOMGROUP” value=“All Hinges” />













</part>


REPEAT
VAR
PART
If this value is greater than zero, it denotes how many times





to repeat this part. For example a REPEAT=“1” will mean





that the part has two instances inside the model, the base





part and the 1 repeated part. Useful for denoting parts that





repeat in a regular fashion, such as slats on a fence or stairs





in a staircase. Please note that for each repeated part, the





software system will set a reserved variable called





“REPEATID” that indicates its index in the list of repeated





parts, allowing one to create formulas that change position





of each repeated part based on “which” copy it is.









Metadata















Reserved Name
Element
Contained in
Description







METANAME
VAR
ROOT ZONE
Defines a “friendly name” for the product. Useful





for having a root zone name that is descriptive





programmatic ally while maintaining a consumer-





facing name with meaning.





XML Example:





<zone name=“Window”>









<var name=“METANAME” value=“Sliding













Window” />





</zone>


METADESCRIPTION
VAR
ROOT ZONE
Defines a long description of the product. Useful





for storing marketing copy.


METAINTRO
VAR
ROOT ZONE
Defines a short description of the product (5-15





words). Generally displayed beneath the name of





the product when shown in list view.


METASKU
VAR
ROOT ZONE
Defines the manufacturer's SKU (Stock Keeping





Unit), generally a unique string of letters and





numbers that define the product distinctly. Often,





the metaSKU is defined as a formula so that one





parametric product can integrate with legacy





systems that rely on SKU database.





XML Example:





<zone name=“Window”>









<var name=“METANAME” value=“‘WIN’ +













Wndow.W” />





</zone>


METAMANUFACTURER
VAR
ROOT ZONE
Defines the name of the manufacturer.


METAURL
VAR
ROOT ZONE
Defines a URL for a marketing website where a





consumer can learn more about the product.


METANOTES
VAR
ROOT ZONE
Contains any notes that generally describe





something about the product or its history.


METAPUBLISHDATE
VAR
ROOT ZONE
Contains a timestamp value defining when the





product was published. Interacts with the root





zone's FILE variable to allow a manufacturer to





publish up to date versions of the product as





needed.


METAAUTHOR
VAR
ROOT ZONE
Contains the name of the person who created the





product.









Web Interaction















Reserved Name
Element
Contained in
Description







. . .
INCLUDE
ANY
The INCLUDE element contains an attribute called “URL”





that defines a remote data source. INCLUDES are





downloaded at run time and the content of their URL





completely replaces the INCLUDE element inside the tree





hierarchy.





XML Example:





<include name=“http://www.anywhere.com/SomeFile.xml”>


GUIURL
VAR
ROOT ZONE
Contains a URL where a web-based configurator program





can be found that is specific to this product. Allows





manufacturers to create custom web configurators on a





product-by-product or catalog-by-catalog basis. This





configurator can be programmed in any programming





environment that can accept an XML stream as POST data





and can return the newly configured XML via a HTTP





download request.


FILE
VAR
PART
Contains a URL where the software can download a file





describing complex geometry for the part (generally in





DWG, SKP, or Collada file format). If this variable is





defined, the software will attempt to download the geometry





file and place it inside the part, scaling it to fit the parametric





size and position. Useful for complex geometry such as a





curved table leg that is impossible to draw with prismatic





boxes, extrusions, or turnings.


FILE
VAR
ROOT ZONE
Contains a URL where the author can post a “canonical”





version of the parametric product. Interacts with the





METAPUBLISHDATE variable to allow a software system





to download the latest version of a product as it is published





by the author.









Operations Array















Reserved Name
Element
Contained in
Description







OPERATIONS
ARRAY
PART
This array contains a series of sub arrays. Each sub array





defines a CNC machining operation to apply to the parent





part. These are things like drilling holes, routing pockets,





etc.


OPERATION
ARRAY
OPERATIONS
Each of these subarrays represents a single CNC operation.


SUBARRAY

ARRAY
It is the variables within the subarray that define the





operation.


TOKEN
VAR
any operation
Contains BORE to define a single circular hole,





MULTIBORE to define a linear series of circular holes, or





POCKET to define a rectangular hole.


FACE
VAR
any operation
Defines one of the 6 faces that make up a prismatic part.





Possible values include FRONT, BACK, LEFT, RIGHT,





INSIDE, and OUTSIDE. This is the face that the machining





operation will be applied to.


X
VAR
BORE or
Defines the X value to start the machining operation, by




POCKET
imagining the selected FACE as a 2 dimension surface with




operations
an origin closest to the part's overall origin.


Y
VAR
BORE or
Defines the Y value to start the machining operation, by




POCKET
imagining the selected FACE as a 2 dimension surface with




operations
an origin closest to the part's overall origin.


STARTX
VAR
MULTIBORE
These 4 related variables define a line along which a series


STARTY

operations
of MULTIBORE holes will be machined. STARTX and


ENDX


STARTY define where the first hole in the multibore


ENDY


sequence will be centered. ENDX and ENDY define a point





where the line of holes will be drawn toward.


PITCH
VAR
MULTIBORE
Defines the distance between each of the MULTIBORE




operations
holes. If one needs to define a hole every 2 inches, then the





PITCH will contain “2”.


DIAMETER
VAR
BORE or
Defines the diameter of the hole to drill.




MULTIBORE




operations


DEPTH
VAR
Any operation
Defines how deeply the operation is cut or bored into the





part.


L
VAR
POCKET
Defines the length of the rectangular POCKET, with the L




operation
dimension measured along the selected FACE's X axis.


W
VAR
POCKET
Defines the width of the rectangular POCKET, with the W




operation
dimension measured along the selected FACE's Y axis.










System-Created Variables


These variables are automatically calculated and made available for formulas. In this illustrated embodiment, they cannot be explicitly set, only read.















Reserved Name
Element
Contained in
Description







LEFTX
VAR
PARTS and
Contains the far left X value as defined by the parent




ZONES
element's bounding box.


RIGHTX
VAR
PARTS and
Contains the far left X value as defined by the parent




ZONES
element's bounding box.


TOPZ
VAR
PARTS and
Contains the largest Z value as defined by the parent




ZONES
element's bounding box.


BOTTOMZ
VAR
PARTS and
Contains the smallest Z value as defined by the parent




ZONES
element's bounding box.


FRONTY
VAR
PARTS and
Contains the closest Y value as defined by the parent




ZONES
element's bounding box.


BACKY
VAR
PARTS and
Contains the farthest back Y value as defined by the




ZONES
parent element's bounding box.


EXTRUSIONLENGTH
VAR
PARTS of type
Contains the total length of material used by an




EXTRUSION
extruded part, including a waste factor that is calculated





to leave enough room for miters as the extrusion goes





around corners.


PATHLENGTH
VAR
PARTS of type
Contains the total length of the path followed by an




EXTRUSION
extruded part, not including a waste factor for miters.


THISPART
VAR
ALL
A “shortcut” variable that contained a reference (aka





pointer) the element's parent part.


THISZONE
VAR
ALL
A “shortcut” variable that contained a reference (aka





pointer) the element's zone.


PARENTZONE
VAR
ALL
A “shortcut” variable that contained a reference (aka





pointer) the element's parent zone.


THISZONENAME
VAR
ALL
Contains the name of the element's current zone


PARENTZONENAME
VAR
ALL
Contains the name of the element's parent zone


REPEATID
VAR
PART
Contains the index of a part in a list of repeated parts.





(See REPEAT variable above.) For example, in the case





of a part with a REPEAT of 2, there will be three parts





created. The first of these parts will contain a





REPEATID of 0, the second will contain a REPEATID





of 1, and the third will contain 2. By using this variable





in a formula, one can space out each part in a different





fashion.





XML Example:





<part name=“stair”>









<var name=“REPEAT” formula=“thisZone.H/8” />



<var name=“Z” formula=“repeatID*8” />









</part>










Settings Array















Reserved Name
Element
Contained in
Description







SETTINGS
ARRAY
ROOT ZONE
The SETTINGS array contains several





reserved variables that control the software





application loading the parametric product.





XML Example (sets the default unit to





millimeters)





<zone name=“UnderTheCounter”>









<array name=“SETTINGS”>










<var
name=“LINEARUNIT”









value=“MM” />









</array>













</part>


LOADONSTARTUP
VAR
SETTINGS
Contains a URL to a parametric product data




ARRAY
source that the software should load the first





time it is opened.


BOMGROUPMISCNAME
VAR
SETTINGS
Tells the software what to name the bill of




ARRAY
material group that parts without a specifically





defined BOMGROUP should be placed into.


BOMGROUPREPORTNAME
VAR
SETTINGS
Tells the software what to title its bill of




ARRAY
material report


PURCHASELISTGROUPREPORTNAME
VAR
SETTINGS
Tells the software what to title its purchase list




ARRAY
report


BOMGROUPSORT
ARRAY
SETTINGS
An array that contains variables whose values




ARRAY
define sorting order for BOMGROUPs that





appear in the product. The name of the child





variables correspond to the BOMGROUP





names. The values of the child variables are





integers, with the lower the number appearing





closer to the front of the bill of materials





report.


PURCHASELISTGROUPSORT
ARRAY
SETTINGS
An array that contains variables whose values




ARRAY
define sorting order for BOMGROUPs that





appear in the product.


DXFLAYERS
ARRAY
SETTINGS
An array whose variables define how layer




ARRAY
names should be output for this product when





DXF files for the containing parts are





generated. See below for a more complete





discussion.









Dxflayers Array















Reserved Name
Element
Contained in
Description







DXFLAYERS
ARRAY
SETTINGS
An array whose variables define how layer names should be




ARRAY
output for this product when DXF files for its parts are





generated. Useful for outputting a 2D DXF for each part in a





product, where certain features are drawn onto explicitly





named layers. Often, these layer names are formulaically





defined to contain extra data in the layer name that





engineering software can parse.


HBORE_L
VAR
DXFLAYERS
These 4 related variables defien the layer name that horizontal




ARRAY
bore boxes will be drawn during DXF output. HBORE_L


HBORE_R
VAR
DXFLAYERS
defines the name for bores drawn on the “left” face. The others




ARRAY
are for the Right, Front, and Back faces, respectively.


HBORE_F
VAR
DXFLAYERS




ARRAY


HBORE_B
VAR
DXFLAYERS




ARRAY


POCKET
VAR
DXFLAYERS
Defines the layer name that POCKET operations will be




ARRAY
drawn in during DXF output.


LINETO
VAR
DXFLAYERS
Defines the layer name that LINETO or ARCTO contours will




ARRAY
be drawn in during DXF output. Formulas in this variable can


ARCTO
VAR
DXFLAYERS
refer to a special shortcut operand called TOOLNUMBER,




ARRAY
such that each contour segment can be placed onto a certain





layer that corresponds to a CNC machine's tool carousel





number or alias. The resolved value of this shortcut





corresponds to the TOOLNUMBER variable set in that





contour segment. If no TOOLNUMBER variable is set in a





contour, then that contour will NOT be drawn into the DXF,





which is useful for manufacturers who care only to get overall





part sizes for nested saw operations, but will run the saw-cut





parts on a CNC further downstream.










Special Variable Attributes


This “special” attributes can be applied directly to a variable attribute. In the same way that a variable can have a name, value, and formula, it can have any of the following:













Attribute Name
Description







ISPRIMARY
Contains a numerical value or a formula. If the value is greater than 0, then this variable



is placed in a special category of “primary variables.” Primary variables are the small



subset of variables that is needed to totally recreate the configuration of this product.



For example, a bicycle product could be made up of dozens of parts that interact with one



another via potentially hundreds of complex formulas. But at the end of the day, the



product itself is defined by perhaps just two variables: WheelSize and PaintColor. These



variables would be defined with isPrimary=“1”, allowing a software system to store the



entire configuration with a very small amount of data.


INITIALFORMULA
Contains a formula that is executed once only when the product is first opened. Useful for



initializing variables that start at a particular value, but can be changed by the end user



from there.


LABEL
This attribute is used to define a “friendly name” for a variable that is displayed at run



time by configuration software. For example, a variable named “DoorX” could have a



label of “Left Side of Door”, making the UI presented to the end user much easier to



understand.










Formula Functions and Operators


Formulas can contain any of the following operators and functions.













FUNCTION



OR


OPERATOR
Description







ARITHMETIC
+ addition


OPERATORS
− subtraction



* multiplication



/ division


COMPARISON
These operators result in a 1 or a 0, representing


OPERATORS
true or false. Their order of operation is higher



than all of the arithmetic operators, meaning they



are evaluated BEFORE arithmetic.



= is equal to



!= is not equal to



< is less than



> is greater than



<= is less than or equal to



>= is greater than or equal to


GROUPING
Parentheses can be used to force order of operation


OPERATORS


ABS( )
Function returns the absolute value


ROUND( )
Function rounds to the nearest integer value


FLOOR( )
Function rounds down to the nearest integer value


CEIL( )
Function rounds up to the nearest integer value










Parts of Type “Dimension”


The following variables and arrays have particular meaning within a part of type “DIMENSION”















Reserved Name
Element
Contained in
Description







TYPE
VAR
PART
If a part is of type “DIMENSION”, then the part will





display in the software system as a linear, drafting-style





dimension that appears in the space defined by the size





and position of the part. In the center of the dimension is





an editable text control.





XML Example:





<part name=“TopWidthDim”>





 <var name=“type” value=“DIMENSION” />]









<var name=“layout” value=“HORIZONTAL” />



<var name=“displayValue” formula=“TopBoard.l” />



<var name=“w” formula=“TopBoard.l” />



<var name=“h” value=“4” />



<var name=“d” value=“0” />



<var name=“x” formula=“TopBoard.leftX” />



<var name=“y” formula=“TopBoard.backY+3” />



<var name=“z” formula=“TopBoard.topZ+4” />



<array name=“editChanges”>









<var value=“Cabinet.w” />









</array>



<array name=“editMultipliers”>









<var name=“Cabinet.w” value=“1” />









</array>













</part>


LAYOUT
VAR
PART of type
Contains one of three string values: HORIZONTAL,




DIMENSION
VERTICAL, or GRID. Horizontal denotes that the





dimension line will appear horizontally with two leaders





on the sides. Vertical denotes that the dimension line will





appear vertically with two leaders at the top and bottom.





GRID denotes a dimension that only appears in an





editable grid set aside from the parametric product. (See





LABEL below for more details.)


LABEL
VAR
PART of type
Defines a string label that is used to identify a “friendly




DIMENSION
name” of the dimension. For example, one might have a





dimension part named “CH” for ease of writing formulas,





but have a label of “Cabinet Height” for maximum





readability by an end user. Also, some software systems





will display a grid of all labelled dimensions to the side of





the 3D view, allowing one to see a summary of the sizes





used in the product.


DISPLAYVALUE
VAR
PART of type
The value of this variable is what will displayed in the




DIMENSION
text control of the dimension part. Typically, a horizontal





dimension will set this value formulaically to equal its





width, and a vertical dimension will set this value





formulaically to equal its height, but any formula can be





defined.


EDITCHANGES
ARRAY
PART of type
This array contains a series of variables. The name of




DIMENSION
these variables is not required (i.e. it is an indexed array,





not an associative array.) The values of these variables





contain a reference to each variable that changes when





this dimension is edited. For example, changing the width





of a dimension might increase both the width of an overall





product AND the width of an embedded zone. One can





define as many “editchanges” variables in this array as





desired.


EDITMULTIPLIERS
ARRAY
PART of type
This array contains a series of variables. The name of




DIMENSION
each variable corresponds with a variable that is





referenced in the editChanges array. The value of each





variable contains a numeric multiplier that is applied to





any dimension change before it is applied to the end





editChanges target. For example, the following example





part INCREASES the width of the left zone while





decreasing the width of the right zone:





XML Example:









<array name=“editChanges”>









<var value=“LeftZone.w” />



<var value=“RightZone.w” />









</array>



<array name=“editMultipliers”>









<var name=“LeftZone.w” value=“1” />



<var name=“RightZone.w” value=“−1” />









</array>










EDITINCREMENT
VAR
PART of type
This optional variable sets an “increment” value that is




DIMENSION
forced on the end user. For example, a value of “.125”





would round any dimension that the end user enters to the





nearest ⅛ of an inch. Useful for situations in which a





parametric product is only available in a set increment of





sizes, such as a window being available in 2” incremental





widths.


MAX
VAR
PART of type
Defines a maximum value for this dimension.




DIMENSION



MIN
VAR
PART of type
Defines a minimum value for this dimension




DIMENSION



MAXALERT
VAR
PART of type
Defines an alert message that will appear when the end




DIMENSION
user attempts to enter a dimension value that is larger than





its defined MAX.


MINALERT
VAR
PART of type
Defines an alert message that will appear when the end




DIMENSION
user attempts to enter a dimension value that is smaller





than its defined MIN.









Drag Rules















Reserved Name
Element
Contained in
Description







DRAGRULE
ARRAY
PART
This array contains sub arrays that define a part's





behavior when it is dragged in a 3D view with a mouse





pointing device. When a user drags a part, they drag it





along a defined axis, and where it drags to inside the





product will alter any number of other variables.


DRAGCHANGES
SUB
DRAGRULE
This array contains a series of variables. The name of



ARRAY
ARRAY
these variables is not required (i.e. it is an indexed array,





not an associative array.) The values of these variables





contain a reference to each variable that changes when





this part is dragged. For example, dragging the side of





the cabine to the right could increase the X value of that





part as well as the overall size of an edjacent zone.


DRAGMULTIPLIERS
SUB
DRAGRULE
This array contains a series of variables. The name of



ARRAY
ARRAY
each variable corresponds with a variable that is





referenced in the dragChanges array. The value of each





variable contains a numeric multiplier that is applied to





any drag change before it is applied to the end





dragChanges target. For example, the following example





part INCREASES the width of the left zone while





decreasing the width of the right zone:





XML Example:





<array name=“dragRule”>









<var name=“ drag Axis” value=“thisZone.x” />



<var name=“dragIncrement” value=“.125” />



<array name=“dragChanges”>









<var value=“thisPart.x” />



<var value=“LeftZone.w” />



<var value=“RightZone.w” />









</array>



<array name=“dragMultipliers”>









<var name=“LeftZone.w” value=“1” />



<var name=“RightZone.w” value=“−1” />









</array>













</array>


DRAGINCREMENT
VAR
DRAGRULE
This optional variable sets an “increment” value that is




ARRAY
forced on the end user. For example, a value of “.125”





would “snap” the dragging of a part to ⅛ inch





increments.


DRAGAXIS
VAR
DRAGRULE
Defines the X, Y, or Z axis of any part or zone in the




ARRAY
product. This is the iamginary line along which the part





can be dragged. For example, setting the dragAxis to





“thisZone.x” will allow the part to be dragged left or





right. Setting the dragAxis to “thisZone.y” will allow the





part to be dragged forward or backward. Setting the





dragAxis to “thisZone.z” will allow the part to be





dragged up or down.










Parts of Type “Extrustion”


The following variables and arrays have particular meaning within a part of type “EXTRUSION”















Reserved Name
Element
Contained in
Description







TYPE
VAR
PART
If a part is of type “EXTRUSION”, then the part will be





defined with a “section” array describing its 2d cross section,





and a “path” array describing the path that the extrusion will





take through the product. A common example of an extruded





part is a crown molding around the top edge of a cabinet. The





molding has a particular cross section, then it is extruded





along a 3-part path around the left, front, and right sides of the





cabinet.


SECTION
ARRAY
PART of type
Contains 2 subarrays named X and Y that define a series of




EXTRUSION
points that make up the section of an extruded part. The X, Y





pairs should be imagined as clockwide, outer path that traces





the shapes of the contour in 2D space.


PATH
ARRAY
PART of type
Contains 3 subarrays named X, Y, and Z that define a series of




EXTRUSION
3D points in the current zone's absolute coordinate space.





These points draw out the series of path that an extrusion is





sent through.










Parts of Type “Panel” or “Turning”


The following variables and arrays have particular meaning within a part of type “PANEL” or “TURNING”















Reserved Name
Element
Contained in
Description







TYPE
VAR
PART
If a part is of type “PANEL”, then it can optionally contain an





Edges array that represents a 2-D shape for the panel. For





example, a panel part might be a 24 × 24 piece of plywood that





is then machined down into a circular tabletop. The Edges





array would contain a series of 4 quarter-circle curves that





trace out the circle. If a part is of type “TURNING”, then it





can contain an Edges array that represents a 2-D shape for the





half-cross section of the turning. For example, a turned table





leg with a fancy shape would have half of that shape defined





in the edges array, and the system will perform the 3D





“sweep” to create its final turned shape.


EDGES
ARRAY
PART of type
Contains a series of subarrays. Each subarray defines the next




EXTRUSION
“point” in a line that traces the shape of the part in a clockwise





fashion.


POINT
SUB
EDGES
Contains several child variables that collectively define the



ARRAY
ARRAY
next point in the shape of the part.


X
VAR
POINT ARRAY
These two related variables define the 2D position of the next





point in the shape of the part.


Y
VAR
POINT ARRAY


TOKEN
VAR
POINT ARRAY
Contains “START”, “LINETO”, or “ARCTO”. Defines the





nature of the line that is drawn into this point. STARTTO





token is always contained in the first point in the Edges array.





LINETO tells the system to draw a straight line to this point.





ARCTO tells the system to draw an arc segment to this point.


ISCONCAVE
VAR
POINT ARRAY
Contains “0” or “1”. Concavity is in terms of the finished part,





meaning concave curves will bulge toward the center of the





part (or “into the material”) and non concave curves will bulge





away from the center.


DROP
VAR
POINT ARRAY
Contains a numerical distance that denotes how “big” the





bulge is in an ARCTO point. The distance is measured from





the midpoint of an imaginary segment from the previous point





to this point, then measured at a 90 degree angle from that





imaginary point to the intersection of the curve. For example,





a DROP of 1 inch will deviate 1 inch from a straight line at





the center of the arc.


RADIUS
VAR
POINT ARRAY
An alternative to defining an arc with a DROP is to define the





radius of the arc. Use this variable in place of DROP to do so.





Please note that one must also define ISMAJORARC is one





wants to use the radius.


ISMAJORARC
VAR
POINT ARRAY
In the case of an ARCTO that is defined as a radius, this





boolean will contain “1” or “0” to denote whether the ARCTO





is greater than a half circle (i.e. is “major”) or is less than a





half circle (i.e. is “minor”.) This is needed because with a





given radius and two points that a circle must go through,





there are two possible center points for that circle.





ISMAJORARC identifies which of these two circles is





desired.


TOOLNUMBER
VAR
POINT ARRAY
This optional var defines a CNC tool number that the current





segment should be machined with in a manufacturing process.





Useful for definining a certain segment to be cut out with a





profiled-tool (such as a fancy edge for a cabinet front) versus





a normal, flat too (such as one would use for the back of a





cabinet top that will be butting against a wall when installed.)








Claims
  • 1. A system for representing a three-dimensional object, the system comprising: a computer processor for processing parameters of the three-dimensional object;a first element representing in at least one storage medium accessible to the computer processor a region that contains the three-dimensional object, said region comprising a root of a tree hierarchy;a second element in the at least one storage medium accessible to the computer processor representing a dimension of a component of the three-dimensional object, said second element comprising a three-dimensional boxed area defining an outer dimension of the three-dimensional object to be modeled, said region defining a size, location and rotation in space of said three-dimensional object to be modeled;a third element in the at least one storage medium accessible to the computer processor representing a first variable associated with the region and a second variable associated with the component, wherein the second variable comprises data defining characteristics of the component, and wherein the second variable includes a variable formula that modifies the data of the second variable according to a mathematical expression containing operators that act upon dynamic values from other variables inside the tree hierarchy; anda graphical user interface in communication with the computer processor for displaying a representation of the three-dimensional object based on the first, second, and third elements retrieved by the computer processor.
  • 2. The system of claim 1, further comprising a fourth element comprising a plurality of options, each of the plurality of options corresponding to a specific value that is applied to the data of the variable upon one of the plurality of options being selected by an end user.
  • 3. The system of claim 2, further comprising a fifth element operable to access data across a plurality of components or three-dimensional objects.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a divisional application of and claims the benefit of co-pending U.S. patent application Ser. No. 12/196,759 filed on Aug. 22, 2008 entitled “Systems and Methods for Parametric Modeling of Three Dimensional Objects” by Peter Saal, and assigned to the assignee of the present application; the disclosure of which is hereby incorporated herein by reference in its entirety. This application also claims priority benefit, under 35 U.S.C. §102(e), of U.S. Provisional Patent Application Ser. No. 60/957,404, filed Aug. 22, 2007, entitled SYSTEMS AND METHODS FOR PARAMETRIC MODELING OF THREE DIMENSIONAL OBJECTS, by Peter Saal, which is incorporated by reference in its entirety.

US Referenced Citations (38)
Number Name Date Kind
5583977 Seidl Dec 1996 A
6133916 Bukszar Oct 2000 A
6219055 Bhargava et al. Apr 2001 B1
6222557 Pulley, IV et al. Apr 2001 B1
6392645 Han et al. May 2002 B1
6525745 Phelan et al. Feb 2003 B1
6791549 Hubrecht et al. Sep 2004 B2
6931604 Lane Aug 2005 B2
7477232 Serra et al. Jan 2009 B2
7590497 Tornquist et al. Sep 2009 B2
7669158 Kamat Feb 2010 B2
7672822 Lee et al. Mar 2010 B2
7825940 Vieilly et al. Nov 2010 B1
7940259 Wright et al. May 2011 B2
7969435 DeSimone et al. Jun 2011 B1
8194067 Raby et al. Jun 2012 B2
8269766 Ogata et al. Sep 2012 B2
8311320 Endo et al. Nov 2012 B2
9679410 Saal et al. Jun 2017 B1
20010055013 Fuki Dec 2001 A1
20020107673 Haller et al. Aug 2002 A1
20040054516 Oyasato et al. Mar 2004 A1
20040263509 Serra et al. Dec 2004 A1
20050018058 Aliaga et al. Jan 2005 A1
20050038540 Hill et al. Feb 2005 A1
20050203718 Carek et al. Sep 2005 A1
20060075371 Kamat Apr 2006 A1
20060152521 Paaso Jul 2006 A1
20060206587 Fabbrocino Sep 2006 A1
20070013709 Charles et al. Jan 2007 A1
20070240152 Li Oct 2007 A1
20080196022 Diederichs Aug 2008 A1
20080246762 Ogata et al. Oct 2008 A1
20080297507 Chen et al. Dec 2008 A1
20080319833 Svendsen Dec 2008 A1
20090110297 Endo et al. Apr 2009 A1
20110218776 Shono et al. Sep 2011 A1
20140003713 Seow et al. Jan 2014 A1
Non-Patent Literature Citations (3)
Entry
Rubin, Steven M., “A 3-Dimensional Representation for Fast Rendering of Complex Scenes”, Bell Laboratories, Holmdel, New Jersey 07733, (1980),pp. 1-7.
U.S. Appl. No. 12/196,759, Non-Final Office Action mailed on Aug. 29, 2016, 13 pages.
U.S. Appl. No. 12/196,759, Notice of Allowance mailed on Feb. 8, 2017, 13 pages.
Related Publications (1)
Number Date Country
20130201189 A1 Aug 2013 US
Provisional Applications (1)
Number Date Country
60957404 Aug 2007 US
Divisions (1)
Number Date Country
Parent 12196759 Aug 2008 US
Child 13799503 US