# Open Source Digital Camera on Field Programmable Gate Arrays

Cristinel Ababei, Shaun Duerr, Joe Ebel, Russell Marineau, Milad Ghorbani Moghaddam, and Tanzania Sewell Department of Electrical and Computer Engineering Marquette University, Milwaukee WI, USA

Email: {cristinel.ababei,shaun.duerr,william.ebeljr,russell.marineau,milad.ghorbanimoghaddam,tanzania.sewell}@marquette.edu

Abstract—We present an open source digital camera implemented on a field programmable gate array (FPGA). The camera functionality is completely described in VHDL and tested on the DE2-115 educational FPGA board. Some of the current features of the camera include video mode at 30 fps, storage of taken snapshots into SDRAM memories, and grayscale and edge detection filters. The main contributions of this project include 1) the actual system level design of the camera, tested and verified on an actual FPGA chip, and 2) the public release of the entire implementation including source code and documentation. While the proposed camera is far from being able to compete with commercial offerings, it can serve as a framework to test new research ideas related to digital camera systems, image processing, computer vision, etc., as well as an educational platform for advanced digital design with VHDL and FPGAs.

*Keywords*-FPGAs; digital camera; grayscale filter; edge detection; Sobel operator;

#### I. INTRODUCTION

Field programmable gate arrays (FPGAs) have become extremely popular in virtually all application domains. If in the early days FPGAs were used mostly as digital glue logic or for prototyping purposes, today they are used as integral parts of complex designs ranging from consumer electronics to communications, military, and space systems. The popularity of FPGAs has continuously increased not only because of the reduced performance gap between FPGAs and ASICs but also because of the great flexibility that reconfiguration offers when it comes to product development, maintenance and updates. Today, FPGAs represent the hardware platform of choice to implement and test digital designs for many circuit designers and educators. These include also contributors to online design resources such as Opencores [1], who test and validate their open source designs on various FPGA chips. Testing and validation on real FPGA chips increase the credibility and confidence in the correctness of these publicly available design resources.

In this paper, we present an open source baremetal digital camera completely described in VHDL and tested and validated on an FPGA chip. While one can find portions of the presented camera design publicly available, we are not aware of any publicly available, self-contained open source design that integrates the same functionality presented here. We make our implementation publicly available (including complete source code and documentation) with the hope that it will serve as a framework to test new research ideas related to digital camera systems, image processing, computer vision, etc., as well as an educational platform for advanced digital design with VHDL and FPGAs.

## II. BAREMETAL DIGITAL CAMERA SYSTEM

In this section, we present the proposed baremetal digital camera system. We discuss some of the design decisions and the main features.

The simplified block diagram of the proposed baremetal digital camera system on FPGA is shown in Fig.1. The main functionality of the camera includes video mode at 30 fps, the ability to take a snapshot and store it on the SDRAM memory or on the SD Card, the ability to fetch a snapshot from the SDRAM or SD Card and display it on the VGA display, grayscale filtering, and edge detection based on Sobel operator.



Fig. 1. Block diagram of the proposed baremetal digital camera system.

Next, we present details about each of the main features shown in the block diagram in Fig.1.

**Video mode.** This is the simplest operation mode of the digital camera. In this mode, the video stream coming out of the OV7670 CMOS camera module [2] is buffered inside the *RAM Frame Buffer 1* at a rate of 30 fps and a default frame size of 320x240 pixels. This buffer, like the *RAM Frame Buffer 2* in Fig.1, is implemented using existing RAM memory blocks

in the Cyclone IV E FPGA. These buffers can be written and read asynchronously at different write and read clocks. Each frame is used to drive, via the VGA Driver, the VGA display connected to the DE2-115 evaluation board. Writing and reading from the RAM Frame Buffer 1 is completed with a 25 MHz clock generated by one of the four PLL blocks within the Cyclone IV E FPGA chip. Thus, the *Capture Logic*, RAM Frame Buffer 1, and the VGA Driver form a datapath that pipelines the video frame data to the VGA display. The Capture Logic block from Fig.1 has the ability to program the camera module by writing into its registers desired values to control image format, color saturation, hue, and gamma. This is done through an I2C like interface connecting the camera module and the Capture Logic block. The camera module is connected using 16 of the GPIO connectors available on the DE2-115 board.

Take and display snapshot. Two of the four push buttons of the DE2-115 board are used to control the process of recording and displaying on request a single snapshot. In this case, when the *take\_snapshot* button is pressed, a frame from *RAM Frame Buffer 1* is taken and stored inside either SDRAM or SDCard memory. When the *display\_snapshot* button is pressed, the frame or image data previously saved is retrieved from SDRAM or SDCard and buffered inside *RAM Frame Buffer 2*. The output of *RAM Frame Buffer 2* is then steered through a multiplexer to the *VGA Driver*. The multiplexer shown in Fig.1 is controlled such that the snapshot is displayed on the VGA display only while the *display\_snapshot* button is pressed.

**Grayscale filter.** A third push button of the board is used to apply a grayscale filter to the snapshot that is displayed. When this *grayscale* button is pressed, the image data from *RAM Frame Buffer 2* is read pixel by pixel, processed using the averaging technique, and then written back into the buffer at a clock rate of 25 MHz. The averaging technique calculates the average of three colors and is the simplest one among other grayscale techniques. For a given RGB image, we compute the grayscale value for a pixel with the following expression:

$$Grayscale = \frac{R+G+B}{3} \tag{1}$$

where R, G, and B are the color codes for each of the three color channels red, green, and blue of the given pixel. This filter can be implemented using two adders and a divider circuit that can be implemented using very little FPGA resources.

**Edge detection filter.** The fourth push button of the board is used to apply the popular Sobel operator to the snapshot that is displayed. This effectively implements an edge detection filter, which can be very useful for various realtime computer vision applications. The implementation of this filter is a bit more involved and requires more FPGA resources. Our implementation is similar to that described in [3], [4]. It basically uses a shift register (whose length is 2W, where W = 320 is the width of the image as number of pixels per row or line) and an approximate calculation of the so called gradient magnitude as illustrated in Fig.2.

The Sobel operator is a discrete differentiation operator, that computes an approximation of the gradient of the image intensity function. Because the Sobel operator is based on convolving the image with a small, separable, and integer valued filter in both horizontal and vertical directions, it is relatively inexpensive in terms of computations – hence easily implemented on an FPGA. The operator uses two 3x3 kernels, which are convolved with the original image to calculate approximations of the derivatives – for horizontal and vertical changes. If we define A as the source image, and  $G_x$  and  $G_y$  are two images which at each point contain the horizontal and vertical derivative approximations, then, the computations are as follows:

$$\mathbf{G}_{x} = \begin{bmatrix} -1 & 0 & +1 \\ -2 & 0 & +2 \\ -1 & 0 & +1 \end{bmatrix} * \mathbf{A}$$
(2)

$$\mathbf{G}_{y} = \begin{bmatrix} -1 & -2 & -1 \\ 0 & 0 & 0 \\ +1 & +2 & +1 \end{bmatrix} * \mathbf{A}$$
(3)

where \* denotes the 2-dimensional convolution operation. The gradient magnitude is given by the following equation:

$$|\mathbf{G}| = \sqrt{\mathbf{G}_x^2 + \mathbf{G}_y^2} \approx |\mathbf{G}_x| + |\mathbf{G}_y|$$
(4)

The circuit from Fig.2.b generates the value in equation 4 for each pixel of the grayscale image and compares it to a threshold (e.g., decimal 127 when working with colors represented on 8 bits per channel; but this threshold can be fine tuned by the user) and then sets the final result as either white or the value itself (which can also be replaced with black if black and white type edge detection is desired).

While the block diagram from Fig.1 includes a JPEG encoder/decoder component, our current implementation (discussed in the next section) does not include this component yet. The implementation of the JPEG encoder/decoder block is under development. Currently, images are saved to memory and fetched from memory as raw pixel data, in an uncompressed format. Note that while the JPEG compression is desirable for the sake of reducing the amount of storage space, working with raw pixel data is preferable in realtime computer vision like image processing applications.

#### **III. EXPERIMENTAL RESULTS AND DISCUSSION**

In this section, we present the experimental setup and results obtained with the current implementation of the digital camera system.

#### A. Experimental Results

The entire functionality of the camera, as discussed in the previous section, was coded in VHDL, synthesized, placed, and routed with Quartus II Web Edition 14.1 design environment [5]. The camera design was tested and verified on the DE2-115 development board [6], which contains Altera's Cyclone IV E FPGA chip [7]. Some of the key aspects of the summary report provided by Quartus II tool are reported in Table I. Note that the overall resource utilization is very



Fig. 2. (a) Illustration of the application of Sobel kernels using a sliding window approach that starts with being centered on pixel (0, 0), labeled a1 and ends on pixel (W-1, H-1). (b) The hardware implementation uses two shift registers (Wx8 bits), three simple load registers (Wx3), a comparator, and a circuit to compute  $|\mathbf{G}_x| + |\mathbf{G}_y|$ .

small at around 1%. This leaves plenty of room for additional functionality that may be added to the system. Also note that, most of the embedded block RAMs existing on the Cyclone IV E FPGA chip are used (79%). This higher memory utilization is due to the two buffers, *RAM Frame Buffer 1* and *RAM Frame Buffer 2* from Fig.1, which are sized such that they can store data for 320x240 pixel images. The design uses one of the four PLLs available on the FPGA chip. The PLL is used to generate four different clock signals with frequencies of 25 MHz, 50 MHz, 100 MHz, and 100 MHz with a clock phase shift of -3 ns. The 50 MHz signal is used by the capture logic block, the 100 MHz signal are required by the SDRAM controller, and the 25 MHz signal is used by most other blocks in the design.

 TABLE I

 Summary of the fitter report as given by Quartus II tool.

| Item                      | Report                      |
|---------------------------|-----------------------------|
| Family                    | Cyclone IV E                |
| Device                    | EP4CE115F29C7               |
| Total logic elements      | 1,616 / 114,480 ( 1% )      |
| Dedicated logic registers | 818 / 114,480 ( < 1% )      |
| Total registers           | 818                         |
| Total pins                | 94 / 529 ( 18% )            |
| Total memory bits         | 3,152,384 / 3,981,312 (79%) |
| Total PLLs                | 1 / 4 ( 25% )               |

The experimental set-up (see Fig.3) includes the DE2-115 with a OV7670 camera module attached via the GPIO connector and a 640x480 VGA monitor attached via the VGA port available on the board. The four push buttons (already debounced, by design of the DE2-115 board) available on the DE2-115 board are used as *take\_snapshot*, *display\_snapshot*, *grayscale*, and *edge\_detection* buttons to control the system. The default mode of operation is the video mode, which works at 30 fps.



Fig. 3. The experimental setup includes the DE2-115 board that has the OV7670 camera module and a VGA monitor attached to it. Images are captured by the camera and displayed on the VGA display as 320x240 pixel images.

Fig.4 and Fig.5 illustrate the operation of the camera system when a snapshot is taken, saved, and displayed (parts (a) of these figures), when the grayscale filter is applied to the snapshot retrieved from the memory (parts (b)), and when the edge detection (e.g., Sobel) filter is applied (parts (c)).

## B. Discussion and Future Work

The proposed baremetal digital camera has been successfully prototyped and tested on real hardware. We consider as its main contributions and merits the following:

- The system level design in VHDL and deployment for testing and verification on a widely popular FPGA board. The actual implementation requires a very small amount of existing resources on the Altera's Cyclone IV E FPGA chip.
- The entire design sources are made publicly available. This includes completed and working VHDL source code as well as detailed documentation. Our hope is that this open source digital camera design will encourage further research and educational ideas in the areas of image processing and advanced VHDL design and FPGAs. The entire project can be downloaded from [8].









(c)

Fig. 4. (a) Example of taken snapshot; objects in the image are within 30 cm of the camera module. (b) The grayscale filter applied to the snapshot. (c) The edge detection filter applied to the snapshot.

As ongoing and future work, we are designing and will manufacture a small PCB board – which will also be made open source – to implement the presented digital camera as a stand alone yet extendable application. This PCB board is built around the same FPGA chip and will also include one SDRAM memory chip, one SD Card slot, a small Flash memory, a USB driver, a driver for 3.2-inch color TFT 320X240 display, four push buttons, and four LEDs. The footprint of this custom







(c)

Fig. 5. (a) Example of taken snapshot; objects in the image are within 3 m of the camera module. (b) The grayscale filter applied to the snapshot. (c) The edge detection filter applied to the snapshot.

PCB is similar to that of a regular Arduino board.

# IV. CONCLUSION

We introduced an open source baremetal digital camera, which was entirely specified in VHDL. The camera system was tested and validated on the popular DE2-115 educational FPGA board, which is constructed around the Cyclone IV FPGA family. The entire design is made publicly available including source code and documentation. We hope that this project will serve as a framework to test new research ideas related to digital camera systems, image processing, computer vision, etc., as well as an educational platform for advanced digital design with VHDL and FPGAs.

# ACKNOWLEDGMENT

This work was supported by the Department of Electrical and Computer Engineering and the OPUS College of Engineering at Marquette University.

#### REFERENCES

- Opencores community for development of hardware IP cores as open source, 2015. [Online]. Available: http://opencores.org/.
- [2] OV7670 Camera Module with OmniVision CMOS Sensor, Datasheet, 2015. [Online]. Available: http://www.cutedigi.com/pub/sensor/ Imaging/OV7670-Datasheet.pdf.
- [3] C. Moore, H. Devos, and D. Stroobandt, "Optimizing the FPGA memory design for a Sobel edge detector," Int. Conf. on Engineering of Reconfigurable Systems & Algorithms (ERSA), 2009.
- [4] S. Singh, A.K. Saini, R. Saini, A.S. Mandal, C. Shekhar, and A. Vohra, "Area optimized FPGA-based implementation of the Sobel compass edge detector," *Hindawi ISRN Machine Vision*, 2013.
- [5] Quartus II Web Edition Software 14.1, 2015. [Online]. Available: http://www.altera.com/products/software/quartus-ii/web-edition/ qts-we-index.html.
- [6] DE2-115 Development and Education Board, 2015. [Online]. Available: http://www.altera.com/education/univ/materials/boards/de2-115/ unv-de2-115-board.html.
- [7] Cyclone IV FPGA Family: Lowest Cost, Lowest Power, Integrated Transceivers, 2015. [Online]. Available: http://www.altera.com/devices/ fpga/cyclone-iv/cyiv-index.jsp.
- [8] Software downloads at MESS Lab, Marquette University, 2016. [Online]. Available: http://dejazzer.com/digital\_camera.html.