The present invention relates to systems and methods for routing traces or wires for an integrated circuit or other electronic design.
A layout is a map of electrical connections on various layers in a semiconductor integrated circuit. Computer-driven routing systems are often used to build layouts to articulate designs to be expressed in an integrated circuit. Such systems typically use a netlist which is a description of required connections between terminals, and create a routed design or layout to make such required connections.
Typically such computer driven routing systems are grid based systems that route traces on a routing grid. Some systems also employ a godless routing scheme, in which routing shapes may be placed at very precise locations.
In such a conventional grid based routing system, each layer of an integrated circuit chip is represented as a routing grid. The grids for the various layers together form a 3D routing grid. A typical integrated circuit will have at least one semiconductor layer and three wiring layers. The three wiring layers are sometimes referred to as HVH (horizontal-vertical-horizontal), ‘Horizontal’ or ‘vertical’ indicates that the layer is generally used to make traces that traverse in that direction. Vias interconnect adjacent layers.
To perform routing, the router must first receive chip technology data including various rules such as geometric rules that describe parameters such as the characteristics of layers on which rectangles representing wires can be generated, the minimum allowed width of any part of a trace, and the minimum allowed separation between traces. Typically, a router includes a global routing step for allocating groups of nets to be routed through corresponding general routing areas.
A number of conventions are employed in typical routing systems and methods. For example, the common “centerline convention” places the center of traces on the routing grid gridlines. When a net is routed, for various reasons, the trace must be distanced from existing obstacles or structures, such as, for example, other traces, including vias, and pins of other nets that have been previously routed on the grid.
As integrated circuits employ smaller sizes such as, for example, submicron-sized designs, the congestion of traces in a circuit design tends to increase. Further, modern designs tend to have wires or traces having different and non-uniform size and spacing. Typical grid-based systems may not efficiently handle such increased congestion and size variation. The increased congestion and size variation place greater constraints on the routing grid pitch employed in a particular region.
One common approach to such increased congestion and size variation is to reduce the pitch of the routing grid to allow more precise placement. Such a scheme causes, however, significant increase in the number of grid points and a corresponding increase in search time.
Another approach is to use a gridless or shape-based routing system. Such a system tracks traces and other obstacles based upon their relative locations. Shape-based systems are typically not limited to a predefined routing grid. The systems are, however, typically slow and complex.
In the IC industry, different objectives for a design are served by different design features. For example, design attributes that improve manufacturability may not so readily serve the interests of feature density just as attributes that serve reduced delay may not so readily serve other interests. The trade offs between manufacturability, reduced delay and timing sensitivity have typically been allocated with methods that are less than systematic and efficient.
What is needed, therefore, are routing techniques that provide speed similar to a grid-based system, but accuracy and flexibility that compares favorably with a shape-based system but which provide efficient management of the trade offs between manufacturability, timing, and reduced delay.
Routing systems and methods are provided having various strategies for optimizing and evaluating possible routes for netlist connections. In one embodiment, a data structure or matrix provides cost-related data weighted to evaluate a connection or segment of a connection based upon an attribute of interest such as, for example, reduced delay (i.e., impact on speed), manufacturability or noise tolerance. In some embodiments, the attribute-weighted cost information includes cost information related to neighborhood or terrain costs and intrinsic or shape costs to provide multidimensional cost information for connections. In some embodiments, the processing of such higher information cost data is made more efficient with an additive process that is less demanding than a computationally intensive iterative multiplication process.
In another embodiment, certain traces are offset from the routing grid to help provide efficient grid usage. Other embodiments have an enhanced routing grid capability that provide those parts of a dense routing grid employed to efficiently route off main grid sites or pins, for example. Various methods are also disclosed for shirting and adjusting routing grids to improve use of available space or reduce run time in routing.
In another embodiment, a parallel processing scheme is used to process multiple regions on multiple processors simultaneously without creating conflicts, that could arise, for example, when two processors try to route a trace on the same gridpoint.
Typically, routing a path or trace 16 requires routing path segments between certain gridpoints or pins. A search algorithm searches the grid to find an unblocked route through which to route trace 16. Once a route is found, many routing systems record the route using a one-bit scheme in which “1” represents that a gridpoint 14 is blocked and “0” represents that a gridpoint 14 is open for use (unblocked). More sophisticated systems employ a two-bit matrix typically stored as a data structure 18 to represent the status of each gridpoint 14. Such a scheme enables matrix or data structure 18 to contain blocking information for more than one type of trace 16. In
One embodiment of the present invention employs data structures that provide a deeper information related to a proposed route for a connection. Rather than bits indicative of one of two states (i.e., blocked/unblocked), the data structures or matrices 18 of a preferred embodiment express values representative of the impact upon selected attributes of interest such as, for example, reduced delay, noise tolerance, or manufacturability that result from routing the path or trace through a segment of the path bounded by a particular grid vertex with which the matrix or data structure has been associated. Although any number of values can be expressed by the cost matrix 18 in preferred embodiments, preferably, at least two matrix values are expressed by the cost matrix or data structure 18, each of the two values taking on one of at least, three possible range values to convey more man a binary unblocked/blocked evaluation of the degree of impact that would impinge upon a selected attribute of interest by incorporation of the selected segment into a possible path for the proposed netlist connection. Typically, one of the range values available for expression by a matrix value of data structure 18 represents a prohibition on use of that segment for the proposed path with a proposed shape.
As shown in
When complete prohibition (blockage) is indicated by more than a “1” range value for a matrix value (n1, n2, . . . nn), in preferred embodiments, that typically means that other range values are available for that matrix value to express a degree of impact upon an attribute of interest other or less than complete blockage for a proposed shape. For example, where the range value 100 indicates blockage for the matrix value n2, there is typically available at least one range value more than “0” and less than “100” for that matrix value. Thus, the matrix value can take one of at least three different range values, at a minimum. When larger range values such as “100” are employed, in a typical preferred embodiment, there will be many range values available to allow a more continuum-like indication of impact upon an attribute of interest arising from use of that proposed segment, or path.
Gridpoint 142 is also depicted as being entirely unavailable for both a single-wide and a double-wide trace. This is expressed by the respective matrix value range values (1, 100) for matrix 18. This is because gridpoint 142 is within the design rule keepout or spacing requirement for the depicted trace 16. The spacing requirement is typically determined by desired electrical properties of traces 16. For example, if the depicted trace 16 is 100 nm wide, the design rules may specify a spacing requirement that it be 100 nm from any neighboring trace. Suppose, for example, that the depicted gridlines are arranged to form a 100 nm pitch grid. In such a case, gridpoint 142 would be within 100 nm of trace 16, and is, therefore, blocked by the spacing requirement or spacing zone of trace 16. Gridpoint 142 is shown blocked for both single-wide and double-wide traces 16, as indicated by (1, 100).
The next gridpoint 143 is shown as having data structure or matrix 18 containing (0, 50). Such range values indicate, in this example embodiment, that gridpoint 143 is unblocked for use by a single-wide trace, and may, if the cost is acceptable, be employed for use with a double-wide trace. The indication of a relative cost of 50 in the n2 position of the cost matrix (n1, n2) indicates that, although it is not absolutely prohibited, use of a double wide trace at 143 will come with some impact. The character of that impact is determined by the weighting given to that site by an optimization tool.
The optimization tool is directed to assign a cost for particular sites or vertices 14n depending upon the relative values placed upon the attributes of interest such as manufacturability, reduced delay, and noise tolerance, for example. Preferably, when absolutely prohibited by prior use at that layer or the design rules, the maximum of the costing continuum of the matrix will be indicated. In this example, that number is 100. The number used to indicate complete prohibition is arbitrary, but expanding the range from 1 to 100 allows a finer gradation of cost to allow finer evaluation of attributes of interest such as reduced delay, noise tolerance or manufacturability, for example. Those of skill will note that other attributes of interest may be woven into the cost weighting, but reduced delay, noise, and manufacturability are the principal attributes of interest. The output of the optimization tool then becomes a label for a particular locus of the grid or a pin and that label is employed to find lower cost routes for particular connections.
The next gridpoint 144 is shown as having a cost matrix of (0, 10), indicating it is unblocked for use by both single-wide and has some, but minimal cost for use with double-wide traces. If a double-wide trace were to be routed along gridpoint 144, it would not overlap or violate the spacing requirement of the depicted trace 16. Also, the depicted trace 16 would not violate the spacing requirement of a double-wide trace if it were routed on gridpoint 144, assuming the required double-wide spacing is 150 nm. However, in this example, it will induce some noise impact if this exemplar trace is a high power trace and switching along trace 16 propagates disturbances some distance from trace 16.
The depicted method may be used to indicate and store in router data storage, data about a variety of different trace types and other shapes that may be placed on a grid 12 and their impact on proposed routes, paths or segments. The data is then used by search algorithms when finding routes for other traces. Those of skill will recognize that routers implement methods and algorithms with software that induces instructions for implementation of the desired method or algorithm. Those of skill will also recognize that the trace size and spacing used in this example are merely exemplary and it is expected that systems will use a variety of trace sizes and other shapes.
The upper depicted double-wide trace 221 is centered on vertical gridline 81 and therefore blocks gridline 81 and gridline 82 because gridline 82 is within the required 150 nm spacing for the trace 221. The first gridline 8 available for routing a single-wide or double-wide trace beside the upper depicted trace 221 is gridline 83. Because the upper depicted trace 221 is centered on gridline 81, it blocks not only gridline 81, but also the neighboring gridline 82 to its right and the corresponding neighboring gridline to its left (not shown). Thus three gridlines 8 are blocked by upper depicted trace 221.
In such a scheme, area may be wasted. The example grid size does not allow optimal spacing. To reduce the pitch of the gridlines, however, to achieve more optimal spacing may greatly slow down the routing program by significantly increasing the number of gridpoints searched.
The lower depicted double-wide trace 222 is placed according to a preferred method of the invention to help optimize space efficiency, or packing, without decreasing the pitch of the gridlines employed. The lower trace 222 is centered on an offset line 24. Line 24 is offset from gridline 82 by 100 nm. With such an offset location, the vertical portion of offset placed lower trace 222 blocks only two gridlines, 82 and 83, rather than blocking three gridlines. In this example, gridpoints 14 on gridline 81 beside offset lower trace 222 may be employed for routing a single-wide trace which is spaced at the correct 150 nm spacing from offset lower trace 222. Thus, the depicted method provides more efficiently spaced traces.
A proper offset distance may be determined for a particular shape such as, for example, a double wide trace, an analog trace, or other special trace, by shifting an outline of the shape with its associated spacing over a desired grid and determining which offset position blocks the smallest number of gridlines. Preferably, the offset position is determined in advance of the routing step. The offset position is preferably associated with a particular type of trace or shape being placed on a particular size grid. Some combinations of a grid and a shape will not have any offset distances that would unblock gridlines.
Offset lower double-wide trace 222 may be stored as a data structure having data fields for the type of trace, the route of the trace, and for the offset distance. In another embodiment, an offset distance may be predetermined for a particular shape on a particular sized grid. In such a case, the offset characteristic may be stored as a tag such as a one-bit tag indicating that the shape is offset, with no indication of the offset distance in the trace data structure.
In an embodiment of a preferred routing system embodiment of the invention, a trace to an offset pin 34 will be routed using a subgrid 32. In a preferred embodiment, a subgrid is generated and data of the subgrid that is unnecessary for a routing step is suppressed or deleted to increase router search efficiency.
The depicted routing grid 12 may have, for example, a 100 nm pitch. While the right-hand depicted pin 343 is on gridline 8 of routing grid 12, the two other depicted pins 341 and 342 are found to be off grid 12. Such a situation may arise when the position of a semiconductor device within an integrated circuit has constraints that do not allow optimal placement. The device having terminals at pins 34 may be, for example, a transistor disposed at a semiconductor layer beneath the metal trace layer for which routing is performed on the depicted routing grids 12 and 32. In this example, subgrid 32 is generated based on the inter-pin distance of pins 34 or it may be generated based upon the size “X” of a pin 34 as shown in
After generation of the subgrid, a shrink or poll is done to determine the data associated with subgrid 32 that is not needed by a particular connection to be routed. The unneeded data is suppressed or deleted. This increases the search speed in the subgrid area. Thus, only required data for a proposed connection is searched. This is done iteratively and data not necessary for routing the next connection is suppressed or deleted.
In use, a typical computer driven router employs a search algorithm that searches for routes on grids such as, for example, subgrid 32 and routing grid 12. A search typically proceeds outward from an origin point in wave fronts or “waves” evidenced by gridpoints labeled commonly from the origin. For example, those gridpoints equidistant from the origin are labeled with the same value to allow searching on the cost criteria of distance from the origin. For example, a wave propagated outward, from origin point “S” will result in labeling gridpoints that reside 1 grid unit from S with a value label of “1”. When the wave 1 points have been labeled, the search algorithm starts at each labeled wave 1 point and searches for unlabelled, and open, neighboring points which are then labeled wave 2. Many search algorithms consider a gridpoint adjacent only if it is along the “edge” of a grid square, between two gridpoints on the same gridline. Others may allow diagonal movement. The search typically proceeds until the destination point is labeled. This is known as a “maze search”.
Referring to
One technique, therefore, is to label gridpoints in a search with a “cost” that relates to distance. For example, subgrid 32 in
In some embodiments of the present invention, higher informational cost data may be incorporated into a wave or wave count evaluation to assess the impact one choice of route may have over another possible route for the same connection. As earlier alluded to, vertices on the grid (or subgrid) may be labeled with cost information implicit in which is an indication of adverse impact upon an attribute of interest (e.g., reduced delay, noise tolerance, manufacturability) for connections that employ that particular vertex.
For example, with reference to
Σliwi=terrain cost. (1)
The summation of equation 1 is taken from S to T. Equation 1 does not, however, include another cost of interest, namely, the shape cost which is an expression of the intrinsic impact on the attribute of interest by the shape selected for the connection or segment (e.g., single wide, double wide, triple wide trace). Thus, a preferred embodiment incorporates terrain cost, shape cost and segment length to develop a wave that allows more accurate assessment of the impact a particular route will have upon an attribute of interest. Thus, equation 2 expresses an incorporation of terrain costs, shape costs and segment lengths to render a more accurate cost assessment:
Σli(wi+si). (2)
Where the sum wi+si is the minimum sum of terrain and shape cost for allowed shapes for the segment li.
In some embodiments of the invention that employ equation 2, waves are spawned that express a more effective cost assessment. This method, although providing more information, can burden the computational engine of the routing system to result in slow routing.
Now, in the just described method, if li=1 for all l, then from S to T:
Σliwi=Σwi. (3)
An alternate preferred method employs, however, a less computationally demanding approach. It has been determined by the assignee that a router using an algorithm according to equation 4 below will typically select a route that would have been selected using equation 1 (i.e., the sum of the multiplications of length and weight).
Σwi+Σli. (4)
Where each of the summations is taken from S to T.
Although the literal cost for a route from S to T will differ between equations 1 and 4, cost figures are, as those of skill will recognize, arbitrary and only have meaning relative to another cost figure computed under the same scheme. Therefore, although the absolute magnitudes may differ between routing methods according to preferred embodiments that compute in accordance with either equations 1 or 4, lower cost routes can be identified by each while the preferred method of equation 4 will typically be faster.
A preferred method of the invention is exemplified with reference to
Thus, in the example of
Σ(wi+si)+Σli (5)
where as before, the sum wi+si is the minimum sum of terrain and shape cost of any shape that is allowed for segment li. Even with the more informational equation 5, search time is reduced from the more computationally demanding equation 2. As those of skill will recognize, there may be rare instances where use of the above described methodology with an equation 4 based router system will exhibit slightly longer or costlier paths but such methods have subsidiary benefits such as reduced bend count that likely compensate for such shortcomings.
Thus, a preferred embodiment of systems and methods in accordance with the present invention allows for the optimization of routes based on a plurality of attributes or criteria (e.g., reduced delay, noise, or manufacturing) that are expressed as costs for the shapes that may be used for routing a connection (through shape cost), as well as interaction of a selected shape with shapes of other connections (through terrain cost). These costs are additive and may be changed to emphasize one criterion or attribute over another. In some of the preferred systems and methods that employ these advantages, the cost function is modified to minimize the impact on run-time of a maze search without adversely impacting the optimality of the solution.
In the early stages of routing a particular integrated circuit design, for example, many large areas may be empty of routes or blocked gridpoints. In such a situation, a search algorithm may have to search large fields of unblocked gridpoints. Such a search will typically be much slower than the optimum possible search. To increase the speed of a search across a large field of unblocked gridpoints, a sparse routing grid may be applied over the routing grid 12.
Preferably, the sparse routing gridpoints 68 that are on the exterior of sparse routing grid 66 are considered, for searching purposes, to be adjacent to their neighboring gridpoints 14 that are outside of the area covered by sparse routing grid 66. For example, the depicted left-upper gridpoint 68 is adjacent to the two adjacent referenced gridpoints 14. Such a scheme allows a routing algorithm to search for a route on gridpoints 68, and continue searching on finer gridpoints 14 when the search reaches the exterior of sparse routing grid 68.
In this example, each step along sparse routing grid 66 may have a cost of 4. In such case, a step from the upper-left depicted gridpoint 68 to one of its adjacent points 14 has a cost of 1. The sparse routing grid 66 may, of course, have a different pitch, such as, for example, 2 times, 6 times, 8 times, or more of the pitch of rooting grid 12. For very large unblocked field 64, a larger pitch is preferred. The advantage in search speed may be readily understood from the depicted sparse routing grid, where four gridpoints 68 are searched to cover an area having 25 gridpoints 12.
With reference to
In one preferred embodiment of the present invention, a route search performs a global search for general areas through which the desired trace should be routed (Step 801). In this example, area 73 is blocked. The global routing step 801 chooses a global route having regions 74, 75, 76, and 79. Regions 74 and 79 are congested and therefore, tighter searching will be required in those regions.
In step 802 of the embodiment referred to by
In this example, regions 74 and 79 have multiple pins and several traces 77 already shown as having been routed therein. Regions 75 and 76, however, are determined to be sparse. Step 802 may search for unblocked regions that are subregions of a larger global routing region produced by step 801. The search of step 802 has, in preferred modes, a required size for each unblocked region that is selected to reduce the computational load for the search. For example, if a certain regions with 200 gridpoints edges would require more computations to create and employ a sparse routing grid than would a search of a normal routing grid, the normal routing grid would be employed. Another region may have edges larger than several thousand gridpoints. In such a case, step 802 may implement a sparse routing grid 66 to improve search efficiency because such a grid would be fester than the normal routing grid. Such size determinations may be pre-computed or selected for various trace types and grid size combinations.
In step 803, after spare areas or regions are identified, sparse routing grids 66 are applied over the identified, unblocked regions 75 and 76. Note that spare regions may overlap denser regions in a lower layer. Preferably, data structures for the sparse routing grids 66 exist simultaneously to allow search algorithms to complete entire traces in step 804. The search step 804 employs sparse routing grids 66 and normal routing grids 12 in combination as described with reference to
While routing on one layer is shown, those of skill in the art will understand, after appreciating this specification, that the techniques described herein are often applied across designs having more than one routing layer. For example, many integrated circuits have one or more metalized layers with a preferred horizontal trace direction, and one or more metalized layers with a preferred vertical trace direction. Routing algorithms frequently search for routes that span the various layers and are connected by vertical connection vias. Regions 75 and 76 may, for example, be on different layers.
In step 805, the routed traces resulting from search step 804 are stored in a database or data structure compatible with a normal routing grid 12. Such storage is preferably accomplished after each individual trace search is complete. In step 806, after routing the considered trace from 71 to 72, data structures for sparse routing grids 66 are preferably removed from the database or data structures store associated with routing grid 12.
Referring to
Several complexities place constraints on systems for implementing such a parallel processing scheme. For example, a routing search algorithm preferably should not use resources that may be used by another search algorithm operating in parallel. One such resource is the data structure holding “blocked/unblocked” information for a particular gridpoint. If one routing algorithm uses or blocks a gridpoint that is also used by a simultaneously-running routing algorithm, a flawed design may result. That is, the two traces produced by such a situation may violate an electrical rule or other design rule. Preferably, a parallel processing scheme does not require communication between processors as they work on their assigned parallel tasks.
The scheme depicted in
Step 1002 designates areas 94 and 98 to be processed during a second parallel processing period. The second period, is preferably subsequent to the first period. As can be seen, areas 94 and 98 are non-overlapping and non-adjacent. Area 94 overlaps area 92. Such overlap is preferable so that any traces which require routing in both area 92 and 94 can be divided into subtraces that meet at a common point inside the overlap area.
While areas are shown for processing in two processing periods, the concept may of course be extended to more than two processing periods. For example, one or more areas for processing in one or more additional processing periods could be placed in the scheme between area 94 and 96, with further areas placed to the right of area 98. Another examples of such a scheme is depicted in
Step 1003 determines the presence of multi-area traces and divides them into subtraces 93. Example multi-area traces 93 are shown, having endpoints at virtual pins 95 in the overlap area. Step 1003 determines the location of virtual pins 95, typically before the search for a route in any particular area. Step 1003 may, in some embodiments, be integrated with a global routing search phase. One such embodiment is described in more detail below with reference to
Step 1004 performs route searches for traces in areas 92 and 96 simultaneously. For example, subtrace 93A is routed in step 1004. Subtrace 93A is the portion of the lower depicted trace 93 between its origin point 91 and virtual pin 95. Also routed in step 1004 are traces 97 that are entirely within area 92 or area 96. There is no trace 97 in area 96 in
In a preferred embodiment, a separate processor searches for routes for each of areas 92 and 96. The processors run in parallel. Such processors are preferably coupled to a common memory which contains database structures for storing completed traces. Such storage is sometimes referred to as “trace storage” or “wire storage”. The parallel-running processors may be part of multiprocessor computer systems, may be in separate computer systems, or may, for example, be processor cores arranged on a common integrated circuit. Other structures for processing algorithms in parallel and combinations of any suitable parallel processing structures may be used.
Step 1005 performs route searches for traces and subtraces in areas 94 and 98 simultaneously. The depicted traces in
The depicted three-period scheme is only exemplary and other embodiments may have two or more than three periods. Further, while routing grids are shown in some examples herein, the described parallel processing scheme may be implemented to advantage on systems that do not employ routing grids.
Referring to
In this embodiment, a global routing system begins the process of finding routes for the required traces and performs a global routing search for routes in step 1301 (
Step 1302 begins detailed searching for a particular global routing area having a set of traces for which routes must be found. Step 1303 applies sparse grid techniques such as those described with reference to
Step 1304 applies other grid modification techniques such as, for example, a detailed subgrid which may be employed in area 1224 to route connections to pins that may be offset from the routing grid 12. Step 1304 similarly may produce temporary modified grid structures on which a search algorithm may search for a route portion as it finds the original mute for a particular trace or subtrace. Subtraces are, in many embodiments, treated exactly as traces are treated by search algorithms.
Step 1305 divides the global route being processed into parallel processing areas. For example, areas 1218 and 122 may be designated as first parallel processing period areas, and areas 1220 and 1224 may be designated as second parallel processing period areas. Step 1305 preferably makes minor adjustments in the boundaries of the areas to obtain proper overlap so that virtual pins may be placed in an overlap area accessible during processing of each adjacent area. Preferably, the overlap area is at least two grid squares wide to allow for placement of virtual pins in the middle of the area. For example, in the overlap area 1226 of areas 1218 and 1220, the top row of sparse routing grid squares is present with the bottom row of normal routing grid squares from the routing grid in area 1220.
Step 1305 further assigns locations for virtual pins at which subtraces are terminated. Such assignment may be accomplished by a track assignment scheme such as that described with reference to
Step 1306 performs parallel processing for the various areas according to techniques such as those described with reference to
Step 1307 checks for global route sets which may need routing. In this example, the set traces in global routing area 1216 also require routing, so the process returns to step 1302 to route the connections in global routing area 1216.
In a preferred method of this embodiment, a routing system detects such a situation and applies a shift to the gridlines. The shift is depicted as a shifted distance 148, which movies gridlines 8 to new gridline locations 149. The shift is preferably applied only locally, but may be applied to the entire gridline. Various methods may be used to implement the shift, such as, for example, adding offsets to all traces in the area, or changing recorded coordinates of the affected gridlines.
In such a situation, it is beneficial for electrical noise performance to increase the spacing between each trace. This can be accomplished by spreading the extra space taken by the two empty gridlines among the remaining traces. If the six traces are ail of the same size and type, the space is preferably divided equally. If any traces have more stringent requirements for electrical noise, those may, in some embodiments, be given a larger allotment of space.
The resulting arrangement is shown in
Although the present invention has been described in detail, it wall be apparent to those skilled in the art that many embodiments taking a variety of specific forms and reflecting changes, substitutions and alterations can be made without departing from the spirit and scope of the invention. The described embodiments illustrate the scope of the claims but do not restrict the scope of the claims.
This application is a Divisional of U.S. patent application Ser. No. 11/148,911, filed Jun. 9, 2005, which application is hereby incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
Parent | 11148911 | Jun 2005 | US |
Child | 12062363 | US |