# IIA GF2 Software: 2nd Interim Report

Martin Jackson (mj380) - Team 8

# 1 User guide

Opening files. There are two methods of opening a file. Either pass the filename as a command line argument when starting the logic simulator, or use the "File  $\rightarrow$  Open" menu item and select the correct file. Logic circuit definition files are plain text files with extension .gf2. Examples are provided. Any errors which occur while loading the file will be shown in the textbox at the bottom of the window.

Running the simulation. After opening a circuit, select the number of cycles to simulate using the textbox in the top right corner. Then click the "Run" button just below the textbox. Results will be displayed in the large space to the left (see figure 1). The run button clears the displayed results and simulates the circuit for the specified number of cycles. To simulate for additional cycles without clearing the displayed results, use the "Continue" button instead. The only limit on the number of displayed signals and simulated cycles is the available memory on the computer. If necessary, scrollbars will appear around the result display area.

Adding or removing monitors. To change which signals are monitored and displayed, use the add or remove monitors buttons on the right. The add monitors button will show a list of unmonitored outputs that can be selected for monitoring, and the remove monitors button a list of current monitors that can be removed. In both cases, multiple items may be selected. After adding a monitor, you must use the run button before using the continue button, as no samples were recorded for the new monitor during the cycles displayed on screen, so the recorded signals cannot be continued, they must be reset first.

Changing switch states. Use the checkboxes located in the bottom right corner of the window. Changes take effect immediately. Run or continue the simulation to see the effect on the circuit.

Editing devices. Click the edit devices button on the right hand side. This will open a window allowing you to add, edit, or delete devices (see figure 2). Select a device to edit using the list on the left. The top panel allows device properties to be modified. The bottom panels show inputs and outputs for the selected device, and which devices are connected to it. They also allow connections to be added and deleted. All changes to devices and connections take effect immediately, except for changes to device properties, which must be confirmed using the "Apply changes" button.



Figure 1: Main logic simulator window



Figure 2: GUI for editing devices  $\frac{1}{2}$ 

# 2 Example circuits

Jamie Magee made all definition files and circuit diagrams shown here.

## 2.1 XOR Gate

#### 2.1.1 Definition File

```
DEVICES
  SWITCH S1:0;
3 SWITCH S2:1;
4 NAND G1:2;
5 NAND G2:2;
6 NAND G3:2;
  NAND G4:2;
  CONNECTIONS
  G1.I1 = S1;
12 G1.I2 = S2;
13 G2.I1 = S1;
14 G2.I2 = G1;
15 G3.I1 = G1;
16 G3.I2 = S2;
_{17} G4.I1 = G2;
  G4.I2 = G3;
18
  END
_{21} MONITORS
22 S1;
23 S2;
24 G4;
25 END
```

Listing 1: xor.gf2

#### 2.1.2 Circuit Diagram



Figure 3: Circuit diagram of an XOR gate implemented using NAND gates

### 2.2 4-bit Adder

#### 2.2.1 Definition File

```
DEVICES
/* 4 bit inputs */
SWITCH A0:1;
SWITCH A1:0;
SWITCH A2:0;
```

```
6 SWITCH A3:0;
7 SWITCH BO:1;
8 SWITCH B1:0;
9 SWITCH B2:0;
10 SWITCH B3:0;
SWITCH CO:1; /* Carry in */
12 AND AND1:2;
AND AND2:2;
AND AND3:2;
15 AND AND4:2;
16 AND AND5:2;
17 AND AND6:2;
18 AND AND7:2;
19 AND AND8:2;
20 XOR XOR1;
21 XOR XOR2;
22 XOR XOR3;
23 XOR XOR4;
24 XOR XOR5;
25 XOR XOR6;
26 XOR XOR7;
27 XOR XOR8;
28 OR OR1:2;
29 OR OR2:2;
30 OR OR3:2;
31 OR OR4:2;
32 END
33
34 CONNECTIONS
35 /* LSB adder */
36 | XOR1.I1 = A0;
37 XOR1.I2 = BO;
38 AND1.I1 = XOR1;
39 AND1.I2 = CO;
40 AND2.I1 = A0;
41 AND2.I2 = B0;
42 XOR2.I1 = XOR1;
_{43} XOR2.I2 = C0;
44 OR1.I1 = AND1;
45 OR1.I2 = AND2;
46
47 XOR3.I1 = A1;
48 XOR3.I2 = B1;
49 AND3.I1 = XOR3;
50 AND3.I2 = OR1;
51 AND4.I1 = A1;
52 AND4.I2 = B1;
53 XOR4.I1 = XOR3;
54 XOR4.I2 = OR1;
55 OR2.I1 = AND3;
0R2.I2 = AND4;
57
  XOR5.I1 = A2;
58
  XOR5.I2 = B2;
59
  AND5.I1 = XOR5;
60
61 AND5.I2 = OR2;
62 AND6.I1 = A2;
63 AND6.I2 = B2;
64 XOR6.I1 = XOR5;
65 \times 12 = 0R2;
66 OR3.I1 = AND5;
67 OR3.I2 = AND6;
69 /* MSB Adder */
_{70} XOR7.I1 = A3;
71 XOR7.I2 = B3;
```

```
72 AND7.I1 = XOR7;
73 AND7.I2 = OR3;
_{74} AND8.I1 = A3;
75 AND8.I2 = B3;
76 XOR8.I1 = XOR7;
77 XOR8.I2 = OR3;
78 OR4.I1 = AND7;
79 OR4.I2 = AND8;
80
81
  MONITORS
82
  /* Outputs */
83
84 XOR2;
85 XOR4;
86 XOR6;
87 XOR8;
88 OR4; /* Carry out */
  END
```

Listing 2: 4bitadder.gf2

#### 2.2.2 Circuit Diagram



Figure 4: Circuit diagram of a 4-bit adder

## 2.3 Serial In Parallel Out Shift Register

### 2.3.1 Definition File

```
1 DEVICES
2 CLOCK CLK1:2;
3 CLOCK CLK2:1;
4 SWITCH S:0; /* Set switch */
  SWITCH R:0; /* Reset switch */
6 DTYPE D1;
7 DTYPE D2;
  DTYPE D3;
  DTYPE D4;
  END
10
12 CONNECTIONS
13 D1.DATA = CLK1;
14 D2.DATA = D1.Q;
15 D3.DATA = D2.Q;
_{16} D4.DATA = D3.Q;
```

```
17 D1.CLK = CLK2;
D2.CLK = CLK2;
19 D3.CLK = CLK2;
20 D4.CLK = CLK2;
21 D1.SET = S;
22 D2.SET = S;
  D3.SET = S;
23
  D4.SET = S;
24
  D1.CLEAR = R;
25
  D2.CLEAR = R;
26
  D3.CLEAR = R;
27
  D4.CLEAR = R;
28
  END
29
  MONITORS
31
  CLK2;
32
зз D1.Q;
34 D2.Q;
35 D3.Q;
36 D4.Q;
  END
```

Listing 3: sipo.gf2

#### 2.3.2 Circuit Diagram



Figure 5: Circuit diagram of a serial in parallel out shift register

**NB** The software used to draw the circuit diagram does not support the same style of D flip-flop used in the definition file, and Fig. 5 was the closest achievable.

#### 2.4 Gated D Latch

#### 2.4.1 Definition File

```
DEVICES
  CLOCK CLK1:1;
  CLOCK CLK2:2;
  NAND G1:1;
  AND G2:2;
  AND G3:2;
  NOR G4:2;
  NOR G5:2;
  END
  CONNECTIONS
11
  G1.I1 = CLK1;
  G2.I1 = G1;
14 G2.I2 = CLK2;
15 G3.I1 = CLK2;
16 G3.I2 = CLK1;
_{17} G4.I1 = G2;
18 | G4.I2 = G5;
19 | G5.I1 = G4;
```

```
20 G5.I2 = G3;

END

21 MONITORS

22 CLK1; /* D */

25 CLK2; /* E */

26 G4; /* Q */

27 G5; /* QBAR */

END
```

Listing 4: sipo.gf2

## 2.4.2 Circuit Diagram



Figure 6: Circuit diagram of a Gated D Latch

 ${f NB}$  The software used to draw the circuit diagram does not support the NAND gates with one input. Therefore the NAND gate G1 was substituted for a NOT gate as can be seen in Fig. 6.