System-Verilog 实现DE2-115 流水灯

news2024/12/26 18:23:41

文章目录

  • 一、什么是SystemVerilog
  • 二、代码实现
  • 实现结果

一、什么是SystemVerilog

SystemVerilog是一种硬件描述语言(HDL),它用于设计和验证电子系统,特别是在集成电路(IC)和系统级芯片(SoC)的设计过程中。SystemVerilog是Verilog语言的一个超集,它添加了许多新的特性和增强功能,使得设计者可以更高效地进行工作。

应用领域:

  • 集成电路设计:SystemVerilog用于设计从简单的门电路到复杂的SoC(System on Chip)。
  • 仿真和原型设计:用于快速原型设计和仿真,以验证设计的功能和性能。
  • 形式验证:与形式验证工具结合使用,以数学方式证明设计的属性。
  • 硬件-软件协同设计:支持硬件和软件的并行开发,确保两者的兼容性。

SystemVerilog的一些关键特性:

  • 面向对象编程(OOP):SystemVerilog支持类(class)和对象(object)的概念,允许设计者以面向对象的方式进行设计,提高代码的可重用性和模块化。

  • 接口(Interfaces):接口是SystemVerilog中用于模块间通信的一种机制,它允许设计者定义一组信号和协议,使得模块间的连接更加灵活和标准化。

  • 序列(sequence):序列是SystemVerilog中用于定义特定事件模式的语法结构,它在验证设计行为时非常有用。

  • 属性(property):属性用于定义设计中必须满足的条件或行为,它们可以用于断言(assertion)来检查设计是否符合预期。

  • 随机化(Rand):SystemVerilog支持随机化测试,可以自动生成测试向量,提高测试的覆盖率和效率。

  • 约束(Constraints):约束用于定义变量的取值范围或条件,它们在随机化测试中非常有用,可以确保生成的测试向量满足特定的要求。

  • 覆盖率(Coverage):SystemVerilog提供了覆盖率分析工具,可以评估测试的完整性,帮助设计者发现可能遗漏的测试场景。

  • 系统任务和函数(System Tasks and Functions):SystemVerilog扩展了系统任务和函数,提供了更多的内置功能,如文件操作、随机数生成等。

  • 多维数组(Multidimensional Arrays):SystemVerilog支持多维数组,使得设计者可以更方便地处理复杂的数据结构。

  • 包(Packages):包是SystemVerilog中用于组织代码的一种方式,它允许设计者定义一组相关的类型、常量、变量和子程序,这些可以在多个模块中共享。

SystemVerilog的这些特性使得它成为现代集成电路设计和验证的强大工具,特别是在处理复杂的系统级设计和高级验证任务时。

二、代码实现

led_chaser.sv

module led_chaser (
    input logic CLOCK_50,  // 50MHz时钟输入
    input logic reset_n,   // 复位信号,低电平有效
    output logic [9:0] LED // 10个LED灯输出
);

    // 定义一个计数器,用于产生慢速时钟
    logic [23:0] counter;

    always_ff @(posedge CLOCK_50 or negedge reset_n) begin
        if (!reset_n) begin
            counter <= 24'd0;
        end else begin
            counter <= counter + 24'd1;
        end
    end

    // 用慢速时钟控制LED的变化
    logic slow_clk;
    assign slow_clk = counter[23]; // 选择较高位做为慢速时钟

    // LED流水灯的状态
    logic [9:0] led_state;
    always_ff @(posedge slow_clk or negedge reset_n) begin
        if (!reset_n) begin
            led_state <= 10'b0000000001; // 初始状态,第一个LED点亮
        end else begin
            led_state <= {led_state[8:0], led_state[9]}; // 左移,循环点亮
        end
    end

    // 将led_state连接到LED输出
    assign LED = led_state;

endmodule

测试文件
led_chaser_tb.vt

`timescale 1ns / 1ps

module led_chaser_tb;

    // 输入信号
    logic CLOCK_50;
    logic reset_n;
    
    // 输出信号
    logic [9:0] LED;

    // 实例化被测模块
    led_chaser uut (
        .CLOCK_50(CLOCK_50),
        .reset_n(reset_n),
        .LED(LED)
    );

    // 时钟产生器,模拟50MHz时钟
    initial begin
        CLOCK_50 = 0;
        forever #10 CLOCK_50 = ~CLOCK_50; // 50MHz时钟周期为20ns
    end

    // 复位信号生成
    initial begin
        // 初始化信号
        reset_n = 1'b0;
        // 等待100ns,然后释放复位信号
        #100 reset_n = 1'b1;
    end

    // 监视信号
    initial begin
        $monitor("Time = %0t | reset_n = %b | LED = %b", $time, reset_n, LED);
    end

    // 结束仿真
    initial begin
        // 运行足够长时间以观察多个LED灯的变化
        #2000 $stop;
    end

endmodule

实现结果

成功实现了流水灯。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1828916.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

存储器的性能指标以及层次化存储器

存储器的性能指标 存储器有三个性能指标&#xff1a;速度、容量和位价&#xff08;每位价格&#xff09; 1.存储速度 &#xff08;1&#xff09;存取时间 想衡量存储速度&#xff0c;最直观的指标就是完成一次存储器读写操作所需要的时间&#xff0c;这叫做存取时间&#x…

如何交叉编译Libsndfile

Libsndfile 是一个用于读取和写入文件的 C 库&#xff0c;它支持多种音频文件格式&#xff0c;包括 WAV、AIFF、FLAC 等。这个库提供了一个简单的 API 来处理音频数据&#xff0c;使得开发者可以在他们的应用程序中轻松地集成音频文件的读写功能。今天介绍一下如何针对x210平台…

C++ 45 之 赋值运算符的重载

#include <iostream> #include <string> #include <cstring> using namespace std;class Students05{ public:int m_age;char* m_name;Students05(){}Students05(const char* name,int age){// 申请堆空间保存m_name;this->m_name new char[strlen(name)…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 部门项目任务分配(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 📎在线评测链接 部门项目任务分配(100分) 🌍 评测功能需要订阅专栏后私信联…

代码随想录——组合总和Ⅱ(Leetcode 40)需要回顾

题目链接 回溯 本题的难点在于&#xff1a;集合&#xff08;数组candidates&#xff09;有重复元素&#xff0c;但还不能有重复的组合。 思想&#xff1a;元素在同一个组合内是可以重复的&#xff0c;怎么重复都没事&#xff0c;但两个组合不能相同。所以要去重的是同一树…

HAL库开发--SPI的配置方式和读写操作

知不足而奋进 望远山而前行 目录 文章目录 前言 目标 内容 需求 SPI配置 SPI编码 OLED驱动拷贝 OLED的GPIO初始化修改 实现SPI的读写 总结 前言 SPI&#xff08;Serial Peripheral Interface&#xff09;是一种常见的串行通信协议&#xff0c;在嵌入式系统中被广泛…

技巧解析,如何向Kimi提问才能写出更好的论文?

学境思源&#xff0c;一键生成论文初稿&#xff1a; AcademicIdeas - 学境思源AI论文写作 今天为大家整理、分享的Kimi提问技巧&#xff0c;将对论文写作的各个阶段提供帮助&#xff0c;可以以此来辅助学术论文撰写。 在此之前&#xff0c;先为大家科普一个概念——信息熵&am…

常见的宽基指数基金

指数基金投资指南 ❝ 这篇博客里面的内容主要来自于银行螺丝钉的《定投十年&#xff0c;财务自由》和《指数基金投资指南》这两本书中章“常见的宽基指数”&#xff0c;最近第三次读这本书&#xff0c;打算做一点笔记加深自己的印象。 博客中很多内容是从书中摘抄的&#xff0c…

面试官:Java中缓冲流真的性能很好吗?我看未必

一、写在开头 上一篇文章中&#xff0c;我们介绍了Java IO流中的4个基类&#xff1a;InputStream、OutputStream、Reader、Writer&#xff0c;那么这一篇中&#xff0c;我们将以四个基类所衍生出来&#xff0c;应对不同场景的数据流进行学习。 二、衍生数据流分类 我们上面…

python15 数据类型 集合类型

集合类型 无序的不重复元素序列 集合中只能存储不可变的数据类型 声明集合 使用 {} 定义 与列表&#xff0c;字典一样&#xff0c;都是可变数据类型 代码 集合类型 无序的不重复元素序列 集合中只能存储不可变的数据类型 声明集合 使用 大括号{} 定义 与列表&#xff0c;字典一…

【Python】理解『下采样』:原理与应用

是你多么温馨的目光 教我坚毅望着前路 叮嘱我跌倒不应放弃 没法解释怎可报尽亲恩 爱意宽大是无限 请准我说声真的爱你 &#x1f3b5; Beyond《真的爱你》 在数字信号处理、图像处理和机器学习中&#xff0c;下采样&#xff08;Downsampling&#xff09;是…

【Linux】 进程信号的发生

送给大家一句话&#xff1a; 何必向不值得的人证明什么&#xff0c;生活得更好&#xff0c;乃是为你自己。 -- 亦舒 进程信号的发生 1 何为信号2 信号概念的基础储备3 信号产生kill系统调用alarm系统调用异常core term Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢…

Blossom:支持私有部署的云端双链笔记软件分享

Blossom 是一款支持私有部署的云端双链笔记软件&#xff0c;能够帮助用户将笔记、图片和个人计划安排保存在自己的服务器中&#xff0c;并在任意设备之间实时同步。同时&#xff0c;它还可以作为一个动态博客使用。本文将详细介绍 Blossom 的特点和使用方法。 一、Blossom 的特…

CPN Tools学习——从平面网构建分层 PN

1.先创建平面petri网 创建如下petri网&#xff1a; CPN ide创建petri网真的舒服很多&#xff0c;但是教程又是CPN Tools的&#xff0c;我的想法是看两个版本能不能互通&#xff0c;在前者创建&#xff0c;在后者运行学习。 新增定义&#xff1a; colset E unit with e; 但…

探索Web Components

title: 探索Web Components date: 2024/6/16 updated: 2024/6/16 author: cmdragon excerpt: 这篇文章介绍了Web Components技术&#xff0c;它允许开发者创建可复用、封装良好的自定义HTML元素&#xff0c;并直接在浏览器中运行&#xff0c;无需依赖外部库。通过组合HTML模…

刷题记录(240613)

aliyun0512 1. 小红定义一个数组是好数组&#xff0c;当且仅当所有奇数出现了奇数次&#xff0c;所有偶数出现了偶数次。现在小红拿到了一个数组&#xff0c;她希望取一个该数组的非空子序列(可以不连续)&#xff0c;使得子序列是好数组。你能帮小红求出子序列的方案数吗?由于…

手机照片免费数据恢复软件EasyRecovery2024免费版下载

大家好&#xff01;今天我要给大家推荐一款非常棒的软件——EasyRecovery。相信大家都知道&#xff0c;电脑中的重要文件一旦丢失&#xff0c;对我们的工作和学习都会产生很大的影响。 而EasyRecovery软件就是专门解决这个问题的利器&#xff01;它能够帮助我们快速、有效地恢…

几种经典排序算法

几种经典排序算法 插入排序折半插入排序法 选择排序冒泡排序希尔排序堆排序二路归并排序快速排序 在介绍排序之前&#xff0c;先来说说&#xff0c;研究不同的排序主要是要研究他们的哪些不同&#xff1a; 时间性能。即排序过程中元素之间的比较次数与元素移动次数。我们此次讨…

【JavaEE进阶】——利用框架完成功能全面的图书管理系统

目录 &#x1f6a9;项目所需要的技术栈 &#x1f6a9;项目准备工作 &#x1f388;环境准备 &#x1f388;数据库准备 &#x1f6a9;前后端交互分析 &#x1f388;登录 &#x1f4dd;前后端交互 &#x1f4dd;实现服务器代码 &#x1f4dd;测试前后端代码是否正确 &am…

Caffe、PyTorch、Scikit-learn、Spark MLlib 和 TensorFlowOnSpark 概述

在 AI 框架方面,有几种工具可用于图像分类、视觉和语音等任务。有些很受欢迎,如 PyTorch 和 Caffe,而另一些则更受限制。以下是四种流行的 AI 工具的亮点。 Caffee Caffee是贾扬青在加州大学伯克利分校(UC Berkeley)时开发的深度学习框架。该工具可用于图像分类、语音和…