# DCLab: A Web-based System for Digital Logic Experiment Teaching

Yuhui Ding, Shanshan Li, Jinghan Liu and Xiaojun Wu

Department of Computer Science and Technology

Tsinghua University

Beijing, China

dingyh15@mails.tsinghua.edu.cn, lishanshan@tsinghua.edu.cn, LiuJh@lib.tsinghua.edu.cn, xjwu@tsinghua.edu.cn

Abstract—This Research-to-Practice Work in Progress paper presents DCLab, a web-based system for conducting digital logic experiments online, to improve both the effectiveness and the efficiency of digital logic experiment teaching. DCLab covers all experimental contents required by traditional digital logic experiment classes. It allows the students to draw circuit diagrams or to write VHDL code to design their own circuits, and it provides complete simulation functions. DCLab records the progress of each student and makes it convenient for a student to review the history of his practice. Furthermore, for the instructors, they are able to post homework assignments on DCLab, and the system will automatically add homework projects to the students' home pages. Statistics about how the students perform on the homework will be displayed to the instructors, which may help them develop more effective courses. We have tested DCLab among students in the digital logic course, and the results have confirmed its validity.

Keywords—digital logic; web-based system; experiment teaching

## I. INTRODUCTION

Digital Logic is a dingyh fundamental course in the computer science curriculum, and its experimental study plays an important role in connecting theory and practice [1] [2], which helps students consolidate what they have learned from textbooks. Specifically, there are two types of digital logic experiment [3]. One is to require the students to build digital circuits manually, connecting circuit elements such as chips with wires, and use instruments for debugging. This type of experiment is indispensable in helping the students get a deep understanding of the digital logic theory and developing their hands-on skills. The other is to use programmable devices, and the students write the hardware description language (HDL) code to design circuits. In this way the students are able to keep away from tedious manual operations, and they can implement complex circuits more easily.

For classical approaches, a detailed guideline and some hardware equipments are distributed before the experimental task, and the students are required to finish design and make measurements on the given devices. Those hardware equipments are often somewhat unwieldy, leading to inconvenience for students who have to bring them to the laboratory. For the instructors, they need to examine the experiment results one by one, and they are sometimes bothered by the high damage rate of equipments. To improve both the effectiveness and the efficiency of digital logic experiment teaching, we have developed DCLab, an integrated web-based system. DCLab is mainly composed of four important modules: Graphical Circuit Module, VHDL Module, Simulation Module and Management Module. The Graphical Circuit Module enables students to place different circuit components on canvas and then assemble a circuit virtually. The VHDL Module allows students to edit circuit design files and stimulation files using VHDL. The Simulation Module is responsible for performing simulation and showing simulation waveforms. The Management Module manages users' projects and allows the instructors to assign homework.

To sum up, the main contributions of our proposed system are listed as follows:

- Based on the web, DCLab allows students to carry out digital logic experiments virtually, involving functions required for a complete experiment process such as compilation, simulation etc. It saves time and labor for both students and instructors.
- DCLab supports two types of digital logic experiment: graphical circuit building and VHDL editing, taking advantages of both.
- Even though conducting experiments online may mean less face-to-face time, DCLab keeps good interaction between students and instructors. It allows instructors to assign homework and track the students' progress, so that they can give directions accordingly.

The rest of the paper is organized as follows: We briefly review related work in Section II. In Section III we introduce the architecture of DCLab in detail. In Section IV we present experiment results and we conclude in Section V.

#### II. RELATED WORK

Considering the importance of digital logic experiment teaching, many educators have been focused on how to make it more effective and how to promote the students' innovation ability [4]. Li et al. [5] set up two different experimental courses according to students' interests and knowledge levels, and they design special hardware equipments which have various interfaces. Even though the particular hardware equipment supports many experimental contents and meets the requirements of the educators, it is rather inconvenient for the students to carry equipments with them, and they are very likely to be confused sometimes by too many wires which twine in the limited space.

To address the aforementioned problems, Yang et al. [6] and Kim et al. [7] both describe the design of a virtual laboratory for digital circuit experiments. The system in [6] only supports drawing wires through drag and drop on pins of circuit elements on a fixed board, which restricts the students' innovative ideas, and it doesn't allow students to design circuits using HDL. What's more, the students are only able to interact with the server that works out simulation results, thus lacking interactive learning between students and instructors. The system in [7] adds flash animation to explain the key concepts of the experiment, and it will give some multiple questions to users after virtual experiments to assess the learning effect. Nonetheless, it cannot support programmable experiments, and it still faces the problem of little interaction between the students and the instructors.

## **III. SYSTEM ARCHITECTURE**

To meet the requirements of the digital logic course and fully support students' experiment practice, DCLab has integrated all activities a student in the traditional experiment course may get involved in, such as design, simulation etc. The whole architecture of DCLab is illustrated in Figure 1. There are two ways to use the system in practice. For one thing, the students can create their own projects, drawing circuit diagrams or editing VHDL files, and see the simulation results. For another, the students may be required to finish experimental tasks as homework assignments, and their homework performance will be shown to the instructors. The functions of DCLab are implemented by several different modules, which will be demonstrated in detail next.



Fig. 1. System architecture of DCLab

#### A. Graphical Circuit Module

The Graphical Circuit Module provides a virtual environment where students can place different circuit elements on canvas and use wires to connect them through merely a few clicks. We have implemented all circuit elements which are required for the digital logic course, including all chips of the 74 series, seven segments LED displays, digital decoders etc. In building the circuit, students can drag and drop circuit elements freely on canvas, change their sizes to some extent and use shortcuts conveniently for cancel or deletion. What's more, DCLab is intelligible enough to discern some common operation mistakes. For instance, warnings will be given when a short circuit is detected, and it is not permitted to draw a wire between two output ports.

One of the most amazing features of the Graphical Circuit Module is that it provides two simulation methods. One method is to simulate the graphical circuit directly in the browser, without sending any file to the background server. Connecting some input stimulation such as a 50Hz clock frequency to the circuit, students can visually see whether the graphical circuit works correctly. Furthermore, in the simulation process, students can place probes to detect the status of different positions in the circuit, and the waveforms of the viewed points changing with time will be displayed at the bottom of the interface, which is illustrated in Figure 2. In this way, students are able to inspect their circuits intuitively and get their ability of debugging improved by using probes. Also, this kind of simulation helps save the computing resources of the server.



Fig. 2. The simulation of a graphical circuit and the probes

The other simulation method gives more detailed results. The students can submit the circuit and the stimulation signals to the background server, and when the data are received by the server they are automatically converted to VHDL files to perform simulation steps using ModelSim. Figure 3 shows an example circuit and its corresponding VHDL code. DCLab provides a graphical user interface to edit the stimulation signals manually, as is shown in Figure 4. Entering the stimulation signal editor, the system will automatically read labels of the input ports and display them in the interface, then the students can either draw waveforms or set some parameters in the text fields to edit the input signals.

## B. VHDL Module

The VHDL Module has integrated an open source framework to support students in writing VHDL code directly to



Fig. 3. A 74LS00 chip and its corresponding VHDL code

design the circuit and define input signals. The VHDL Module acts like other integrated development environments (IDE), providing sophisticated editing features such as color syntax highlighting, keyboard macros, code completion etc. These features help the students learn VHDL quickly and improve the efficiency of writing code. The compiler is able to work with multiple source files, and if any error occurs in the compilation, the debugger may suggest what type it is and what line it is on.



Fig. 4. Stimulation signal editor

## C. Simulation Module

The Simulation Module employs ModelSim to conduct simulation of VHDL files describing circuit design and input signals. The background server will execute certain ModelSim commands after it receives submitted files and will then return simulation waveforms and logs to be displayed to the user. Figure 5 shows the result of a submission.

| 00<br>11<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 00<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10<br>10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 0 20 40 60 100 120 140 160 160 160 160 160 160 160 160 160 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Let Vec <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Start 1.58 at 0.73.04 at 0.91.04 (SeptEr 2015.12) \$\begin{bmatrix}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| up provide the second s |  |
| odel Technology ModelSim ALTERA vcom 10.4d Compiler 2015.12 Dec 30 2015<br>- Loading package STANDARD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| - Loading package STANDARD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| - Loading package TEXTIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| Loading package std_logic_1164                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| - Loading package std_logic_arith                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| - Construction and the Action of Act |  |
| - Compling white y supplements                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| - Compiling entity Chip74L304                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| - Compiling architecture arch of Chip74L504                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| - Compiling entity top                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Compiling architecture bhv of top                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Compiling entity topsim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Compiling architecture T8 of topsim                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Compiling architecture 18 of topsim<br>End time: 07:31:48 on Dec 28,2017, Elapsed time: 0:00:00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

Fig. 5. The simulation waveforms of a submission

## D. Management Module

The Management Module is based on a database which contains all user profiles, projects' metadata and submission records. It is of great importance in making DCLab an interactive system.

On a student entering his home page, he will see four columns: Attention, Homework, Playground and Example, The Attention column lists notices with their dates of issue and authors, so that the students can read important experiment instructions from the instructors promptly. The Homework column contains experimental projects which the students are required to finish and submit as homework. The Management Module will automatically add an empty project to every student's Homework column once a new homework assignment is posted. In the Playground column, the students are free to create their own projects. While the type of a homework project (graphical circuit or VHDL code) is often specified by the instructor, a student can decide how to design his circuit independently for a self-created project, and he is encouraged to design some innovative circuits to achieve some particular functions. The Management Module records every submission of a self-created project in the database and keeps related files, so that a student can review the submission history of a certain project at any time. Each item of the submission history contains simulation waveforms (if compiled correctly) and compilation logs. Students' projects and submission histories can also be accessed by the instructors, which enable them to track the students' progress and give guidance accordingly. Projects in the Example column are edited by the instructors as paradigms or homework answers. The students do not have permissions to modify an example project, but they can conduct a simulation analysis and verify its correctness.

On the side of instructors, the Management Module allows them to broadcast notices, edit examples and assign homework. Example projects serve as paradigms or homework answers which the students may refer to. Editing examples is almost the same as what students would do to create their own projects. Once an example project is built, instructors could decide whether to set it visible to all students. To assign homework, the instructors are required to specify an example project as the possible answer and edit several different input stimulations, using the graphical signal editor, as test points. After a student has submitted his homework, DCLab will automatically complete compilation and simulation analysis, and will then check whether the obtained simulation waveforms are consistent with those of the example at all test points. The submission is graded according to how many test points it has passed.

Inspired by [8], in order to make the instructors understand how well the students perform on the homework assignment, the Management Module records the following features for each individual student:

- The number of submissions for the homework assignment
- The time of each submission
- The score of each submission
- The score of the student for the homework assignment (the highest score among all his submissions before the homework deadline)

Through these features the instructors are able to know an individual student's progress promptly and could then help him solve some possible problems. What's more, some metrics which can reflex the students' performance in general, such as the ratio of students who have already submitted the homework at least once, can be drawn from individual features of all students. These metrics are calculated automatically and displayed to the instructors through diagrams, and they can help the instructors develop the homework more effectively.

# **IV. EXPERIMENT RESULTS**

In order to show the validity of DCLab, we have tested it within a group of 31 second year undergraduates in the digital logic course. The students were instructed to design a simple counter circuit which could count from 0 to 59 in decimal and display the digits using the seven segments LED displays. They were allowed either to assemble a graphical circuit or to write VHDL code. We collected data three days after the homework was assigned without informing the students.

Among the 31 students, 17 have submitted the homework at least once, 10 of which have got the correct solution. Considering students' different levels, those who have got the correct answer may have different numbers of tries for doing homework. Figure 6 illustrates how many submissions the students have made before they get the right answer, which verifies our assumption. From Figure 6, we see that while student 1, 2 and 10 have given the right solution in their first submission, student 7 may have met more problems and has tried 7 times. It would cost him much more time and labor if he debugged his circuit in traditional experiment courses. For



Fig. 6. How many submissions the students have made

the instructors, such information provided by DCLab allows them to focus on certain particular students and help them accordingly.

We have also looked over when the students made their submissions. Figure 7 shows the distribution of submissions among the 24 one-hour intervals in a day, which demonstrates that DCLab provides a large flexibility for the students to choose suitable time to finish their experimental tasks.



Fig. 7. Distribution of submissions with respect to time

## V. CONCLUSION AND FUTURE WORK

In this paper, we propose DCLab, a web-based system for digital logic experiment teaching. DCLab combines two types of digital logic experiment and meets the requirements of the digital logic experiment course. Besides, DCLab keeps good interaction between students and instructors, which makes it suitable for educational practice. Experiment results have shown that DCLab can improve both the effectiveness and the efficiency of digital logic experiment teaching.

For future work, we will employ DCLab in courses with a larger number of students, and try to adapt it to the needs of students and instructors.

## REFERENCES

- X. Yan-xia, "Innovation and research of experimental teaching for digital electric circuit [j]," *Research and Exploration in Laboratory*, vol. 2, pp. 84–86, 2007.
- [2] O. B. Adamo, P. Guturu, and M. R. Varanasi, "An innovative method of teaching digital system design in an undergraduate electrical and computer engineering curriculum," in *Microelectronic Systems Education*, 2009. MSE'09. IEEE International Conference on. IEEE, 2009, pp. 25– 28.
- [3] L. Shanshan and Y. Shiqiang, "Digital logic experiment teaching based on experimental platform," in *Computer Science and Education (ICCSE)*, 2017 12th International Conference on. IEEE, 2017, pp. 33–37.
- [4] O. Farook, C. R. Sekhar, J. P. Agrawal, E. Bouktache, A. Ahmed, and H. Moghbelli, "Computer engineering technology program-a curriculum innovation initiative," in *American Society for Engineering Education*. American Society for Engineering Education, 2011.
- [5] L. Shanshan, W. Xiaojun, and Q. Chengbin, "Training students' practical and innovation ability in hardware experiment," in *Frontiers in Education Conference (FIE)*. IEEE, 2017, pp. 1–5.
- [6] O. Yang, Y. Shiping, D. Yabo, and Z. Miaoliang, "Web-based interactive virtual laboratory system for digital circuit experiment," in *Innovations* in *E-learning, Instruction Technology, Assessment, and Engineering Education.* Springer, 2007, pp. 305–309.
- [7] D. Kim, K. Choi, C. Jeon, J. Lim, S. Kim, S. Seo, and J. Yoo, "A webbased virtual laboratory system for electronic and digital circuits experiments," in *International Conference on Hybrid Learning and Education*. Springer, 2009, pp. 77–88.
- [8] B. Minaei-Bidgoli, D. A. Kashy, G. Kortemeyer, and W. F. Punch, "Predicting student performance: an application of data mining methods with an educational web-based system," in *Frontiers in education, 2003. FIE 2003 33rd annual*, vol. 1. IEEE, 2003, pp. T2A–13.