|  | 1-11: Schematics Example |  | 
Electric starts in IC design mode (MOSIS CMOS layout), so you have to switch to schematics before doing any design. Use the Change Current Technology... command from the Technology menu. Select the "schematic, digital" entry (you will have to scroll down to find it) and click OK. The symbols in the component menu on the left will change to a Digital schematics set. Analog components can be created by selecting the "schematic, analog" technology, but they may also be selected with the New Analog Part command in the Edit menu.
| Before you can place any schematics, the editing window must have a facet in it. Use the Edit Facet... command in the Facets menu. This will show a dialog with a list of existing facets (which is empty, because none exist yet). Click on the "New Facet" button at the bottom of this dialog to create a new facet. You will then see a dialog which asks you for information about this new facet. |  | 
|  | Type the name ("MyCircuit" is used here) and click OK. The editing window will no longer have the "No facet in this window" message, and circuitry may now be created. | 
| Logic elements are placed by selecting nodes from the components menu, and then wiring them together. This example shows two nodes that have been created. This was done by clicking on the appropriate component menu entry, and then clicking again in the editing window to place that node. After clicking on the component menu entry, the cursor changes to a pointing hand to indicate that you must select a location for the node. When placing the node, if you press the button and do not release it, you will see an outline of the new node, which you can drag to its proper location before releasing the button. |  | 
In this example, the top node is called a Buffer (found in the seventh entry from the bottom of the component menu). The node on the bottom is called an And (eighth entry from the bottom of the component menu). Both of these nodes are from the Schematic technology (which is listed as "schematics" in the status area).
|  | A highlighted node has two selected parts: the node and a port on that node. Note that the And is highlighted in the example above, and the Buffer is highlighted in the example here. The little "+" sign is the currently highlighted port (there are two possible ports on these nodes, on the input and the output). | 
To highlight a node, use the selection button. The node, and the closest port to the cursor, will be selected. After highlighting, you can hold the mouse button down and drag the highlighted object to a new location. If nothing is under the cursor when the selection button is pushed, you may drag the cursor while the button remains down to define an area in which all objects will be selected.
Another way to affect what is highlighted is to use the toggle select button. The toggle select button causes object highlighting to be reversed (highlighted objects become unhighlighted and unhighlighted objects are highlighted).
The shape of the highlighted port is important. Ports are the sites of arc connections, so the end point of the arc must fall inside this port area. Ports may be rectangles, lines, single points (displayed as a "+"), or any arbitrary shape. For example, the entire left side of the And gate is the input port and so its highlighting is a line.
| To wire a component, select it, move the cursor away from the component, and use the creation button. A wire will be created that runs from the component to the location of the cursor. Note that the wire is a fixed-angle wire which means that it will be drawn along a horizontal or vertical path from the originating node. To see where the wire will end, click but do not release the button and drag the outline of the wire's terminating node (a pin) until it is in the proper location. It is highly recommended that you do all wiring operations this way, because wiring is quite complex and can follow many different paths. |  | 
Once a wire has been created, the other end is highlighted (see above). This is the highlighting of a pin node that was created to hold the other end of the arc. Because it is a node, the creation button can be used again to continue the wire to a new location. If the creation command terminates over an existing component, the wire will attach to that component.
One aspect of the And, Or, and Xor gates that you will notice is that their left side (the input side) can accept any number of wires. To see this in action, place one of these components in the facet. Then repeatedly select its left side and use the creation button to draw wires out of it. After three wires have been connected to the input side, the gate grows to accommodate more. Note that the vertical cursor location along the input side is used to select the position that will be used when a new wire is added.

| To negate an input or output of a digital gate, you must negate the wire connected to that gate. Select a wire and use the Negated command from the Arc menu. With this facility, you can construct arbitrary gate configurations. |  | 
To remove wires or components, you can issue the Undo command of the Edit menu to remove the last created object. Alternatively, you can select the component and use the Erase command from the Edit menu.
Once components are wired, moving them will also move their connecting wires. Notice that the wires stretch and move to maintain the connections. What actually happens is that the programmable constraint system follows instructions stored on the wires, and reacts to component changes. The default wire is fixed-angle and slidable, so the letters "FS" are shown when the wire is highlighted.
Select a wire and issue the Rigid command of the Arc menu. The letters change to "R" on the arc and the wire no longer stretches when components move. Find another arc and issue the Not Fixed-angle command in the Arc menu. Now observe the effects of an unconstrained arc as its neighboring nodes move. These arc constraints can be reversed with the Rigid and Fixed-angle commands.
Electric supports hierarchy by allowing you to create icons for a schematic and place them in another facet. Before creating an icon, all connection points to the schematic should be defined.
|  | Before creating an icon, there must be connection sites, or exports on the schematic. Select the output port of the Buffer node and issue the Create Export... command from the Export menu. You will be prompted for an export name and its characteristics (the characteristics can be ignored for now). | 
|  | The output port on the buffer node is now exported to the outside world. Run a wire from the input side of the And node and export the pin at the end of the wire. Your circuit should look like this. | 
| You can now make an icon for this circuit by using the Make Icon command of the View menu. The icon will be placed in your circuit (you may have to move it away from the rest of the circuitry). The result will look like this. |  | 
| Now create a new facet with the Edit Facet... command of the Facets menu. Click on the "New Facet" button at the bottom, and make sure the "Make new window for facet" option is checked in the dialog. Then type the new facet name ("Higher" is used in the example here) and set its view. |  | 
A new (empty) facet will appear in a separate window. Try creating a few simple nodes in this new window (place a gate or two).
|  | Now place an instance of the other facet by using the New Facet Instance... command from the Edit menu. You will be given a list of facets to create: select the one that is in the OTHER window (the one called "MyCircuit{ic}" in this example). Then click in the newer facet to create the instance. | 
| The icon that appears is a node in the same sense as the Buffer and And gate: it can be moved, wired, and so on. In addition, because the node contains subcomponents, you can see its contents by selecting it and using the Down Hierarchy command in the Facets menu. Note that if the objects in a facet no longer fit in the display window, use the Fill Window command from the Windows menu. |  | 
Some final commands that should be mentioned in this introductory example are the Save Library and the Quit commands which can be found in the File menu. They do the obvious things. Also, the Help... command from the Info menu is very useful. It displays a dialog with a list of subjects and offers information about each one.
|  | Previous |  | Table of Contents | Next |  |