| GDS II (also called "Stream" format) is used as an interchange between design systems and fabrication facilities.
For information on reading and writing GDS, see
Section 3-9-2 and
Section 3-9-3, respectively.
In GDS files, there are no names for each layer, just a pair of numbers (the layer number and type).
It is important that Electric know how these values correspond with layers so that it can properly
read and write GDS files.
You can set the correspondences by using the GDS Map File... command (in menu File / Import)
to read a GDS map file. |  | 
You can also use the GDS Preferences
(in menu File / Preferences..., "I/O section, "GDS" tab) to edit the GDS numbers and
control other aspects of GDS input and output.
 
Project Preferences
The left side of the dialog shows the Project Preferences which control the mapping
of GDS layer numbers to Electric layers.
The list on the left shows all of the Electric layers in the current technology.
By clicking on a layer name, its GDS numbers are shown in the top-right and can be edited.
In addition to GDS numbers to use for layout, there are also two other types of GDS numbers:
pin (for exports) and text (for export names).
To ignore a layer, clear the layer field (it is not sufficient to set it to zero...it must be blank).
These dialog elements apply to the export of GDS:
- 
"Output merges Boxes".
This controls the merging of adjoining geometry.
It is an issue because of the duplication and overlap that occurs wherever arcs and nodes meet.
The default action is to write each node and arc individually.
This makes the file larger because of redundant box information,
however it is faster to generate and uses simpler constructs.
If you check this item,
all connecting regions on the same layer are merged into one complex polygon.
This requires more processing, produces a smaller file, and generates more complex constructs.
- 
"Output writes export Pins".
This controls whether pins are written to the GDS file for each export.
If checked, and there is a valid pin layer, then it is written.
- 
"Output all upper case".
This controls whether the GDS file uses all upper case.
The default is to mix upper and lower case, but some systems insist on upper-case GDS.
- 
"Output converts brackets in exports".
This controls whether the square brackets used in array specifications should be converted (to underscores).
Some GDS readers cannot handle the square bracket characters.
- 
"Max chars in output cell name".
This limits the number of characters in a cell name.
Names longer than this are truncated, and adjusted to ensure uniqueness.
- "Output default text layer".
This is the layer number to use when writing text.
When exports are being written, and there is a text layer number associated with the appropriate Electric layer,
then that layer number is used instead of this default number.
This dialog element applies to the import of GDS:
- "Scale by".
This scales the GDS by the given factor when read from disk.
User Preferences
These dialog elements are available on the right side (the GDS User Preferences):
- "Merge boxes (slow)".
This requests GDS input to combine overlapping boxes into complex polygons.
It takes more time, but produces a more compact database.
- "Include text".
Text annotations in the GDS file can often clutter the display, so they are ignored during input.
If you check this item, annotation text will be read and displayed.
- "Expand cells".
This controls whether cell instances are expanded or not in the Electric circuit.
By default, cell instances are not expanded (they appear as a simple box).
If you check this item, cells are expanded so that their contents are displayed.
Expansion of cells can always be changed after reading GDS by using the subcommands of the Expand Cell Instances
and Unexpand Cell Instances commands of the Cells menu.
- "Simplify contact vias".
This requests GDS input to find combinations of metal and via cuts and replace them with Electric contacts.
It takes time, and may simplify some GDS.
- "Use NCC annotations for exports".
The network consistency checker (NCC)
allows special circuit annotations to join two networks
(see Section 9-7-4).
For example, two separate power networks may be joined higher in the circuit hierarchy,
and the NCC needs to know this at the current level of design.
This checkbox requests that the NCC annotations be used when exporting GDS.
It enables external circuit analysis programs (such as Assura) to properly understand the circuit connectivity.
- "Collapse VDD/GND pin names".
Requests that all names starting with "VDD" or "GND" be merged into a single power or ground signal.
- "Instantiate arrays".
This controls whether or not arrays in the GDS file are instantiated.
By default, arrays are instantiated fully, but this can consume excessive amounts of memory if there are large arrays.
If you uncheck this item, only the upper-left and lower-right instance are actually placed.
- "Array simplification".
This controls the simplification of special "array reference" objects in GDS.
When an array of cell instances is found, and each cell instance contains a single piece of geometry,
Electric can simplify the array specification so that a single pure-layer node is created instead
of an array of instances.
This pure-layer node has outline information that covers each of the arrayed objects
(see Section 6-10-1 for more on outlines).
This preference can be set to "None" (no simplification of array references is used),
"Merge individual arrays" in which the above simplification is performed,
and "Merge all arrays" in which multiple array references are combined so that a single pure-layer node
is place for each layer in the cell, regardless of the number of array references that are used.
This last choice can produce highly-complex pure-layer nodes, but is fastest and uses the least amount of memory.
- "Unknown layers".
This controls how unknown layers in the GDS file are treated.
The default is "Convert to DRC Exclusion layer" which creates an orange DRC-Node wherever an unknown layers appears.
If you set this to "Ignore", the unknown layers are simply ignored.
A final choice is "Convert to random layer" which picks a different layer in the technology for each unknown GDS layer number.
This allows the distinction between layers to be seen, even if the correct layer associations are not known.
- "Cadence compatibility".
This forces a GDS import to do things that assume the GDS has come from a Cadence system.
Export locations are forced to be inside of the geometry on which they reside.