

## ENGINEERING TRIPPOS PART IIA

PROJECT GF2

SOFTWARE

### LOGIC SIMULATOR

*First Interim Report*

Name: Yi Chen Hock, Michael Stevens, Cindy Wu  
College: Queens', Robinson, John's

---

## Contents

|          |                                         |          |
|----------|-----------------------------------------|----------|
| <b>1</b> | <b>Introduction</b>                     | <b>2</b> |
| <b>2</b> | <b>General Approach</b>                 | <b>2</b> |
| 2.1      | Teamwork Planning . . . . .             | 2        |
| <b>3</b> | <b>EBNF for Syntax</b>                  | <b>3</b> |
| 3.1      | Example A — Simple Circuit . . . . .    | 5        |
| 3.2      | Example B — Complex Circuit . . . . .   | 5        |
| <b>4</b> | <b>Errors</b>                           | <b>6</b> |
| 4.1      | Error Handling . . . . .                | 6        |
| 4.2      | Semantic Error Identification . . . . . | 6        |
| <b>5</b> | <b>Appendix</b>                         | <b>7</b> |

# 1 Introduction

The aim of this project is to develop a logic circuit simulator in Python. As a team of three, we will work together on the project under a real-life simulation of a professional software development environment. This will involve the five major phases of the software engineering life cycle: specification, design, implementation, testing and maintenance. This report will cover the general approach of the project including teamwork planning; EBNF for syntax; identification of all possible semantic errors; description of error handling; and two example definition files together with diagrams showing the logic circuits they represent.

## 2 General Approach

The general approach to the project is to split it into four main sections. The first section involves defining a precise specification for the logic description language, which the client will use to define their logic circuit. The aim of this is to create a simple and coherent language using EBNF notation, which is readable to both the user as well as the computer. In addition, the specification will identify the semantic constraints which apply to the language as well as consider how any error conditions will be handled. The details of this section are outlined in this report.

The second section involves developing the individual modules for the bulk of the logic simulator. The scanner and parse modules will directly use the logic description language as well as the specification of error handling as defined in the first section. The approach for this is to create a detailed specification in the first section to allow for easier and efficient development of the code. The user interface will be designed to be straight forward as well as intuitive to use. Throughout this section, unit tests will be implemented to ensure that each module works as expected, even when given unexpected inputs.

The third section is to integrate the various modules together and ensure that the program works as one. The unit tests for each module developed in the previous section will greatly improve the speed and efficiency of integration as they will ensure that any bugs found will be confined to the integration of the modules rather than the modules themselves. Therefore, it is vital that well written and complete unit tests are developed to allow for smooth integration. In addition, clear and easy to read documentation will be produced for the client.

Finally, the last section is involved with implementing any modifications to the system which the client proposes. These modifications will not be known until after the logic simulator is developed and hence, the code will be structured with plenty of modularisation. This will allow system modifications to be implemented more efficiently and with less bugs.

### 2.1 Teamwork Planning

The Gantt chart in the Appendix (Figure 3) shows how the tasks for this project have been split up and allocated to each team member. Note that the allocated person(s) for each task will not necessarily be the only person working on that task since the workload for each task may not be predictable at this stage of the project. In particular, the development of unit tests for each module will likely be developed by a different team member than the module's author, however, a single member will be responsible for the overall completion of these unit tests. The Gantt chart also highlights the deadlines given by the client. It's also to be noted that the aim is to complete the first iteration of the code within the first two weeks of the project, to allow sufficient time for integration and testing of the system. Throughout this project, git is used for collaborative coding and version control. The repository can be found at <https://github.com/yichenhock/GF2>.

### 3 EBNF for Syntax

The logic description language will be specified using EBNF notation. The language was designed with ease of readability in mind, so English keywords and punctuation have been used such that the meaning is clear to a human reader as well as a machine. There are four main sections to the description file:

1. **device**: Defines the device and device type by user-defined names and along with the number of input ports for each device and defines any switches or clocks.
2. **initialise**: Sets the state of the switches (which will be the inputs to the logic circuit) and the frequency of the clock. Error handling will be implemented to ensure that
3. **connections**: Defines the connections between switches, devices and input ports.
4. **monitors**: Defines the output signals which will be monitored.

The following is a formal description using EBNF of the logic description language we will be using in this project:

```
circuit_description = device_block, initialise_block, connections_block, [monitors_block];  
  
device_block = "device", bracket_open, {gate_definition | dtype_definition | switch_definition |  
clock_definition}, bracket_close, semicolon;  
  
initialise_block = "initialise", bracket_open, {switch_initialisation | clock_initialisation},  
bracket_close, semicolon;  
  
connections_block = "connections", bracket_open, {device_name, bracket_open,  
{connection_definition}, bracket_close, semicolon}, bracket_close, semicolon;  
  
monitors_block = "monitors", bracket_open, {device_name | dtype_output_name | switch_name |  
clock_name}, bracket_close, semicolon;  
  
gate_definition = device_name, {[comma, device_name]}, definition, gate_type, semicolon;  
  
dtype_definition = device_name, {[comma, device_name]}, definition, ("DTYPE" | "DTYPES"),  
semicolon;  
  
switch_definition = switch_name, {[comma, switch_name]}, definition, ("SWITCHES" | "SWITCH"),  
semicolon;  
  
clock_definition = clock_name, {[comma, clock_name]}, definition, ("CLOCK" | "CLOCKS"),  
semicolon;  
  
gate_inputs = device_name, {[comma, device_name]}, possession, {digit}, ("input" | "inputs"),  
semicolon;  
  
switch_initialisation = switch_name, {[comma, switch_name]}, definition, switch_level, semicolon  
;  
  
clock_period = clock_name, ("cycle length" | "cycle"), {digit}, semicolon;  
  
connection_definition = (device_name | dtype_output_name | switch_name | clock_name), ("is  
connected to" | "to" | "connects to" | arrow), {(gate_input_name | dtype_input_name)},  
semicolon;  
  
gate_input_name = device_name, dot, "I", {digit};
```

```

dtype_input_name = device_name, dot, dtype_inputs;

dtype_output_name = device_name, dot, dtype_outputs;

device_name = letter, {[letter|digit]};

clock_name = "clk", {[digit]};

switch_name = "sw", {[digit]};

gate_type = "AND" | "ANDS" | "OR" | "ORS" | "NOR" | "NORS" | "XOR" |
            "XORS" | "NAND" | "NANDS";

switch_level = "HIGH" | "LOW" | "TRUE" | "FALSE" | "1" | "0";

dtype_inputs = "DATA" | "CLK" | "SET" | "CLEAR";

dtype_outputs = "Q" | "QBAR";

letter = "a" | "b" | "c" | "d" | "e" | "f" | "g" | "h" | "i" |
         "j" | "k" | "l" | "m" | "n" | "o" | "p" | "q" | "r" |
         "s" | "t" | "u" | "v" | "w" | "x" | "y" | "z" ;

digit = "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" ;

definition = "is" | "are";

possession = "has", "have";

arrow = "=>" | "->";

bracket_open = "(";

bracket_close = ")";

semicolon = ";";

comma = ",";

dot = ".";

```

We do not include comment syntax in EBNF as the scanner removes comments from input file. The syntax for comments will be "# ;", where "#" denotes the start of the comment section, and ";" denotes the end of the comment section. There will be no line comments as line breaks and spaces hold no significance. Additional notes on the ENBF syntax include:

- AND, OR, NAND and NOR gates can have from 1 to 16 inputs but XOR gates can only have 2 inputs.
- The monitor block is optional. The user may define it later or they may choose to not monitor any outputs.
- When defining the circuit, there are a couple of phrase options which may be used. For example, when specifying connections, both "is connected to" and "to" can be used, as shown in Example A and B respectively".
- The clock cycle length  $n$  is number of simulation cycles for clock to change.
- The DTYPEn bistable has two outputs, Q and QBAR, where QBAR is the inverse of Q.

### 3.1 Example A — Simple Circuit



Figure 1: XOR Gate

```

1      devices(                               17
2          a is OR;                         18
3          b is NAND;                        19
4          c is AND;                         20
5          a, b, c have 2 inputs;           21
6          sw1, sw2 are SWITCHES;          22
7      );                                 23
8
9      initialise(                         24
10         sw1, sw2 are HIGH;             25
11     );                                26
12
13      connections(                     27
14          a(                           28
15              sw1 is connected to a.I1;  29
16              sw2 is connected to a.I2; 30
17          )                           31
18      )                                32
19
20      monitors(                         21
21          b(                           22
22              sw1 is connected to b.I1; 23
23              sw2 is connected to b.I2; 24
24          )                           25
25      );
26
27      c(                               28
28          a is connected to c.I1;       29
29          b is connected to c.I2;       30
30      );
31
32

```

### 3.2 Example B — Complex Circuit



Figure 2: 2 Bit Counter with Outputs XOR

```

1      devices(                               30          );
2          a is NOR;                      31
3          b, c, d, e are NANDS;          32          d(
4          f is DTYPE;                  33          b to d.I1;
5          g is XOR;                   34          e to d.I2;
6          a, b, c, d, e, g have 2 inputs; 35          );
7          sw1, sw2 are SWITCHES;        36
8          clk1 is CLOCK;              37          e(
9      );                                38          d to e.I1;
10                                         39          c to e.I2;
11      initialise(                     40          );
12          sw1, sw2 are LOW;           41
13          clk1 cycle length 1000;     42          f(
14      );                                43          f.QBAR to f.DATA;
15
16      connections(                 44          d to f.CLK;
17          a(                           45          sw1 to f.SET;
18              e to a.I1;             46          sw2 to f.CLEAR;
19              e to a.I2;             47          );
20      );                                48
21          b(                           49          g(
22              e to b.I1;             50          d to g.I1;
23              clk1 to b.I2;         51          f.Q to g.I2;
24      );                                52          );
25          c(                           53          );
26              clk1 to c.I1;         54
27              a to c.I2;            55          monitors(
28      );                                56          d, f.Q, g;
29

```

## 4 Errors

### 4.1 Error Handling

### 4.2 Semantic Error Identification

5 Appendix



1: First interim report deadline, 2: Second interim report deadline, 3: Final interim report deadline

Figure 3: Gantt Chart