1
<HTML><HEAD><TITLE>Using Electric 1-11: Schematics Example</TITLE></HEAD>
2
<BODY BGCOLOR="#FFFFFF">
3
<!-- PAGE BREAK --><A NAME="chap01-11"></A>
5
<BR><CENTER><FONT SIZE=6><B>Chapter 1: INTRODUCTION</B></FONT></CENTER><BR>
6
<CENTER><TABLE WIDTH="90%" BORDER=0><TR>
7
<TD><CENTER><A HREF="chap01-10.html#chap01-10"><IMG SRC="../images/iconplug.png" ALT="plug" BORDER=0></A></CENTER></TD>
8
<TD><CENTER><H2>1-11: Schematics Example</H2></CENTER></TD>
9
<TD><CENTER><A HREF="chap02-01.html#chap02-01"><IMG SRC="../images/iconplug.png" ALT="plug" BORDER=0></A></CENTER></TD></TR></TABLE></CENTER>
13
This section takes you through the design of some simple schematics.
15
Electric starts in IC design mode (MOSIS CMOS layout),
16
so you have to switch to schematics before doing any design.
17
Use the <B>Change Current Technology...</B> command from the <B>Technology</B> menu.
18
Select the "schematic, digital" entry (you will have to scroll down to find it) and click OK.
19
The symbols in the component menu on the left will change to a Digital schematics set.
20
Analog components can be created by selecting the "schematic, analog" technology,
21
but they may also be selected with the <B>New Analog Part</B> command in the <B>Edit</B> menu.
25
Before you can place any schematics, the editing window must have a facet in it.
26
Use the <B>Edit Facet...</B> command in the <B>Facets</B> menu.
27
This will show a dialog with a list of existing facets (which is empty, because none exist yet).
28
Click on the "New Facet" button at the bottom of this dialog to create a new facet.
29
You will then see a dialog which asks you for information about this new facet.
30
</TD><TD><CENTER><IMG SRC="../images/chap01-03.png" ALT="Figure 1.3"></CENTER></TD></TR></TABLE>
34
<TD><CENTER><IMG SRC="../images/chap01-24.png" ALT="Figure 1.24"></CENTER></TD><TD>
35
Type the name ("MyCircuit" is used here) and click OK.
36
The editing window will no longer have the "No facet in this window" message,
37
and circuitry may now be created.
42
Logic elements are placed by selecting nodes from the components menu,
43
and then wiring them together.
44
This example shows two nodes that have been created.
45
This was done by clicking on the appropriate component menu entry,
46
and then clicking again in the editing window to place that node.
47
After clicking on the component menu entry,
48
the cursor changes to a pointing hand to indicate that you must select a location for the node.
49
When placing the node, if you press the button and do not release it,
50
you will see an outline of the new node,
51
which you can drag to its proper location before releasing the button.
52
</TD><TD><CENTER><IMG SRC="../images/chap01-17.png" ALT="Figure 1.17"></CENTER></TD></TR></TABLE>
56
the top node is called a Buffer (found in the seventh entry from the bottom of the component menu).
57
The node on the bottom is called an And (eighth entry from the bottom of the component menu).
58
Both of these nodes are from the Schematic technology
59
(which is listed as "schematics" in the status area).
62
<TD><CENTER><IMG SRC="../images/chap01-18.png" ALT="Figure 1.18"></CENTER></TD><TD>
63
A <I>highlighted</I> node has two selected parts: the node and a port on that node.
64
Note that the And is highlighted in the example above,
65
and the Buffer is highlighted in the example here.
66
The little "+" sign is the currently highlighted port
67
(there are two possible ports on these nodes, on the input and the output).
71
To highlight a node, use the <I><A HREF="chap01-08.html#chap01-08" TITLE="UNIX:left Windows:left Mac:click">selection</A></I> button.
72
The node, and the closest port to the cursor, will be selected.
73
After highlighting, you can hold the mouse button down and drag the highlighted object to a new location.
74
If nothing is under the cursor when the selection button is pushed,
75
you may drag the cursor while the button remains down to define an area in which all objects will be selected.
78
Another way to affect what is highlighted is to use the
79
<I><A HREF="chap01-08.html#chap01-08" TITLE="UNIX:shift-left Windows:shift-left Mac:shift-click">toggle select</A></I> button.
80
The <I>toggle select</I> button causes object highlighting to be reversed
81
(highlighted objects become unhighlighted and unhighlighted objects are highlighted).
83
The shape of the highlighted port is important.
84
Ports are the sites of arc connections,
85
so the end point of the arc must fall inside this port area.
86
Ports may be rectangles, lines, single points (displayed as a "+"), or any arbitrary shape.
87
For example, the entire left side of the And gate is the input port and so its highlighting is a line.
91
To wire a component, select it, move the cursor away from the component,
92
and use the <I><A HREF="chap01-08.html#chap01-08" TITLE="UNIX:right Windows:right Mac:cmd-click">creation</A></I> button.
93
A wire will be created that runs from the component to the location of the cursor.
94
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.
95
To see where the wire will end,
96
click but do not release the button and drag the outline of the wire's terminating node
97
(a pin) until it is in the proper location.
98
It is highly recommended that you do all wiring operations this way, because wiring is quite complex and can follow many different paths.
99
</TD><TD><CENTER><IMG SRC="../images/chap01-19.png" ALT="Figure 1.19"></CENTER></TD></TR></TABLE>
102
Once a wire has been created, the other end is highlighted (see above).
103
This is the highlighting of a <I>pin</I> node that was created to hold the other end of the arc.
104
Because it is a node,
105
the <I><A HREF="chap01-08.html#chap01-08" TITLE="UNIX:right Windows:right Mac:cmd-click">creation</A></I>
106
button can be used again to continue the wire to a new location.
107
If the creation command terminates over an existing component,
108
the wire will attach to that component.
111
One aspect of the And, Or, and Xor gates that you will notice is that their left side
112
(the input side) can accept any number of wires.
113
To see this in action, place one of these components in the facet.
114
Then repeatedly select its left side and use the
115
<I><A HREF="chap01-08.html#chap01-08" TITLE="UNIX:right Windows:right Mac:cmd-click">creation</A></I> button to draw wires out of it.
116
After three wires have been connected to the input side,
117
the gate grows to accommodate more.
118
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.
120
<CENTER><IMG SRC="../images/chap01-14.png" ALT="Figure 1.14"></CENTER>
124
To negate an input or output of a digital gate,
125
you must negate the wire connected to that gate.
126
Select a wire and use the <B>Negated</B> command from the <B>Arc</B> menu.
127
With this facility, you can construct arbitrary gate configurations.
128
</TD><TD><CENTER><IMG SRC="../images/chap01-15.png" ALT="Figure 1.15"></CENTER></TD></TR></TABLE>
131
To remove wires or components,
132
you can issue the <B>Undo</B> command of the <B>Edit</B> menu to remove the last created object.
133
Alternatively, you can select the component and use the <B>Erase</B> command from the <B>Edit</B> menu.
135
Once components are wired, moving them will also move their connecting wires.
136
Notice that the wires stretch and move to maintain the connections.
137
What actually happens is that the programmable constraint system follows instructions stored on the
138
wires, and reacts to component changes.
139
The default wire is <I>fixed-angle</I> and <I>slidable</I>,
140
so the letters "FS" are shown when the wire is highlighted.
142
Select a wire and issue the <B>Rigid</B> command of the <B>Arc</B> menu.
143
The letters change to "R" on the arc and the wire no longer stretches when components move.
144
Find another arc and issue the <B>Not Fixed-angle</B> command in the <B>Arc</B> menu.
145
Now observe the effects of an unconstrained arc as its neighboring nodes move.
146
These arc constraints can be reversed with the <B>Rigid</B> and <B>Fixed-angle</B> commands.
149
Electric supports hierarchy by allowing you to create icons for a schematic and place them in another facet.
150
Before creating an icon, all connection points to the schematic should be defined.
153
<TD><CENTER><IMG SRC="../images/chap01-22.png" ALT="Figure 1.22"></CENTER></TD><TD>
154
Before creating an icon, there must be connection sites, or <I>exports</I> on the schematic.
155
Select the output port of the Buffer node and issue the <B>Create Export...</B> command from the <B>Export</B> menu.
156
You will be prompted for an export name and its characteristics
157
(the characteristics can be ignored for now).
163
<TD><CENTER><IMG SRC="../images/chap01-20.png" ALT="Figure 1.20"></CENTER></TD><TD>
164
The output port on the buffer node is now exported to the outside world.
165
Run a wire from the input side of the And node and export the pin at the end of the wire.
166
Your circuit should look like this.
171
You can now make an icon for this circuit by using the <B>Make Icon</B> command of the <B>View</B> menu.
172
The icon will be placed in your circuit (you may have to move it away from the rest of the circuitry).
173
The result will look like this.
174
</TD><TD><CENTER><IMG SRC="../images/chap01-21.png" ALT="Figure 1.21"></CENTER></TD></TR></TABLE>
178
Now create a new facet with the <B>Edit Facet...</B> command of the <B>Facets</B> menu.
179
Click on the "New Facet" button at the bottom,
180
and make sure the "Make new window for facet" option is checked in the dialog.
181
Then type the new facet name ("Higher" is used in the example here) and set its view.
182
</TD><TD><CENTER><IMG SRC="../images/chap01-25.png" ALT="Figure 1.25"></CENTER></TD></TR></TABLE>
184
A new (empty) facet will appear in a separate window.
185
Try creating a few simple nodes in this new window (place a gate or two).
188
<TD><CENTER><IMG SRC="../images/chap01-10.png" ALT="Figure 1.9"></CENTER></TD><TD>
189
Now place an instance of the other facet by using the <B>New Facet Instance...</B> command from the <B>Edit</B> menu.
190
You will be given a list of facets to create:
191
select the one that is in the OTHER window (the one called "MyCircuit{ic}" in this example).
192
Then click in the newer facet to create the instance.
197
The icon that appears is a node in the same sense as the Buffer and And gate:
198
it can be moved, wired, and so on.
199
In addition, because the node contains subcomponents,
200
you can see its contents by selecting it and using the
201
<B>Down Hierarchy</B> command in the <B>Facets</B> menu.
202
Note that if the objects in a facet no longer fit in the display window,
203
use the <B>Fill Window</B> command from the <B>Windows</B> menu.
204
</TD><TD><CENTER><IMG SRC="../images/chap01-23.png" ALT="Figure 1.23"></CENTER></TD></TR></TABLE>
207
Some final commands that should be mentioned in this introductory example are the <B>Save Library</B>
208
and the <B>Quit</B> commands which can be found in the <B>File</B> menu.
209
They do the obvious things.
210
Also, the <B>Help...</B> command from the <B>Info</B> menu is very useful.
211
It displays a dialog with a list of subjects and offers information about each one.
215
<CENTER><TABLE BORDER=0><TR>
216
<TD><A HREF="chap01-10.html#chap01-10"><IMG SRC="../images/iconbackarrow.png" ALT="Prev" BORDER=0></A></TD>
217
<TD><A HREF="chap01-10.html#chap01-10">Previous</A></TD>
218
<TD> </TD>
219
<TD><A HREF="../index.html"><IMG SRC="../images/iconcontarrow.png" ALT="Contents" BORDER=0></A></TD>
220
<TD><A HREF="../index.html">Table of Contents</A></TD>
221
<TD> </TD>
222
<TD><A HREF="chap02-01.html#chap02-01">Next</A></TD>
223
<TD><A HREF="chap02-01.html#chap02-01"><IMG SRC="../images/iconforearrow.png" ALT="Next" BORDER=0></A></TD>
224
</TR></TABLE></CENTER>