US6678874B1 - Computer-aided design (CAD) tool - Google Patents
Computer-aided design (CAD) tool Download PDFInfo
- Publication number
- US6678874B1 US6678874B1 US09/997,025 US99702501A US6678874B1 US 6678874 B1 US6678874 B1 US 6678874B1 US 99702501 A US99702501 A US 99702501A US 6678874 B1 US6678874 B1 US 6678874B1
- Authority
- US
- United States
- Prior art keywords
- pcb
- signal path
- computer
- data files
- board
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime, expires
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/39—Circuit design at the physical level
- G06F30/394—Routing
Definitions
- This invention relates generally to the design of computer systems and, more particularly, to computer aided design (CAD) tools.
- CAD computer aided design
- a printed circuit board (also referred to as a printed wiring board (PWB), or a PC Laminate (PC Lam)) provides a mechanism for implementing a circuit design (i.e., the interconnection of electrical devices and components) for use, e.g., in the design of a computer system.
- a PCB may be “single layer,” “double layer,” or “multi-layer”—each of which refers to the number of electrically conductive layers.
- a multi-layer board bonded together. Typically, holes (or through-holes) are drilled through a PCB and are subsequently coated, or plated, with a conductive substance (forming “vias”) for the purpose of connecting signal paths on different conductive layers together.
- CAD computer-aided design
- a CAD tool in designing a computer system comprising a number of PCBs, a CAD tool generates data files, or output files, for each of the PCBs and processes the PCB data files for taking into account a system-level design parameter.
- a CAD tool takes into account signal path length at the system-level for a computer system comprising N PCBs, where N>1.
- the CAD tool processes at least N board-related data files comprising layout, layup and signal path routing information for each PCB for determining if a system-level requirement for overall signal path length is met for at least one signal path.
- a CAD tool takes into a physical orientation of signal paths as the signal paths traverse a computer system comprising N PCBs, where N>1.
- the CAD tool processes at least N board-related data files comprising layout and signal path routing information for each PCB for creating a three-dimensional (3D) picture for showing how at least one signal path traverses the computer system in going from one PCB to another PCB.
- FIG. 1 shows a high-level flow chart of a prior art PCB design approach using CAD tools
- FIG. 2 shows illustrative prior art file information found in a design-type file
- FIG. 3 shows illustrative prior art file information found in a routing-type file
- FIG. 4 shows an illustrative diagram embodying the principles of the invention
- FIG. 5 shows an illustrative flow chart in accordance with the principles of the invention
- FIG. 6 shows another illustrative diagram embodying the principles of the invention
- FIGS. 7-17 show illustrative file formats in accordance with the principles of the invention.
- FIG. 18 shows another illustrative flow chart in accordance with the principles of the invention.
- FIG. 19 shows another illustrative flow chart embodying the principles of the invention.
- FIG. 20 shows an illustrative file format in accordance with the principles of the invention.
- FIG. 21 shows an illustrative 3D view
- FIG. 22 shows an illustrative block diagram of a machine for use in accordance with the principles of the invention.
- inventive concept is described in the context of a computer system comprising a number of PCBs. However, the details of the computers system and the PCBs are irrelevant to the invention and, as such, are not described herein.
- computer program product represents any mechanism for storing a computer program, e.g., a floppy diskette; a CD-ROM; a file, or files, in compressed and/or uncompressed from, representing the computer program; etc.
- machine refers to any stored-program-control processor-based equipment, e.g., a personal computer, work station, etc.
- inventive concept is implemented using conventional programming techniques, which are also not described herein.
- FIG. 1 shows an illustrative high-level flow chart of an existing PCB design approach using CAD tools for an illustrative computer system (not shown) comprising a number of PCBs (not shown).
- CAD tools for use in FIG. 1 are: Cadence Concept®, Cadence Allegro®, Cadence SPECCTRA®, and the CAD tool suite Mentor Graphics Board Station®.
- step 10 a schematic (not shown) of a PCB design is captured for performing operations such as physical board definition (e.g., the number of layers, thickness, etc.) and component placement (physical layout).
- one or more output files are produced as represented by PCB design file 11 .
- a portion of design file 11 comprises overall dimensions information 80 and a component location list 81 , which identifies each component on the PCB (by a predefined name), its x and y location (with respect to a predefined reference point, e.g., the lower left corner of the PCB), and what surface of the PCB the component is located on (e.g., top or bottom).
- this output file is in an ASCII (American Standard Code for Information Interchange) format.
- step 20 routing for the signal paths on the PCB is performed in step 20 .
- step 20 produces one or more output files as represented by PCB routing file 21 .
- the latter (like PCB design file 11 ) is typically in an ASCII format.
- Routing file 21 provides a two-dimensional view of the signal path routing on each layer of the PCB for each signal.
- routing file 21 includes “net” and “wire” information for each signal on the PCB.
- a “net” is associated with each signal and is represented by a predefined name (i.e., the signal name).
- a net comprises a number of “wires,” where each wire can be thought of as representing the actual signal path between components and/or vias on a particular layer of the PCB.
- FIG. 3 This is illustrated in FIG. 3 on PCB 90 , where 3 “wires” of a “net” are shown. In this example, each wire is between two vias. Thus, a “net” is the total series of wires across all layers of the PCB for a particular signal.) An illustration of information typically found in a routing file is shown in FIG. 3 .
- each net there is net name information 70 , in this illustration a signal named “NF$ 19 .”
- each net comprises wire information 71 , which lists, for each wire, the layer this particular signal path is on (here the layer associated with the name “SIGNAL_ 1 ) the width of the trace (or etching), and a sequence of x, y coordinates that trace the path of the wire (in this example, only two pairs of x, y coordinates are shown).
- dimension information is provided in routing file 21 in, e.g., tens of nanometers.
- connect field 73 which identifies, for the starting and ending x, y pairs of wire information 71 , the type of connection for this wire (in this example, between a via and a surface mount device (smd) identified as U100-1).
- steps 10 and 20 may be iterative in nature. For example, it may be the case that step 20 cannot route particular signals given a particular component placement on the PCB as represented in PCB design file 11 . In this case, component placement may have to be altered again in step 10 , thus producing a new PCB design file 11 for use in another pass through step 20 for routing the signals.)
- step 20 may be iterative in nature. For example, it may be the case that step 20 cannot route particular signals given a particular component placement on the PCB as represented in PCB design file 11 . In this case, component placement may have to be altered again in step 10 , thus producing a new PCB design file 11 for use in another pass through step 20 for routing the signals.
- each PCB output file such as PCB routing file 21
- PCB routing file 21 is specific only to that particular PCB. Consequently, it may subsequently be discovered that an existing PCB—e.g., one already designed and manufactured according to PCB routing file 21 —in fact contributes to the computer system exceeding a system-level design parameter—with the result that the existing PCB may have to be manually re-worked and/or re-designed.
- a CAD tool in designing a computer system comprising a number of PCBs, a CAD tool generates output files for each of the PCBs and processes the PCB output files for taking into account a system-level design parameter.
- a system-level design parameter e.g., one or more PCB output files cause the resulting system to exceed a system-level design requirement—this may be detected earlier in the design process—before any PCBs are actually built.
- a CAD tool takes into account signal path length at the system-level for a computer system comprising N PCBs, where N>1.
- the CAD tool processes at least N board-related data files comprising layout and signal path routing information for each PCB for determining if a system-level requirement for overall signal path length is met for at least one signal.
- overall signal path length for the computer system may be of critical importance because of concerns related, but not limited to, time delay (signal propagation), signal rise times, electrical impedance matching, etc.
- a particular signal bus may have a maximum allowed signal path length, which corresponds to a maximum allowed time delay. (Conversion of a time delay into equivalent signal path length is known in the art and not described herein.)
- a signal bus i.e., a group of signal paths
- FIG. 4 an illustrative diagram embodying the principles of the invention is shown. Like numbers indicate like elements and will not be described further. Turning first to steps 10 and 20 (as described above), for each of the N PCBs of the computer system a routing file is produced resulting in a routing files collection 645 . These files are processed by system length program 30 (described below), which produces length report files 695 .
- FIG. 5 An illustrative flow chart for use in system length program 30 , and embodying the principles of the invention, is shown in FIG. 5 . It is assumed that system length program 30 executes on, e.g., a work station. It should be recalled that a PCB routing file comprises net information for each signal on the PCB. For the purposes of this description, it is assumed that identical signals have identical signal (net) names on each PCB of the computer system. Thus, a signal (net) name of “clock_ 1 ” in the routing file of one PCB would also appear in the routing file of other PCBs of the system that use that clock signal.
- step 205 data from the above-mentioned routing files collection is read into, e.g., a memory of a work station (not shown in FIG. 5 ).
- step 210 system length program 30 steps through the data (i.e., processing data associated with each PCB) to calculate a PCB-specific signal path length for each net on each PCB using the associated wire information (the sequence of x, y coordinates).
- System length program 30 determines for each PCB a collection of signal (net) names and their associated PCB-specific signal path lengths. Then, for those signal names that are identical across the PCBs, those PCB-specific signal path lengths are combined to provide a system-level signal path length across the computer system.
- a signal, NF$ 19 appears on a PCB 90 and a PCB 95 .
- the total PCB signal path length of NF$ 19 on PCB 90 is calculated and, then, for PCB 95 the total PCB signal path length of NF$ 19 on PCB 95 is calculated.
- step 215 checks if any signal exceeds its predefined maximum system length. (The latter is determined empirically for a particular system design, or from, e.g., device manufacturers specifications for particular signals (e.g., via time delay requirements). Thus, different signals may have different associated predefined maximum lengths.
- Such a table of predefined maximum length values and associated signal names is stored in a memory (not shown) for use by system length program 30 .) If a signal is determined to exceed its associated predefined maximum system length in step 215 , then a suitable error message (e.g., identifying the signal, its length by PCB, its system length, and the predefined maximum system length for that signal) is displayed in step 220 (e.g., on a display of the work station).
- a suitable error message e.g., identifying the signal, its length by PCB, its system length, and the predefined maximum system length for that signal
- a length report file 695 is provided in step 225 , where the length report lists, e.g., for each signal (net) name the associated rough approximation of system signal path length.
- Suitable exception handling can be added to system length program 30 to handle, e.g., those signals for which there is no limitation to system signal path length, etc.
- time delays can be directly associated with signals and, instead of checking if electrical lengths are exceeded, equivalent calculations can be performed in the time domain such that, in step 215 , a calculated time delay for a signal is compared to a predefined time delay limit.
- the flow chart of FIG. 5 can be modified to include checking for signal path length tolerances in a signal bus (as mentioned above).
- the above-described method provides a rough approximation of system signal path length—basically just including the foil lengths on the various layers of each PCB.
- this method can be further improved to include such items as, but not limited to, connector pin lengths, device (e.g., integrated circuit (IC)) bonding lengths, via lengths, etc.
- FIG. 6 another illustrative diagram embodying the principles of the invention is shown. Like numbers indicate like elements and will not be described further. Turning first to steps 10 and 20 (as described above), for each of the N PCBs of the computer system a design file and a routing file are produced resulting in a design files collection 650 and a routing files collection 645 .
- a number of other files are created utilizing data collected, e.g., from each of the PCB board designers, in step 635 .
- the created files are in ASCII format and each is described below.
- a package length information file is typically associated with a particular type of device package and provides the ability to associate a bonding length with a particular pin of a device. It is assumed that there is a mapping (not shown) of component (device) names (as listed in a design file) to a particular package type.
- a connector pin length information file is typically associated with a particular type of electrical/physical connector and provides the ability to associate a length with a particular pin of a connector.
- PCB-specific signal path length calculations include not only any foil lengths on the various layers of a PCB, but also any length added by pins of individual device packages and associated connectors that are also coupled to the signal, etc. Whether or not a particular type of package or connector is of concern in determining a signal path length is a subjective design decision. As such, the inclusion of files of this type is not required. However, as system speeds continue to increase, parameters that previously could be ignored—may need to be considered.
- FIG. 7 An illustrative format for a package length information file 665 - 1 is shown in FIG. 7 .
- This file comprises a units field 306 (e.g., identifying the measurement type for any provided measurement values); a number of pins field 307 , the value of which, p, is the number of pins associated with this package; and pin array field 308 .
- the latter comprises at least a two dimensional array having at least 2 columns and p rows. Each row of the array comprising a pin identifier and an equivalent electrical length.
- an actual package length information file is shown in FIG. 8 . It should be noted that equivalent electrical length values are calculated using known techniques (not described herein) and represent the device bonding lengths associated with this particular package.
- FIG. 9 An illustrative format for a connector pin length information file 665 - 2 is shown in FIG. 9 .
- This file comprises a units field 406 (e.g., identifying the measurement type for any provided measurement values); a number of rows field 407 , the value of which, r, is the number of rows associated with this connector; and row array field 408 .
- the latter comprises at least a two dimensional array having at least 2 columns and r rows, where each row further comprises a row identifier and an equivalent electrical length.
- each pin of a connector could also be identified. However, it is often the case that rows of pins, each row comprising m pins, share the same electrical length. Hence, the simplification of this file to just identifying connector rows.
- a board layup file Another type of file is referred to as a “board layup” file.
- the latter file is typically associated with a particular type of PCB and provides information comprising the number of layers, thickness of each layer, line width used on each layer and associated electrical impedance. Whether or not a particular type of PCB is of concern in determining signal path lengths is a subjective design decision. As such, the inclusion of files of this type is not required. (It should be noted that this file provides more detailed information than the above-mentioned PCB design file.)
- FIG. 11 An illustrative format for a board layup file 660 is shown in FIG. 11 .
- This file comprises, essentially, a table of information, where each row comprises fields for identifying the layer 451 , the thickness 452 , the layer number 453 (it should be observed that layer numbers are only associated with the conductive layers), the layer name 454 , the line width 455 (again, only for those conductive layers of interest), and the electrical impedance 456 characteristic for the layers.
- summary information 457 comprising the total width of the board, and a legend for use in the layer column for identifying the various types of layers.
- an actual board layup file is shown in FIG. 12 .
- the layer name is identical to the associated layer name used in the respective PCB routing file.
- Another type of file is a system configuration file.
- the latter file is typically associated with a particular connecting-board, e.g., a backplane, or midplane, etc., into which other PCBs are inserted.
- This file provides physical configuration information for the system that, as described below, enables the tracing of a particular signal path through out the system. In other words, this file describes how the various PCBs of the computer system “fit together.”
- System configuration file 655 comprises at least one connecting-board name 101 (representing the connecting-board, which comprises a number of slots into which various ones of the PCBs are inserted or plugged).
- connecting-board name 101 is also illustratively a PCB (although this is not required).
- each connecting-board name there is associated a board list 102 (i.e., the boards inserted into this connecting board) (described below), a connector map filename (which points to the file comprising additional connector information), a netsfile name (which provides groupings for signal paths in the computer system), and a filename associated with the board layup file (described above) for this connecting-board.
- a board list 102 i.e., the boards inserted into this connecting board
- a connector map filename which points to the file comprising additional connector information
- a netsfile name which provides groupings for signal paths in the computer system
- a filename associated with the board layup file (described above) for this connecting-board.
- k board type records there are k board type records, where k ⁇ N.
- 3 may be identical types and plugged into different slots of the connecting-board.
- Board list 102 comprises j records, where each record is associated with a PCB inserted into the connecting-board and j ⁇ N. (It can be observed that j is less than N in this example since the connecting-board itself is one of the N PCBs).
- Each record comprises a board type identifier, the name of the connector group into which the board for this record is inserted, the pin depth for this connector group and an identifier (for ease of reference) of the associated connector.
- connector group is similar to board type, i.e., there may be 4 connectors (having different identifiers) that are located at different points of the connecting-board and that are of the same type, i.e., connector group, in the computer system.)
- Each board type record comprises information related to calculating critical lengths and comprises one, or more, of the following.
- Connector information comprising the name of the connector group that is used on the board, the associated pin depth for this connector group and an identifier (for ease of reference).
- Length information comprising any associated length information files (described above) along with an associated identifier (for ease of reference).
- an associated board layup file (described above).
- FIG. 15 a portion of an actual system configuration file is shown in FIG. 15 .
- the connecting-board (Board) name is “cas_mp_ 3 _ 14 _ 01 .”
- the board list indicates four boards (SubBoards) plugged into it.
- the first board record identifies a board of type “cas_uhen_re 14 a” inserted into connector group (ConGroup) “Uhen_CG 1 ” having a pin depth of 0.03 inches and actually inserted into connector associated with the identifier “UHENO.” It can be observed from the remaining entries in the board list that there is another board of type “cas_ohm_re 14 a” inserted into the connector associated with the identifier “UHEN 1 ”, that there are two boards of type “lion_black_box” inserted into connectors identified as “LION 0 ” and “LION 1 ,” and that there are two boards of type “cas_ujkl_rel 17 b” inserted into connectors identified as SPSMO and SPSM 1 , respectively.
- the connector map (ConMap) file is “Ujkl_conn_map.txt” (which, in this example, relates to the connectors identified as SPSMO and SPSM 1 , as shown by dotted line 53 ), the netsfile file name is “cas_mp_netList.txt,” and the board layup file (Layup) associated with this connecting-board is “cas_mp_layup.txt.”
- Two board type records are also illustrated in FIG. 15, as shown by dotted lines 51 and 52 , one for the “cas_uhen_re 14 a” board and one for the “lion_black_box” board.
- Each “cas_uhen_re 14 a” board has a connector of type “Uhen_CG 1 ” with a pin depth of 0.03 inches associated with plugging into the mid-plane (here represented by the associated identifier MIDCNT).
- a connector pin length (Conlen) file “Vhdm 8 _conn_len.txt” also associated with the mid-plane, re: MIDCNT
- a board layup file “cas_uhen_layup.txt” are indicated.
- a board layup file may not exist, e.g., because one is not deemed necessary, or the information required to create one is not available. The latter situation would occur, e.g., if the computer system used a board manufactured by another vendor, for which there is no detailed PCB information.
- the netslist file is used to group signals of interest for the system. For example, a listing of the clock signals, and/or data signals, and/or address signals, etc. It should be noted that the signal names used should, preferably, be the same ones used by the above-mentioned design file and routing file.
- FIG. 16 An illustrative format for a netslist file 670 is shown in FIG. 16 .
- This file comprises, essentially, at least one grouping-of signal-related information, each group comprising a group name 471 and a list of signals 472 associated with that group.
- FIG. 17 a portion of an actual netslist file is shown in FIG. 17 .
- system length program 680 processes the various above-mentioned files (and illustrated in FIG. 6) to determine if a particular signal path exceeds a predefined signal path length for the system.
- Like numbers indicate like elements and are not described further. (It should be observed that either a consistent naming approach must be enforced across the system for identifying signal names, connector pins, etc., (e.g., a design engineer is required to use predefined signal names if they already exist); or mapping information (e.g., a conversion table) must be provided that allows one to associate a particular signal name on one PCB to its corresponding name on other PCBs. Similarly, it is assumed that each routing file identifies connector information consistently. For example, as a signal path exits a PCB to a particular-pin of a connector, that connector/pin identification is consistent through the computers system or, via a mapping process, can be converted from one identifier/label to another.)
- system length program 680 reads system configuration file 655 . For each signal name identified in the associated netsfile, system length program 680 accumulates signal path length information. In particular, system length program 680 accumulates PCB-specific signal length information from routing files collection 645 (as described earlier) for each named signal path (i.e., from the associated netsfile). In addition, system length program 680 examines for each identified board in board list 102 , of the system configuration file, the associated board type information for calculating additional signal path length values for those named signals from any identified connector information (e.g., associated pin length), length file(s) and/or board layup file.
- any identified connector information e.g., associated pin length
- system length program 680 adds any additional signal path length value due to the identified connector group (e.g., the associated pin depth) for those named signals.
- the identified connector map information is processed.
- the board layup file for the connecting board itself is processed for any additional signal path length values.
- design files collection 650 provides additional information for use in calculating additional length value increments for any components (devices) associated with a particular package, e.g., the x, y location of a component and whether the component is on the top or bottom of a particular PCB.
- the above-mentioned process provides—for a particular signal—the ability to take into account signal path length across the entire system. For example, from each PCB routing file (of routing files collection 645 of FIG. 6) it can be determined if the particular signal has a net on that PCB and the x and y information is used to determine signal path length. Further, from each PCB layup file (of board layup files 660 ) the width of various layers of the PCB is taken into account. Similarly, length information files 665 takes into account connector information and device length. Finally, system configuration file 655 provides the information as to how the PCBs are arranged in the system and netsfile 670 provides the signal names of interest.
- step 215 checks if any signal exceeds its predefined system length. If a signal is determined to exceed its associated predefined system length in step 215 , then a suitable error message (e.g., identifying the signal, its length by PCB, its system length, and the predefined system length for that signal) is displayed in step 220 (e.g., on a display of the work station).
- a suitable error message e.g., identifying the signal, its length by PCB, its system length, and the predefined system length for that signal.
- a length report file 695 is provided in step 225 , where the length report lists, e.g., for each signal (net) name the associated rough approximation of signal path length.
- Suitable exception handling can be added to system length program 30 to handle, e.g., those signals for which there is no limitation to system signal path length, etc.
- other statistical data can also be presented, such as, but not limited to, the average system length computed across all signal paths in a particular group, the maximum length, the minimum length and any delta for the group.
- a CAD tool takes into account a system-level design parameter, where the system-level design parameter represents a physical orientation of at least one signal path as the signal paths traverse a computer system comprising N PCBs, where N>1.
- the CAD tool processes at least N board-related data files comprising layout and signal path routing information for each PCB for creating a three-dimensional (3D) picture for showing how at least one signal path traverses the computer system in going from one PCB to another PCB.
- Such a capability is important in those systems where, e.g., as a signal bus moves from one PCB to another PCB, the signal bus cannot use “routing vias” (i.e., there is a predefined tolerance on the amount of physical “twist” in the signal paths).
- a “routing via” (where a signal path moves from one layer to another) is different from a “breakout via” (where the signal path moves from, e.g., an IC to a layer.
- a twisting requirement is tied to desired signal propagation characteristics and minimum skew requirements for the signal.
- FIG. 19 An illustrative diagram of a CAD tool providing a spatial view of signal paths in a computer system comprising N PCBs, where N>1, is shown in FIG. 19 .
- Like numbers indicate like elements and will not be described further. Familiarity with the known Virtual Reality Modeling Language (VRML) 2.0 using the UTF- 8 character set is assumed.
- VRML provides an easy-to-use syntax for defining lines, both as to their starting point, endpoint, width and orientation in an x, y, z axis (three dimensional (3D)). As can be observed from FIG. 19, a number of VRML files are created.
- VRML player 600 for the purpose of displaying, e.g., on a display of a computer system, a 3D representation of the computer system, both as to board placement and as to individual signal paths as they traverse the computer system.
- a particular signal or groups of signals
- One illustration of a VRML player is Microsoft Internet Explorer 5.0 configured with the Cosmo Player 2.1.1 plug-in, which is a free download for Windows-based platforms available from http://www.cai.com/cosmo.
- a board layout VRML file is created for each PCB of the computer system. This is created manually (element 615 ) and uses the length, width and thickness information from each PCB design file. Similarly, for each connector, a VRML connector file is created manually and uses available length, width and thickness information. (Other than the inventive concept, both a board layout VRML and a VRML connector are, in effect, representations of 3D polygons, e.g., a 3D rectangle, the creation of which from length, width and thickness information is known in VRML.)
- the system length program 680 (described with respect to FIG. 18) is modified to provide a set of VRML wires files for each named signal (netlist file 670 ).
- VRML wires file 690 - 1 A portion of an illustrative VRML wires file 690 - 1 is shown in FIG. 20 .
- VRML wires file portion 690 - 1 comprises a VRML macro definition 690 - 2 , which, other than the inventive concept, is know in the art and not described herein.
- system length program 680 traces each signal through the computer system, it builds up the VRML wires file. For example, as the system length program 680 operates on a particular board (board cas_clk is illustrated in FIG.
- system length program 680 converts any x, y and z information into appropriate VRML commands as illustrated in FIG. 20 .
- the linelocation and linesize entry values represent the midpoint of that particular line segment.
- the lineangle entries provide rotation information.
- FIG. 21 An illustrative 3D view (of a portion of a server) that can result from the above-described CAD tool is shown in FIG. 21 .
- the latter shows an outline of a midplane 910 comprising at least two connectors 911 and 912 .
- Board 915 (as illustrated by its outline) is inserted into connector 912
- board 905 (as illustrated by its outline) is inserted into connector 911 .
- On board 915 is ASIC 955 (as illustrated by its outline), while ASIC 950 (as illustrated by its outline) is on board 905 .
- a visual image is provided for the signal paths going from ASIC 955 to ASIC 950 , via route 902 (on board 915 ), route 901 (on midplane 910 ) and route 903 (on board 905 ).
- the inventive concept provides an efficient mechanism to validate early in the design process whether various components of a system, when virtually combined in three dimensions, cause the system to not conform to a system-level design requirement.
- Work station 50 comprises an application 60 (which executes, e.g., the flow charts described above) residing on a computer platform 55 , which is a stored-program-control based processor architecture including a processor, memory, display, keyboard, etc. It should be noted that the information in the above-described PCB-specific files can be compiled into a memory mapped file by application 60 (versus accessing, e.g., a hard disk for each and every file access).
- This provides fast access to the information—thus saving time when application 60 is re-executed to, e.g., re-compute a signal path length.
- Application 60 updates theses PCB-specific files only when information has changed, which, e.g., is detected by examining the system time and date stamp of the PCB-specific files.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Evolutionary Computation (AREA)
- Geometry (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
Description
(1) | 3d_system.wrl |
Proto definitions | |
View section for the system | |
Midplane outline | |
Container for midplane route data | |
References to Connectors and boards that plug input the | |
midplane, |
and has containers for each boards route data | |
See (2) and (3) |
Code use to load and unload route file, and references to routes |
files | |
See (6) |
DialogBox and Buttons for bus selections | |
DialogBox and Buttons for Board selections |
(2) | Board_data_xxx.wrl Files-( xxx = board name ) |
View section for the board | |
Board outline | |
Reference to the board connector Connector_xxx_bd.wrl |
See (4) |
Reference to the board asic Asic_xxx.wrl |
See (5) |
(3) | Connector_xxx_mp.wrl Files-( xxx = board name, connector for the |
midplane) |
Proto definitions | |
View section for the connector | |
Connector outline | |
Connector pin layout section |
(4) | Connector_xxx_bd.wrl Files-( xxx = board name, connector for the |
board) |
Proto definitions | |
View section for the connector | |
Connector outline | |
Connector pin and Guide layout section |
(5) | Asic_xxx.wrl Files-( xxx = board name that asic is used on, currently |
only one per board ) |
Proto definitions | |
View section for the asic | |
Asic outline | |
Asic pin layout section |
(6) | Wires_xxx.wrl Files ( xxx = group name ) |
Proto definitions | ||
board route data | ||
Claims (16)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/997,025 US6678874B1 (en) | 2001-11-28 | 2001-11-28 | Computer-aided design (CAD) tool |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/997,025 US6678874B1 (en) | 2001-11-28 | 2001-11-28 | Computer-aided design (CAD) tool |
Publications (1)
Publication Number | Publication Date |
---|---|
US6678874B1 true US6678874B1 (en) | 2004-01-13 |
Family
ID=29780837
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/997,025 Expired - Lifetime US6678874B1 (en) | 2001-11-28 | 2001-11-28 | Computer-aided design (CAD) tool |
Country Status (1)
Country | Link |
---|---|
US (1) | US6678874B1 (en) |
Cited By (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030135829A1 (en) * | 2002-01-17 | 2003-07-17 | Srinivas Garrepally | Methodology of creating an object database from a Gerber file |
US20030179232A1 (en) * | 2002-03-25 | 2003-09-25 | Fousek Daniel P. | Custom drawing symbols |
US20040068557A1 (en) * | 2002-10-02 | 2004-04-08 | Renesas Technology Corporation | IP (Intellectual Property) generating system |
US20050241168A1 (en) * | 2004-04-29 | 2005-11-03 | Iannuzzelli Raymond J | PWB warp gauge |
US20080082949A1 (en) * | 2006-10-01 | 2008-04-03 | Dell Products L.P. | Method, Apparatus and Media for Updating CAD Data with Printed Circuit Board Stencil Data |
US7409667B1 (en) * | 2005-12-15 | 2008-08-05 | Emc Corporation | Techniques for modeling a circuit board structure |
US7721235B1 (en) * | 2006-06-28 | 2010-05-18 | Cadence Design Systems, Inc. | Method and system for implementing edge optimization on an integrated circuit design |
US20110299782A1 (en) * | 2009-12-02 | 2011-12-08 | Qualcomm Incorporated | Fast subspace projection of descriptor patches for image recognition |
US20120042297A1 (en) * | 2010-08-16 | 2012-02-16 | Hon Hai Precision Industry Co., Ltd. | Computer aided design system and method |
CN102750419A (en) * | 2012-06-27 | 2012-10-24 | 西安理工大学 | Subway comprehensive pipeline aided design system and method |
US8438524B1 (en) | 2009-12-30 | 2013-05-07 | Cadence Design Systems, Inc. | Hierarchical editing of printed circuit board pin assignment |
US9390216B2 (en) * | 2014-10-20 | 2016-07-12 | Oracle International Corporation | System and method for obstacle-avoiding signal bus routing |
US9530073B2 (en) | 2010-04-20 | 2016-12-27 | Qualcomm Incorporated | Efficient descriptor extraction over multiple levels of an image scale space |
US9633163B1 (en) * | 2015-01-05 | 2017-04-25 | Cadence Design Systems, Inc. | System and method for displaying routing options in an electronic design |
US11028584B2 (en) | 2018-04-18 | 2021-06-08 | Christie Lites Enterprises Canada Inc. | Connection apparatus and method |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5109479A (en) * | 1989-09-07 | 1992-04-28 | Amp-Akzo Corporation | Method of designing three dimensional electrical circuits |
US5111362A (en) * | 1990-09-18 | 1992-05-05 | Intel Corporation | Enclosure assembly with two identical covers having modifiable supports for asymmetrically housing a printed circuit board or the like |
US5666516A (en) * | 1993-12-16 | 1997-09-09 | International Business Machines Corporation | Protected programmable memory cartridge having selective access circuitry |
US5825630A (en) * | 1996-11-07 | 1998-10-20 | Ncr Corporation | Electronic circuit board including a second circuit board attached there to to provide an area of increased circuit density |
-
2001
- 2001-11-28 US US09/997,025 patent/US6678874B1/en not_active Expired - Lifetime
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5109479A (en) * | 1989-09-07 | 1992-04-28 | Amp-Akzo Corporation | Method of designing three dimensional electrical circuits |
US5111362A (en) * | 1990-09-18 | 1992-05-05 | Intel Corporation | Enclosure assembly with two identical covers having modifiable supports for asymmetrically housing a printed circuit board or the like |
US5666516A (en) * | 1993-12-16 | 1997-09-09 | International Business Machines Corporation | Protected programmable memory cartridge having selective access circuitry |
US6173358B1 (en) * | 1993-12-16 | 2001-01-09 | International Business Machines Corporation | Computer system having dual bus architecture with audio/video/CD drive controller/coprocessor having integral bus arbitrator |
US5825630A (en) * | 1996-11-07 | 1998-10-20 | Ncr Corporation | Electronic circuit board including a second circuit board attached there to to provide an area of increased circuit density |
Cited By (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6920624B2 (en) * | 2002-01-17 | 2005-07-19 | Seagate Technology, Llc | Methodology of creating an object database from a Gerber file |
US20030135829A1 (en) * | 2002-01-17 | 2003-07-17 | Srinivas Garrepally | Methodology of creating an object database from a Gerber file |
US20030179232A1 (en) * | 2002-03-25 | 2003-09-25 | Fousek Daniel P. | Custom drawing symbols |
US20040068557A1 (en) * | 2002-10-02 | 2004-04-08 | Renesas Technology Corporation | IP (Intellectual Property) generating system |
US6934918B2 (en) * | 2002-10-02 | 2005-08-23 | Renesas Technology Corporation | IP (Intellectual Property) generating system |
US20050241168A1 (en) * | 2004-04-29 | 2005-11-03 | Iannuzzelli Raymond J | PWB warp gauge |
US7409667B1 (en) * | 2005-12-15 | 2008-08-05 | Emc Corporation | Techniques for modeling a circuit board structure |
US7721235B1 (en) * | 2006-06-28 | 2010-05-18 | Cadence Design Systems, Inc. | Method and system for implementing edge optimization on an integrated circuit design |
US20080082949A1 (en) * | 2006-10-01 | 2008-04-03 | Dell Products L.P. | Method, Apparatus and Media for Updating CAD Data with Printed Circuit Board Stencil Data |
US20110299782A1 (en) * | 2009-12-02 | 2011-12-08 | Qualcomm Incorporated | Fast subspace projection of descriptor patches for image recognition |
US8897572B2 (en) * | 2009-12-02 | 2014-11-25 | Qualcomm Incorporated | Fast subspace projection of descriptor patches for image recognition |
US8438524B1 (en) | 2009-12-30 | 2013-05-07 | Cadence Design Systems, Inc. | Hierarchical editing of printed circuit board pin assignment |
US9530073B2 (en) | 2010-04-20 | 2016-12-27 | Qualcomm Incorporated | Efficient descriptor extraction over multiple levels of an image scale space |
US20120042297A1 (en) * | 2010-08-16 | 2012-02-16 | Hon Hai Precision Industry Co., Ltd. | Computer aided design system and method |
US8370790B2 (en) * | 2010-08-16 | 2013-02-05 | Hong Fu Jin Precision Industry (Shenzhen) Co., Ltd. | Computer aided design system for checking dimensions of patterns and method |
CN102750419A (en) * | 2012-06-27 | 2012-10-24 | 西安理工大学 | Subway comprehensive pipeline aided design system and method |
US9390216B2 (en) * | 2014-10-20 | 2016-07-12 | Oracle International Corporation | System and method for obstacle-avoiding signal bus routing |
US9633163B1 (en) * | 2015-01-05 | 2017-04-25 | Cadence Design Systems, Inc. | System and method for displaying routing options in an electronic design |
US11028584B2 (en) | 2018-04-18 | 2021-06-08 | Christie Lites Enterprises Canada Inc. | Connection apparatus and method |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6678874B1 (en) | Computer-aided design (CAD) tool | |
JP3264806B2 (en) | Circuit simulation model extraction method and apparatus | |
US7039892B2 (en) | Systems and methods for ensuring correct connectivity between circuit designs | |
EP1906326A1 (en) | Circuit board information acquisition and conversion method, program, and device for the same | |
US20070057380A1 (en) | Method for designing semiconductor apparatus, system for aiding to design semiconductor apparatus, computer program product therefor and semiconductor package | |
US20090228848A1 (en) | Circuit verification apparatus, a method of circuit verification and circuit verification program | |
US7117464B2 (en) | System and method for evaluating signal coupling between differential traces in a package design | |
US6629307B2 (en) | Method for ensuring correct pin assignments between system board connections using common mapping files | |
US7383092B2 (en) | Information processing apparatus and method, and program | |
US6922822B2 (en) | Verifying proximity of ground vias to signal vias in an integrated circuit | |
JP4136495B2 (en) | Circuit design support apparatus including a directional coupler, its design support program, and circuit design method | |
US9256707B2 (en) | Trace routing according to freeform sketches | |
WO2006121042A1 (en) | Method, device and program for creating power source model of semiconductor integrated circuit | |
US20050223348A1 (en) | System and method for evaluating signal trace discontinuities in a package design | |
US6789243B2 (en) | Interactive floor planner apparatus for circuit blocks | |
KR20110009634A (en) | Wiring design assisting apparatus, wiring design assisting method, and computer-readable recording medium having wiring design assisting program | |
KR100999016B1 (en) | Jitter amount estimating method, method for calculating correlation between amount of simultaneously operating signal noise and jitter amount, and recording medium | |
JPH09274623A (en) | Transmission line simulation system and transmission line simulation method using the same | |
US20040163056A1 (en) | System and method for evaluating signal coupling between vias in a package design | |
US7055124B2 (en) | System and method for evaluating signal deviations in a package design | |
US7313509B2 (en) | Simulation method and apparatus, and computer-readable storage medium | |
US8055486B2 (en) | Power delivery analysis and design | |
Singh et al. | Drone Hardware Development | |
JP3027962B2 (en) | Wiring capacity evaluation method and wiring capacity evaluation system | |
JP2977422B2 (en) | Product specification estimation method, logic circuit classification / evaluation device, product specification database creation device, product specification estimation device, and automatic logic circuit hierarchy generation device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JOCHYM, DANIEL A.;CLOSS, JOSEPH N.;REEL/FRAME:012611/0663 Effective date: 20020116 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023312/0044 Effective date: 20090601 Owner name: UNISYS HOLDING CORPORATION, DELAWARE Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023312/0044 Effective date: 20090601 Owner name: UNISYS CORPORATION,PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023312/0044 Effective date: 20090601 Owner name: UNISYS HOLDING CORPORATION,DELAWARE Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023312/0044 Effective date: 20090601 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023263/0631 Effective date: 20090601 Owner name: UNISYS HOLDING CORPORATION, DELAWARE Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023263/0631 Effective date: 20090601 Owner name: UNISYS CORPORATION,PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023263/0631 Effective date: 20090601 Owner name: UNISYS HOLDING CORPORATION,DELAWARE Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:023263/0631 Effective date: 20090601 |
|
AS | Assignment |
Owner name: DEUTSCHE BANK TRUST COMPANY AMERICAS, AS COLLATERA Free format text: PATENT SECURITY AGREEMENT (PRIORITY LIEN);ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:023355/0001 Effective date: 20090731 |
|
AS | Assignment |
Owner name: DEUTSCHE BANK TRUST COMPANY AMERICAS, AS COLLATERA Free format text: PATENT SECURITY AGREEMENT (JUNIOR LIEN);ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:023364/0098 Effective date: 20090731 |
|
AS | Assignment |
Owner name: GENERAL ELECTRIC CAPITAL CORPORATION, AS AGENT, IL Free format text: SECURITY AGREEMENT;ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:026509/0001 Effective date: 20110623 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:DEUTSCHE BANK TRUST COMPANY;REEL/FRAME:030004/0619 Effective date: 20121127 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:DEUTSCHE BANK TRUST COMPANY AMERICAS, AS COLLATERAL TRUSTEE;REEL/FRAME:030082/0545 Effective date: 20121127 |
|
FPAY | Fee payment |
Year of fee payment: 12 |
|
AS | Assignment |
Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, AS COLLATE Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:042354/0001 Effective date: 20170417 Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, AS COLLATERAL TRUSTEE, NEW YORK Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:042354/0001 Effective date: 20170417 |
|
AS | Assignment |
Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT, ILLINOIS Free format text: SECURITY INTEREST;ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:044144/0081 Effective date: 20171005 Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT Free format text: SECURITY INTEREST;ASSIGNOR:UNISYS CORPORATION;REEL/FRAME:044144/0081 Effective date: 20171005 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WELLS FARGO BANK, NATIONAL ASSOCIATION (SUCCESSOR TO GENERAL ELECTRIC CAPITAL CORPORATION);REEL/FRAME:044416/0358 Effective date: 20171005 |
|
AS | Assignment |
Owner name: UNISYS CORPORATION, PENNSYLVANIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WELLS FARGO BANK, NATIONAL ASSOCIATION;REEL/FRAME:054231/0496 Effective date: 20200319 |