Yogesh,
I am going to take a crack at your future questions because I have a
bit of free time at the moment. I personally find this topic pretty
interesting.
15 years ago...
CAD systems were pretty simple. They provided an interface to build
geometrical representations of models, a data structure to contain
them, and a means of viewing combined with tools for basic analysis of
and between the various elements input by the user.
They were not feature based or parametric, other than through some
macro type capabilities.
The primary difference between then and now is this:
The older systems did not capture design intent, only the result of
it. If a user were to make a change, they must analyze the structure
of the model, then use the tools available to them to manually change
the model.
Today, we basically tell the program how the model should be built and
how it should respond to changes and the system builds the model.
Another primary difference between then and now is the quality and
nature of the model representation. Early systems were limited to
wireframe only. They represented the intersections of surfaces only.
Today, we have full boundary representation models. (B-rep) These
models include all the intersections present in the older systems plus
surfaces and volumes along with material property definitions. All of
this comes with increasing demands for compute power of course.
Lets take a very simple example; namely, a cube that will change size
and have a hole cut into it.
Early wireframe systems would require a manual process for this:
- Draw a rectangle anyway you want. 4 lines, rectangle command,
whatever because it does not matter. Lines are lines...
- Transform along vector normal to rectangle and construct the 4
additional lines that represent the intersections of the side
surfaces.
Modern day systems:
- Draw a rectangle. This time the method matters somewhat because the
system can capture your design intent. So, a rectangle drawn with the
rectangle command will act like one when changed. Since the user
asked for a rectange, as opposed to 4 lines, the system can make a
number of assumptions; namely, the two parameters for width and
length, each line end point being coincident with its nearest
neighbor, two lines perpendicular, two lines parallel, etc...
Or, one could construct the same rectangle manually using the line
command as well, then proceed to specify each necessary constraint and
parameter as needed until the result acts like a rectangle.
The idea being you are building instructions for use later, not just
constructing geometry. Notably, the rectangle drawn and constrained
in the modern system is not really part of the model, it is a
representation used to tell the system how to build the model.
Contrast that with the earlier method.
- Extrude, linear sweep, whatever to form a solid. Additional
parameters are supplied during this step also. (Depth, draft, etc...)
The system then builds the model according to the parameters given.
It is interesing to note at this stage, construction can sometimes be
more involved during the initial create process, compared to the time
required for the simple geomtery constructs used in the early systems.
The amount of information captured is significantly greater however.
The older system only knows a bunch of lines have been added to its
database of entities, along with some elementary attributes:
1. line x,y,z x1,y1,z1, color, level, style, etc...
2. line x,y,z x1,y1,z1, color, level, style, etc...
.
.
.
12. line x,y,z x1,y1,z1, color, level, style, etc...
The newer one knows a number of things; namely, (In the case of
I-deas)
- an Untitled part is now present on the workbench
- said part consists of:
- a local coordinate system, currently at the origin
- one feature composed of
- 1 sketch with its own constraint network and lines in this case
- feature operation parameters detailing type, etc...
- one solid volume composed of:
- 6 trimmed planes
- surface information mapped in the UV coordinate space (ST for
ideas)
- 24 lines defining the limits of the planes (4 per)
- boundary information detaling common edges
- material definition, I believe the default for I-deas is
Styrofoam.
- other relevant information
- geometry pick list
- labels for relationships (vertex, face, edge, volume, curve,
etc...
- display information (tesselation, color, etc...)
- etc...
The difference in datasets is significant, as are the results
Change size of block model:
In the manual system, the user must determine the nature of the change
to be made, develop a mental picture of the result, then finally map
those two to both the tools at hand and a process for using them to
achieve the desired result. This process involves more than simple
geometry elements, the intended design intent must be communicated in
some fashion outside the tool used to make the change. Typically,
this information is represented in a drawing or design notes the user
can use to help with this task. Additionally, the older system knows
nothing of parts, volumes and other things taken for granted today.
The attributes are used to convey this information in a limited way,
again the idea being to help the user process the change correctly.
A CADKEY user might decide to BOX MOVE the model to change its size.
If other models are on the screen, the user may have to pick via
attribute masking, and check that pick to verify it includes only the
entities necessary, where a modern system would know what entities are
involved because it has the additional data necessary to do so. Other
systems might involve a transform step and several trim/extend steps
to complete the change. The end result is the same though --a manual
change directly on the model representation itself.
Once the change is complete, the user must verify the operation in
order to determine the new representation meets the requirements.
Measurement and dimensioning tools can be used for this. Again, the
user must process both the low level data (dimensional size and
geometric shape) and the higher level data involving design intent, in
order to achieve a correct result.
If the model has a drawing associated with it, the user must also
view, modify, and in many cases re-render the drawing to better
represent and communicate all they have learned about the model in the
hope that others will understand it. Since the limited dataset does
not include enough information to properly detail the model, many of
the view processing options we see today are done manually as well.
(Hidden line removal, etc...)
In the modern system, the larger volume of data, combined with the
captured design intent make this a simple process.
-Change the parameter that most directly controls the change, then ask
the system to show the new result. Given the change results in
geometry, within the limits of the already specified design intent and
the system is able to correctly interpet this intent, the change will
be made without significant user intervention.
An associated drawing can be mostly updated as well, normally only
requiring minor cosmetic adjustments to complete the task.
Overall, this is a much shorter and mentally easier process!
Adding the hole in the manual system involves the same tedious steps
as required for the block. Common representations, during this time,
involved two circles, connected by a single line. So, three more
entities get added to the database. The attributes might be used to
communicate feature related information, but the system can do nothing
but display the differences. It is all up to the user to understand
what those attributes mean in the future.
The parametric, feature based approach is basically the same, in
I-deas at least, for parts as it is for features; namely, sketch
something and create a solid from it, then tell the system how that
solid relates to the part at hand. (Boolean operation add, join, cut,
intersect.) Many feature based systems today include specific feature
types intended to make this process faster. (Hole and rib commands,
for example.)
Users of the parametric model representation can browse the
instruction set (history/feature tree) to choose among features to
modify. Ideally, the modifications are considered in the context of
the other features for a fast and accurate result. Many minor details
are invisible to the user as a result of this process, compared to the
older systems.
Additionally, the higher level representations permitted in modern
systems, like I-deas, allow the user to think about their model in
terms that can greatly help with accuracy and problem solving. Fully
constrained models help the user determine if they have really thought
about the entire feature in question during create, for example.
Breaking down new features into their component constraints and design
intent needs helps to build functional designs without having to also
worry about all the numbers.
Doug's rule of CAD: In a properly designed CAD system, you should be
able to construct a fully functional model without having to input and
calculate specific numerical aspects of the model. (I-deas is
fantastic at this, BTW where many CAD packages demand more information
from you than necessary.) This is also true of many older systems,
within their limits as well. (CADKEY has a very nice position menu
that allowed users to directly determine coordinates based on other
model entities, greatly reducing the number of numbers one had to
remember and process in order to construct new model entities.)
(Hello NX! <-- I sure hope they fix this!)
Lets say you want to make a simple tube handle for a door. Said
handle will consist of a planar path, consisting of three lines, two
arcs tangent to their respective lines, one profile; namely a circle,
and a sweep operation to form the solid, followed by a shell operation
to represent a hollow tube.
In I-deas, this model can be easily built, constrained to represent
design intent, and drawing made without actually having to input
numbers or do calculations. When the model is put into context, such
as the door assembly, changes can be made via the measure command and
simple addition/subraction to determine optimal model size. If the
data is known in advance, it can be input at that time, or not...
depending on the nature of the model and data available at the time.
All one needs to do is draw any handle meeting the engineering
requirements, then adapt that model, given the information already
present in the system as a minimum, then work forward from there as
the requirements become more clear.
In the older, non parametric systems, drawing something the wrong size
generally is a waste of time because modification is difficult. This
places a high burden on the user to more fully mentally realize the
model details than would be strictly necessary at the time.
In newer systems, I-deas in particular, getting the model right
involves higher level thought about the nature of the model and how it
relates to other ones, not low level details, such as size. When
dealing with complex representations, this difference is significant
because the manual calculations required to verify the model
representation become increasingly time consuming.
I have mentioned I-deas specifically in the above mess, because some
of the terminology is specific to it. I-deas really is different from
almost every other CAD system in a number of key ways; namely, hybrid
modeling, variational math, shared multi-user global coordinates,
integrated data management...
(Another day.)