当前位置: 首页 > news >正文

gowin GW1N4 LED

基于上已篇文章基础上增加LED闪烁的功能

 《gowin GW1N4 OSC IP 使用》 gowin GW1N4 OSC IP 使用-CSDN博客 https://blog.csdn.net/wzy15965343032/article/details/136172184?spm=1001.2014.3001.5502

代码:

module osc_test(input rst_n,output test_clk,output reg led,output led2
);
parameter BLINK_PERIOD = 12_500_000;  // LED 翻转周期//parameter BLINK_PERIOD = 0.5 / (1 / 50,000,000) = 25,000,000
//parameter BLINK_PERIOD = 0.5 / (1 / 25,000,000) = 12,500,000reg [31:0] counter;  // 32 bits counter for BLINK_PERIOD cycles
wire clkin;Gowin_OSC my_osc (.oscout(clkin)
);assign test_clk = clkin;
assign led2 = led;always @(posedge clkin or negedge rst_n) beginif (~rst_n) begin  // Reset counter and LED on negative edge of rst_ncounter <= 0;led <= 0;end else beginif (counter == BLINK_PERIOD) begin  // Toggle LED every BLINK_PERIOD cyclesled <= ~led;counter <= 0;  // Reset counterend else begincounter <= counter + 1;  // Increment counterendend
endendmodule

这段代码定义了一个名为 osc_test 的模块,其中包含了一个时钟信号 clkin,一个复位信号 rst_n,以及两个输出信号 ledled2

  • parameter BLINK_PERIOD = 12_500_000; 定义了 LED 翻转的周期,即 LED 每隔 BLINK_PERIOD 个时钟周期翻转一次。
  • reg [31:0] counter; 定义了一个 32 位的寄存器 counter,用于计数时钟周期。
  • wire clkin; 定义了一个时钟信号输入端口 clkin
  • Gowin_OSC my_osc (.oscout(clkin)); 实例化了一个名为 my_oscGowin_OSC 模块,将其输出端口 oscout 连接到 clkin
  • assign test_clk = clkin;clkin 赋值给 test_clk,用于输出测试时钟信号。
  • assign led2 = led;led 的状态赋值给 led2,使得 led2led 同步。

接下来是一个 always 块,用于控制 LED 的翻转。在时钟信号 clkin 的上升沿或复位信号 rst_n 的下降沿触发时执行。如果复位信号 rst_n 为低电平,则将 counterled 复位为 0;否则,当 counter 达到 BLINK_PERIOD 时,翻转 led 并将 counter 复位为 0,否则递增 counter

最后,注释部分是被注释掉的之前的代码,可能是之前版本的 LED 翻转实现。

相关文章:

gowin GW1N4 LED

基于上已篇文章基础上增加LED闪烁的功能 《gowin GW1N4 OSC IP 使用》 gowin GW1N4 OSC IP 使用-CSDN博客 https://blog.csdn.net/wzy15965343032/article/details/136172184?spm1001.2014.3001.5502 代码&#xff1a; module osc_test(input rst_n,output test_clk,output …...

Linux ipvlan详解(l2、l3、l3s和bridge、private和vepa模式)

Linux ipvlan详解&#xff0c;测试l2、l3、l3s和bridge、private和vepa模式。 最近在看Docker的网络&#xff0c;看到关于ipvlan网络的介绍。查阅了相关资料&#xff0c;记录如下。 参考 1.图解几个与Linux网络虚拟化相关的虚拟网卡-VETH/MACVLAN/MACVTAP/IPVLAN 2.IPVlan 详…...

理解并实现OpenCV中的图像平滑技术

导读 图像模糊&#xff08;也称为图像平滑&#xff09;是计算机视觉和图像处理中的基本操作之一。模糊图像通常是噪声减少、边缘检测和特征提取等应用的第一步。在本博客中&#xff0c;我们将重点介绍如何使用Python中的OpenCV库应用多种模糊技术。 理论概述&#xff1a; 基本…...

ChatGPT高效提问—prompt实践(白领助手)

ChatGPT高效提问—prompt实践&#xff08;白领助手&#xff09; ​ 随着社会的不断发展&#xff0c;白领的比例越来越高。白领的工作通常较为繁忙&#xff0c;需要管理复杂的项目。工作量大、要求高、任务紧急&#xff0c;时间分配不当部分可能导致工作效率低下&#xff0c;任…...

Code Composer Studio (CCS) - Comment (注释)

Code Composer Studio [CCS] - Comment [注释] References Add Block Comment: 选中几行代码 -> 鼠标右键 -> Source -> Add Block Comment shortcut key: Ctrl Shift / Remove Block Comment: 选中几行代码->鼠标右键->Source->Remove Block Comment s…...

springboot/ssm校园菜鸟驿站管理系统Java校园快递取件管理系统

springboot/ssm校园菜鸟驿站管理系统Java校园快递取件管理系统 开发语言&#xff1a;Java 框架&#xff1a;springboot&#xff08;可改ssm&#xff09; vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.…...

【Mybatis】TypeHandler使用

引言 在使用MyBatis进行项目开发时&#xff0c;我们经常会遇到Java类型与数据库类型不匹配的情况。为了解决这一问题&#xff0c;MyBatis提供了一个强大的机制——TypeHandler。TypeHandler是MyBatis中一个用于处理Java类型和数据库类型转换的组件&#xff0c;它在MyBatis进行…...

[计算机网络]---网络编程套接字

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、基础知识…...

分布式文件系统 SpringBoot+FastDFS+Vue.js【二】

分布式文件系统 SpringBootFastDFSVue.js【二】 六、实现上传功能并展示数据6.1.创建数据库6.2.创建spring boot项目fastDFS-java6.3.引入依赖6.3.fastdfs-client配置文件6.4.跨域配置GlobalCrosConfig.java6.5.创建模型--实体类6.5.1.FastDfsFile.java6.5.2.FastDfsFileType.j…...

开源软件:推动软件行业繁荣的力量

文章目录 &#x1f4d1;引言开源软件的优势分析开放性与透明度低成本与灵活性创新与协作 开源软件对软件行业的影响推动技术创新和进步促进软件行业的合作与交流培养人才和提高技能促进软件行业的可持续发展 结语 &#x1f4d1;引言 随着信息技术的飞速发展&#xff0c;软件已经…...

[杂记]mmdetection3.x中的数据流与基本流程详解(数据集读取, 数据增强, 训练)

之前跑了一下mmdetection 3.x自带的一些算法, 但是具体的代码细节总是看了就忘, 所以想做一些笔记, 方便初学者参考. 其实比较不能忍的是, 官网的文档还是空的… 这次想写其中的数据流是如何运作的, 包括从读取数据集的样本与真值, 到数据增强, 再到模型的forward当中. 0. MMDe…...

阿里云香港轻量应用服务器怎么样,建站速度快吗?

阿里云香港服务器中国香港数据中心网络线路类型BGP多线精品&#xff0c;中国电信CN2高速网络高质量、大规格BGP带宽&#xff0c;运营商精品公网直连中国内地&#xff0c;时延更低&#xff0c;优化海外回中国内地流量的公网线路&#xff0c;可以提高国际业务访问质量。阿里云服务…...

事务及在SpringBoot项目中使用的两种方式

1.事务简介 事务&#xff08;transaction&#xff09;是访问并可能操作各种数据项的一个数据库操作序列&#xff0c;这些操作要么全部执行&#xff0c;要么全部不执行&#xff0c;是一个不可分割的工作单位。 事物的四大特性: 原子性&#xff08;Atomicity&#xff09;&#xf…...

stm32--笔记

一、引脚与变量 ​​​​​​​​​​​​​​ 二、STM32时钟 [STM32-时钟系统详解_stm32时钟_KevinFlyn的博客-CSDN博客] 三、定时器中断实验 1、定时器中断实验 ​ stm32关于通用定时器的周期、频率计算公式_stm32tim频率计算_胶囊咖啡的博客-CSDN博客 ​ 【STM32】通用…...

2024前端面试准备之CSS篇(二)

全文链接 1. 什么是伪类和伪元素 伪类(Pseudo-class): 伪类是选择器的一种,用于选择特定状态或条件下的元素。它们以冒号(:)开头,用于向选择器添加额外的特定条件。例如,:hover伪类用于选择鼠标悬停在元素上的状态,:nth-child(n)伪类用于选择父元素下的第n个子元素等。…...

轨道交通信号增强与覆盖解决方案——经济高效,灵活应用于各类轨道交通场景!

方案背景 我国是世界上轨道交通里程最长的国家&#xff0c;轨道交通也为我们的日常出行带来极大的便利。伴随着无线通信技术的快速发展将我们带入电子时代&#xff0c;出行的过程中对无线通信的依赖程度越来越高&#xff0c;无论是车站还是车内都需要强大、高质量的解决方案以…...

学习数据接构和算法的第10天

题目讲解 尾插 #include <stdio.h> #include <stdlib.h> // 定义顺序表结构 #define MAX_SIZE 100 struct ArrayList {int array[MAX_SIZE];int size; // 当前元素个数 }; // 初始化顺序表 void init(struct ArrayList *list) {list->size 0; // 初始时元素个…...

初识KMP算法

目录 1.KMP算法的介绍 2.next数组 3.总结 1.KMP算法的介绍 首先我们会疑惑&#xff0c;什么是KMP算法&#xff1f;这个算法是用来干什么的&#xff1f; KMP&#xff08;Knuth-Morris-Pratt&#xff09;算法是一种用于字符串匹配的经典算法&#xff0c;它的目标是在一个主文本…...

Javaweb之SpringBootWeb案例之AOP概述及入门的详细解析

2.1 AOP概述 什么是AOP&#xff1f; AOP英文全称&#xff1a;Aspect Oriented Programming&#xff08;面向切面编程、面向方面编程&#xff09;&#xff0c;其实说白了&#xff0c;面向切面编程就是面向特定方法编程。 那什么又是面向方法编程呢&#xff0c;为什么又需要面向…...

【Java代码洁癖】NO.2 单元测试mock显式赋值,不能忍

反例 RunWith(MockitoJunitRunner.class) public class Test {Mockpublic SomeBean someBean new SomeBean(); } 正例 RunWith(MockitoJunitRunner.class) public class Test {Mockpublic SomeBean someBean ; } 解读 使用Mock注解的对象不应该被显式赋值&#xff0c;应当…...

无敏感信息下的机器学习公平性:两大前沿框架与工程实践

1. 机器学习公平性&#xff1a;从理论到无人口统计信息的实战在算法决策日益渗透到信贷审批、司法风险评估、招聘筛选等关键社会领域的今天&#xff0c;一个尖锐的问题浮出水面&#xff1a;我们如何确保这些“智能”系统不成为偏见与歧视的放大器&#xff1f;机器学习公平性&am…...

机器学习笔记本崩溃深度解析:高频错误类型、根因与实战避坑指南

1. 项目概述与核心价值 在机器学习&#xff08;ML&#xff09;项目开发中&#xff0c;尤其是在Jupyter Notebook这类交互式环境中&#xff0c;代码执行到一半突然崩溃&#xff0c;弹出一堆令人费解的红色错误信息&#xff0c;是每个开发者都经历过的“日常”。这些崩溃不仅打断…...

机器学习赋能软件工程:从缺陷预测到代码生成的实践指南

1. 项目概述与核心价值作为一名在软件工程领域摸爬滚打了十几年的老兵&#xff0c;我亲眼见证了从瀑布模型到敏捷开发&#xff0c;再到如今DevOps和AI驱动的开发范式的变迁。最近几年&#xff0c;一个最深刻的感受是&#xff1a;我们写的代码和构建的系统越来越复杂&#xff0c…...

JMeter梯度压测:精准定位系统可扩展性边界

1. 为什么“梯度式压测”不是加个线程组就完事了&#xff1f;很多人第一次打开JMeter&#xff0c;照着教程建个线程组、加个HTTP请求、跑个聚合报告&#xff0c;看到TPS从200涨到800就以为“压测完成了”。结果上线后流量一上来&#xff0c;服务直接503&#xff0c;监控里CPU没…...

Java SPI机制原理与实战

前言 在现代软件开发中&#xff0c;Java SPI机制原理与实战是一个非常重要的技术点。本文将从原理到实践&#xff0c;带你深入理解这一技术&#xff0c;并通过完整的代码示例帮助你快速掌握核心知识点。 核心概念 基本原理 Java SPI机制原理与实战的核心在于理解其底层机制。以…...

不止是颜色:深入挖掘(ANSI转义码)在Linux/Mac终端里的高级玩法

不止是颜色&#xff1a;深入挖掘ANSI转义码在终端里的高级玩法当大多数开发者还在用\033[31m给终端文字涂上红色时&#xff0c;极客们早已用ANSI转义码玩出了更酷炫的花样。想象一下&#xff1a;终端里跳动的进度条、实时刷新的数据仪表盘、甚至完整的文字冒险游戏——这些全都…...

机器学习势函数与元动力学模拟揭示Ni掺杂BaTiO₃提升OER活性机理

1. 项目概述与核心挑战在电催化水分解制氢这个赛道上&#xff0c;析氧反应&#xff08;OER&#xff09;一直是制约整体效率提升和成本下降的瓶颈。目前&#xff0c;商业电解槽的阳极严重依赖铱、钌等贵金属氧化物催化剂&#xff0c;它们的稀缺性和高昂成本直接阻碍了绿氢技术的…...

LeetCode 523:连续的子数组和 | 前缀和同余定理

LeetCode 523&#xff1a;连续的子数组和 | 前缀和同余定理 引言 连续的子数组和&#xff08;Continuous Subarray Sum&#xff09;是 LeetCode 第 523 题&#xff0c;难度为 Medium。题目要求判断数组中是否存在长度至少为 2 的连续子数组&#xff0c;其元素和是 K 的倍数。这…...

跨环境漏洞复现:Docker Desktop与VMware Kali的TCP/信号对齐实战

1. 这不是“复现个POC就完事”的演练&#xff0c;而是真实攻防链路上的环境卡点攻坚你有没有遇到过这种情况&#xff1a;在本地Kali虚拟机里跑通的CVE-2026-24061利用脚本&#xff0c;一放到客户现场的Docker Desktop环境里就报错——不是缺Python模块&#xff0c;就是socket连…...

别光背公式了!用Python的NumPy和SciPy手把手带你玩转SVD(附实战代码与可视化)

别光背公式了&#xff01;用Python的NumPy和SciPy手把手带你玩转SVD&#xff08;附实战代码与可视化&#xff09;在数据科学和机器学习领域&#xff0c;奇异值分解&#xff08;SVD&#xff09;就像一把瑞士军刀——它可能不是你每天都会用到的工具&#xff0c;但当遇到棘手问题…...