Legal project definition: Sharpness and edge detection on programmable logic for real-time video stream data to be able to accelerate further image processing which will be established on SoC CPU after DMA.
Team members:
- Ertuğrul Tiyek (21828916)
- Eyüp Enes Aytaç
- Halil İbrahim Çobanoğlu
- Hasan Can Demir (21947157)
- Ahmet Yusuf Şirin (21947641)
This repository contains the Quartus project for lane detection using a Sobel-like filter on an FPGA, specifically implemented on the Altera DE1-SoC development board. The project utilizes an OV7670 camera for video input and incorporates FuseSoC to streamline the continuous integration and deployment (CICD) processes.
- Introduction
- Getting Started
- Prerequisites
- Installation
- Directory Structure
- Usage
- Contributing
- License
Lane detection is a fundamental task in computer vision, particularly for autonomous vehicles and advanced driver assistance systems (ADAS). This project focuses on implementing a Sobel-like filter on an FPGA to detect lanes in real-time. The Altera DE1-SoC development board serves as the hardware platform, while the OV7670 camera provides the video input.
To facilitate seamless integration and automation, the project incorporates FuseSoC. FuseSoC simplifies the management of IP cores and libraries, enabling an efficient and scalable development workflow. Additionally, the project leverages Git version control and GitHub tools like issues to facilitate collaboration among team members.
To get started with the project, follow the instructions below.
- Quartus Prime software (version X.X or later): Download
- DE1-SoC Board Support Package (BSP): Download
- Git version control system: Download
- FuseSoC: Installation Guide
- Clone the repository:
git clone https://github.com/ayusufsirin/ele432_project/
-
Install Quartus Prime software according to the instructions provided by Intel.
-
Download and install the DE1-SoC BSP package from the Terasic website.
-
Install Git and configure your global settings (if not already done).
-
Install FuseSoC by following the installation guide provided in the FuseSoC repository.
The workspace for this project follows the following directory structure:
-
workspace: This directory contains the compiled project files for Quartus, including the generated output files, such as the programming files and project configuration files.
-
hdl: The
hdl
directory contains the generic IP core files. These files define the hardware design components used in the project, such as modules, interfaces, and entities. -
ip: The
ip
directory contains the IP cores specifically developed for Quartus. These cores are reusable hardware components that can be integrated into the project design. Examples of IP cores include processors, memory modules, and communication interfaces. -
report: The
report
directory contains the project report, which provides detailed information about the design, implementation, and results of the lane detection FPGA project. It may include performance analysis, optimization strategies, and other relevant documentation.
Please refer to the specific directories for more details on their contents and organization. Ensure that you maintain the directory structure when working with the project to ensure proper file references and ease of navigation.
-
Connect the Altera DE1-SoC development board to your computer.
-
Open the Quartus Prime software and load the Quartus project file (
digital_cam_impl1.qpf
) located in the project sub-directoryworkspace
. -
Configure the project settings as needed.
-
Build the project by selecting the appropriate build configuration and clicking on the "Start Compilation" button.
-
Once the compilation is complete, program the FPGA using Quartus Prime.
-
Connect the OV7670 camera to the appropriate interface on the DE1-SoC board.
-
Power on the board and execute the lane detection application.
-
Monitor the output on the display or via the UART interface, as specified in your design.
For more detailed information or troubleshooting, refer to the project documentation.
Contributions to this project are welcome. To contribute, please follow these steps:
-
Fork the repository.
-
Create a new branch for your feature or bug fix.
-
Make the necessary changes in your branch.
-
Test your changes thoroughly.
-
Commit your changes and push the branch to your fork.
-
Submit a pull request to the main repository.
Please ensure that your contributions adhere to the coding standards, and include appropriate documentation where necessary.
This project is licensed under the MIT License. You are free to modify, distribute, and use the code in this project for personal or commercial purposes. See the LICENSE file for more details.