Designing VLSI systems represents a challenging task. It is a
transfonnation among different specifications corresponding to different
levels of design: abstraction, behavioral, stntctural and physical. The
behavioral level describes the functionality of the design. It consists
of two components; static and dynamic. The static component describes
operations, whereas the dynamic component describes sequencing and
timing. The structural level contains infonnation about components,
control and connectivity. The physical level describes the constraints
that should be imposed on the floor plan, the placement of components,
and the geometry of the design. Constraints of area, speed and power are
also applied at this level. To implement such multilevel transfonnation,
a design methodology should be devised, taking into consideration the
constraints, limitations and properties of each level. The mapping
process between any of these domains is non-isomorphic. A single
behavioral component may be transfonned into more than one structural
component. Design methodologies are the most recent evolution in the
design automation era, which started off with the introduction and
subsequent usage of module generation especially for regular structures
such as PLA's and memories. A design methodology should offer an
integrated design system rather than a set of separate unrelated
routines and tools. A general outline of a desired integrated design
system is as follows: * Decide on a certain unified framework for all
design levels. * Derive a design method based on this framework. *
Create a design environment to implement this design method.