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

跟着逻辑先生学习FPGA-实战篇第一课 6-1 LED灯闪烁实验

硬件平台:征战Pro开发板
软件平台:Vivado2018.3
仿真软件:Modelsim10.6d
文本编译器:Notepad++

征战Pro开发板资料
链接:https://pan.baidu.com/s/1AIcnaGBpNLgFT8GG1yC-cA?pwd=x3u8
提取码:x3u8

1 知识背景

LED,又名发光二极管。 LED 灯工作电流很小(有的仅零点几毫安即可发光),抗冲击和抗震性能好,可靠性高,寿命长。由于这些优点, LED 灯被广泛用在仪器仪表中作指示灯、 液晶屏背光源等诸多领域。
不同材料的发光二极管可以发出红、 橙、 黄、 绿、 青、蓝、 紫、白这八种颜色的光。 图 6-1-1 左边是可以发出黄、红、蓝三种颜色的直插型二极管实物图,这种二极管长的一端是阳极,短的一端是阴极。 图 6-1-1 右边是开发板上用的贴片二极管实物图。 贴片二极管的正面一般都有颜色标记,有标记的那端就是阴极。
在这里插入图片描述
图6-1- 1发光二极管实物图
发光二极管与普通二极管一样具有单向导电性。给它加上阳极正向电压后,通过 5mA 左右的电流就可以使二极管发光。通过二极管的电流越大,发出的光亮度越强。不过我们一般将电流限定在 3~20mA 之间,否则电流过大就会烧坏二极管。

2 实验任务

本节实验任务是征战 Pro 开发版上的 LED3以固定的频率闪烁。

3 硬件设计

扩展知识点:
位号就是元器件的“身份证”,我们可以通过 PCB 板上的丝印找到对应的器件。
网络名是一种连线,相同的网络名就表示连接在一起。当原理图比较简单的时候我们可以通过画线将管脚与管脚连接起来,那如果我们的原理图非常复杂时,用画线这种方式就不现实了,满屏的连线根本无法保证设计的准确性,所以用网络名来表示就非常方便了,这个知识大家在学习原理图和 PCB 设计时会涉及到,此处我们一笔带过。

3.1 原理图分析

板载了 8 个用户 LED 灯,LED 灯的正极接的 FPGA 管脚,负极接地。当 FPGA 管脚输出高电平时,发光二极管的正负极有电压差,便会产生电流流过发光二极管,从而点亮 LED 灯;当 FPGA 管脚输出低电平时,发光二极管正负极没有电压差,也不会产生电流,LED 灯熄灭。我们选用位号为 LED3 的 LED 来做为本实验的外设 LED 灯。通过图 6-1-2,图 6-1-3 我们可以看到灯 LED3 的管脚与 FPGA 的管脚 M22 连接在一起。
复位按键我们用开发板上的 SW1,通过图 6-1-4 可知,当按键按下时, SW1 的管脚 1 和管脚 2 导通,信号KEY0就为低电平;当松开按键时,KEY0 被上拉到 VCCIO (VCCIO 默认等于3.3V),即为高电平。至于 KEY0 与 FPGA 哪个管脚连接在一起,读者可以尝试自已在原理图上去找,会看原理图是 FPGA 工程师最基本的技能噢!
在这里插入图片描述
图6-1- 2 LED灯原理图
在这里插入图片描述
图6-1- 3 FPGA管脚图
在这里插入图片描述
图6-1- 4 按键原理图

3.2 管脚映射表

本实验中,系统时钟、按键复位以及 LED 端口的管脚分配如下表所示:
表6-1- 1管脚映射表
在这里插入图片描述

同学们可能会好奇,为什么原理图中的网络名不和程序中的信号名一致呢?这是因为一般有两个原因:
1. 在公司里面,设计硬件的工程师和设计软件的工程师并不是同一个人,每个人的命名习惯不同,所以就会命名不一样的情况,
2. 硬件上的器件功能和软件上的功能并不一样。比如我们的按键 SW1,在硬件上它就是一个按键,但是在软件设计中,我们可以认为它是复位管脚,也可以认为它是控制管脚,所以原理图中的网络名和程序中的信号名没办法统一。
这种情况是很常见的,只要同学们掌握了原理,这个命名随便怎么变我们都知道如何去约束 FPGA 管脚。

3.3 编写XDC 约束文件

在这里插入图片描述
下面我们以 clk 时钟引脚为例, 简要介绍 xdc 文件的语法。第一行以“#”号开头,表示这是一条注释语句。第二行是有效的约束命令。每一个约束命令单独占用一行,命令的结尾没有如 verilog 中的分号“;”一样的语句结束符号。每一条注释也单独占用一行。命令的第一个关键字代表该命令的名称,其后的所有字段都是该命令的参数列表。例如,在第二行的时钟周期约束命令中,“create_clock”是该命令的名称,它会创建一个时钟;其后的“-name clk”、“ -period 20”、“[get_ports clk ]”都是该命令的各个参数,分别表示所创见的时钟的的名称是“clk”、时钟周期是 20ns、时钟源是 clk 引脚。
第 4 行至第 6 行是对 IO 管脚的引脚位置约束和电平标准约束。例如,在第 4 行中,“set_property”是命令的名称;“PACKAGE_PIN Y18”是引脚位置参数,代表引脚位置是 Y18; “IOSTANDARD LVCMOS33”代表该引脚所使用的电平标准是LVCMOS33。
其他 IO 引脚的约束命令的语法与 clk 引脚是相同的,这里就不再重复了。但是要注意, create_clock 约束命令只能在 clk 时钟引脚上使用,其他普通 IO 上不能使用 create_clock 约束命令。
在 Notpepad++ 中编辑好之后,一定要记得保存!!!

扩展知识点:
时序约束(Timing Constraints) 用来描述设计人员对时序的要求,比如时钟频率,输入输出的延时等,以满足设计的时序要求。那么为什么工程中需要添加时序约束呢? 对于这个原因,首先给大家说明下,如果有些设计工程不加时序约束,可能会出现功能错误,这个地方加了“可能” 两个字,也就是说不一定会出错,有可能某一次编译功能没有问题,下一次编译就出现功能问题。
对时钟的约束最简单的理解就是,设计者需要告诉 EDA 工具设计中所使用的时钟的频率是多少;然后工具才能按照所要求的时钟频率去优化布局布线,使设计能够在要求的时钟频率下正常工作。 本次实验 clk 的时钟频率为 50MHz,周期为 20ns,在做约束时可以等于这个值或者略低于这个值,不建议周期设置的太小,否则软件在布局布线时很难满足这个要求。
其实对于比较简单的设计,即使不对工程做时序约束,可能也不影响最终的功能。但是当设计变得复杂起来,或者输入的时钟频率比较高的时候,如果不添加时序约束,那么就有可能在验证设计结果的时候出现一些意料之外的情况。所以这里推荐大家无论简单或者复杂的实验,都对工程做时序约束。时序约束的内容非常多,这里不再展开介绍,这里只对输入时钟做周期约束,约束的方法是在 XDC 文件中添加如下语句:
create_clock -period 20.000 -name clk [get_ports clk]
“create_clock”是该命令的名称,它会创建一个时钟;其后的“-name sys_clk” 、 “ -period 20”、“ [get_ports clk ]”都是该命令的各个参数,分别表示所创建时钟的名称是“clk”、时钟周期是20ns、时钟源是 clk 端口,一般只对输入的时钟做周期约束。

4 程序设计

由于发光二极管的阳极与 FPGA 的管脚相连,只需要改变与 LED 灯相连的 FPGA 管脚的电平, LED 灯的亮灭状态就会发生变化。当 FPGA 管脚为高电平时, LED 灯点亮; 为低电平时, LED 灯熄灭。
其中,计数器对 50MHz 时钟进行计数,从而达到计时的目的。计数器在每次计时到 0.5秒之后清零,然后重新开始计数,计数的值用于控制 LED 的显示状态。当计数器的值等于 0 时,就把 LED 信号取反。代码如下所示:
在这里插入图片描述
本程序中输入时钟为 50MHz,所以一个时钟周期为 20ns(1 / 50MHz)。因此计数器 cnt 通过对 50MHz 系统时钟计数, 计时到 0.5S, 需要累加 0.5s / 20ns=2500_0000 次。 在代码第 27行,每当计时到 0.5s 计数器清零一次。同时,在代码的第 37 行,根据计数器的计数值来赋值 LED 的状态。当计数值等于 0 时,led 进行取反操作,这样就实现了每 0.5s,led 信号翻转一次,以此实现 LED 灯闪烁功能。
疑问 :代码第 16 行, cnt 寄存器位宽为什么要设置成[24:0]呢?这是因为 cnt 最大计数值是 24999999,我们用计算器将其转成十六进制,如下图:
在这里插入图片描述
图6-1- 5 windows计算器界面

从上图右边我们可以看到总共是 25 位。
注 :代码 8 行,我们可以看到都在寄存器后面赋了初值,这不是必须的,但是建议同学们加上,因为一些央企研究所等单位的代码需要做评测,测评单位会要求给寄存器赋初值,笔者曾经经历过。

5 仿真验证

对 RTL 代码进行仿真之前,我们首先需要编写实验对应的仿真文件(TestBench)。 TestBench 是用于验证功能模块的设计是否符合预期,其内容主要分为以下三个步骤:
1、 向被测功能模块的输入接口添加激励
2、 对被测功能模块的顶层接口进行信号例化
3、 判断被测功能模块的输出是否满足设计预期

5.1 led灯闪烁模块(led_shark)仿真

5.1.1 仿真激励代码编写

接下来在Sim 中新建一个 tb_led_shark.v仿真测试文件,接下来右击“tb_led_shark.v”文件使用“ Notepad++”工具打开“tb_led_shark.v”文件,就可以开始编写仿真代码了。
在这里插入图片描述
为了节约仿真时间,更快地看到仿真现象,我们在仿真激励文件的第 23 行将 led_shark模块中的 TIME_0S5 进行重新定义赋值。
TB 模块编写完成后就可以使用仿真软件对我们编写的 RTL 代码进行仿真了,本次实验我们用Modelsim 软件来进行仿真。

5.1.2 批处理仿真

Modelsim仿真一般有两种方法,第一种是图形化界面仿真,即所有的操作都是在 Modelsim软件界面上来完成,其它友商都是用的这种方式。做为一个工作了十多年的工程师来说,实在不想使用图形化界面一步一步的去操作软件,不仅步骤繁琐而且没有任何技术含量。那有没有一种一键仿真的方式呢?读者朋友别急,我们即将为大家安排批处理仿真(全网首家使用该方式),更快捷,更贴近实际工程。相信读者学会了这种仿真方式,其它的仿真都不香了!接下来,我将手把手的教大家使用批处理仿真。
先来看看我们仿真文件夹的构成,如下图:
在这里插入图片描述
图6-1- 6 仿真文件夹Sim构成
tb_led_shark.v 就是我们的仿真测试代码
do 文件夹里面存放的就是我们的批处理文件,如下图:
在这里插入图片描述
图6-1- 7 do文件夹构成

我们打开 modelsim.bat 文件,选中 modelsim.bat,鼠标右键用 notepad++ 打开,打开后如下图:
在这里插入图片描述
图6-1- 8 modelsim.bat文件
第 2 行中,指定了 modelsim 的 vsim.exe 文件路径,读者只用将路径改为自己电脑存放vsim.exe 的位置(vsim.exe 文件在 modelsim 的安装路径下),改好以后,保存即可。
接着我们打开 sim.do 文件,同样用 notepad++ 打开,如下图所示:
在这里插入图片描述
图6-1- 9 sim.do文件

第二行:用于指定源码的位置,只要大家的工程结构和我们的一致,此处就不用更改
第三行:用于指定仿真代码的位置,只要大家的工程结构和我们的一致,此处就不用更改
第五行:仿真 tb_led_shark 这个仿真代码(就是我们前面编写的仿真代码)
第八行:调用波形文件,当我们还未开始仿真时,文件夹里面没有这个wave.do文件,仿真开始后,我们在波形窗口中加入要观察的信号后,按下 ctrl+s 就会生成一个 wave.do 文件,再下一次运行时,会自动加载上次观察的信号。
第九行:仿真运行时间
第十行:停止仿真
modelsim.bat 和 sim.do 文件修改好以后,就可以开始仿真了。
步骤1:直接鼠标双击 modelsim.bat 文件,如下图所示:
在这里插入图片描述
图6-1- 10 批处理仿真步骤1

步骤2:添加波形文件,选中被仿真的模块(led_shark),鼠标右键,然后选择 Add Wave,如下图所示:

在这里插入图片描述
图6-1- 11批处理仿真步骤2-1

这时我们可以看到波形窗口出现了我们添加的信号,如下图所示:
在这里插入图片描述
图6-1- 12批处理仿真步骤2-2
步骤3:保存添加的信号,按 CTRL+S ,出现如下对话框
在这里插入图片描述
图6-1- 13批处理仿真步骤3

默认会将 wave.do 文件保存在 do 文件夹下,直接点击 OK
步骤4:此时回到图 6-1-10 界面,在命令窗口输入 do sim.do ,如下图所示:
在这里插入图片描述
图6-1- 14批处理仿真步骤4-1
然后按下键盘上的 ENTER 键,modelsim 就开始编译仿真了,这时我们可以看到波形窗口出现了波形,如下图所示:
在这里插入图片描述
图6-1- 15批处理仿真步骤4-2
此时,我们可以按上面的图标,将波形缩小至全屏。波形的放大和缩小可通过按住 CTRL 键,滚动鼠标滚轮实现。
如果我们修改了代码,只用在图 6-1- 14 的命令窗口重新再输入 do sim.do 即可。

5.1.3 仿真波形分析

我们将仿真波形放大,如下图所示:
在这里插入图片描述
图6-1- 16仿真波形图

从上图可以看到, 计数器 cnt 的值在 0 到 9之间循环计数。当 cnt = 0 时, led 信号翻转,实现 LED 闪烁的效果。

6 综合编译

6.1 新建Vivado工程

毕竟笔者工作了十多年,再像前面《4-4 Vivado 使用初体验》章节那样使用Vivado软件,太繁琐了,我就以真正做项目的步骤生成bit文件。在前面我们已经将Source里面的源码(led_shark.v)和约束文件(pin.xdc)通过notepad++ 软件编辑好了,并且通过Modelsim进行了功能仿真,接下来我们新建Vivado工程。
步骤1:File --> Project --> New,然后点击Next
在这里插入图片描述
图6-1- 17 新建工程步骤1
步骤2:更改工程名及工程保存路径(注意:路径不能有中文字符),修改好以后,点击Next
在这里插入图片描述
图6-1- 18新建工程步骤2
步骤3:默认选择RTL Project即可,点击Next
在这里插入图片描述
图6-1- 19新建工程步骤3
步骤4:添加源文件(.v),点击Add Files,然后找到源文件存放的路径,将 .v 文件全部选中,点击OK
在这里插入图片描述
图6-1- 20 新建工程步骤4-1
在这里插入图片描述
图6-1- 21新建工程步骤4-2
步骤5:可以看到我们加入到工程的 .v 文件,点击Next
在这里插入图片描述
图6-1- 22新建工程步骤5
步骤6:添加约束文件(.xdc),点击Add Files
在这里插入图片描述
图6-1- 23新建工程步骤6
步骤7: 找到我们的管脚约束文件(pin.xdc),点击Next
在这里插入图片描述
图6-1- 24新建工程步骤7
步骤8: 选择器件xc7a35tfgg484-2,点击Next
在这里插入图片描述
图6-1- 25新建工程步骤8
步骤9:可以看到我们新建工程的总结,点击Finish即可
在这里插入图片描述
图6-1- 26新建工程步骤9
步骤10:可以看到新建工程的结构,包括了1个源码,1个约束文件,器件型号,如下图所示:
在这里插入图片描述
图6-1-27新建工程步骤10

6.2生成下载文件bit

我们直接生成bit文件,点击Generate Bitstream
在这里插入图片描述
图6-1- 28 生成bit文件
如果编译有错,我们就根据错误信息对我们的代码或约束文件进行修改,如果编译成功,如下图所示:
在这里插入图片描述
图6-1- 29 编译成功

7 下载验证

7.1 硬件连接

此时将 Xilinx 下载器一端连接电脑, 另一端与开发板上的 JTAG 下载口连接,开发板连接电源线,如下图所示:在这里插入图片描述
图6-1- 30征战 Pro 开发板连接实物图

注意!一定要先把下载器的一端连接到了电脑、另一端连接了 JTAG 接口之后,再给开发板上电!否则,对开发板的 JTAG 接口进行带电热插拔,有一定概率会损坏 JTAG 接口!

7.2 下载bit文件

步骤1:点击“Flow Navigator”窗口中的“Open Hardware Manager”按钮,如下图所示:
在这里插入图片描述

图6-1- 31下载bit文件步骤1-1
在这里插入图片描述
图6-1- 32下载bit文件步骤1-2

步骤2:鼠标右击“xc7a35t_0”,在弹出的菜单中选择“Program Device”,如下图所示:

在这里插入图片描述
图6-1- 33下载bit文件步骤2

步骤3:在弹出的对话框中直接点击“Program”即可,如下图所示:
在这里插入图片描述
图6-1- 34下载bit文件步骤3

下载完成之后,我们可以看到位于开发板上的 LED 灯在不断地闪烁,如下图所示:
在这里插入图片描述

图6-1-34 实验现象

到此,我们第一实验已经完成,大家多练习,延伸!
大家发现数码管显示了乱码,这是正常现象,因为数码管的驱动芯片我们没有控制它,在数码管接口上就会有一个不定状态的电平,反应到数码管就是显示乱码,这个我们不用管,只用关心 Led 灯是否正常控制。

相关文章:

跟着逻辑先生学习FPGA-实战篇第一课 6-1 LED灯闪烁实验

硬件平台:征战Pro开发板 软件平台:Vivado2018.3 仿真软件:Modelsim10.6d 文本编译器:Notepad 征战Pro开发板资料 链接:https://pan.baidu.com/s/1AIcnaGBpNLgFT8GG1yC-cA?pwdx3u8 提取码:x3u8 1 知识背景 LED,又名…...

【文献精读笔记】Explainability for Large Language Models: A Survey (大语言模型的可解释性综述)(四)

****非斜体正文为原文献内容(也包含笔者的补充),灰色块中是对文章细节的进一步详细解释! 四、提示范式(Explanation for Prompting Paradigm) 随着语言模型规模的扩大,基于提示(prom…...

分布式算法(五):初识ZAB协议

文章目录 一、什么是Zookeeper二、ZAB与Zookeeper的关系为什么Zookeeper不直接使用Paxos 三、ZAB简介1.名词解释提案(Proposal)事务(Transaction)原子广播(Atomic Broadcast) 2.集群角色领导者(…...

用Python操作字节流中的Excel工作簿

Python能够轻松地从字节流中加载文件,在不依赖于外部存储的情况下直接对其进行读取、修改等复杂操作,并最终将更改后的文档保存回字节串中。这种能力不仅极大地提高了数据处理的灵活性,还确保了数据的安全性和完整性,尤其是在网络…...

PHP-Casbin v4.0.0 发布,支持 ACL、RBAC、ABAC 等模型的访问控制框架

PHP-Casbin 是一个用 PHP 语言打造的轻量级开源访问控制框架,支持 ACL、RBAC、ABAC 多种模型。它采用了元模型的设计思想,支持多种经典的访问控制方案,如基于角色的访问控制 RBAC、基于属性的访问控制 ABAC 等。 更新内容: http…...

MIT S081 Lab 2 System Calls

Lab链接 一 实现trace功能 1 题目要求 In this assignment you will add a system call tracing feature that may help you when debugging later labs. You’ll create a new trace system call that will control tracing. It should take one argument, an integer “ma…...

Oracle Dataguard(主库为 Oracle 11g 单节点)配置详解(2):配置主数据库

Oracle Dataguard(主库为 Oracle 11g 单节点)配置详解(2):配置主数据库 目录 Oracle Dataguard(主库为 Oracle 11g 单节点)配置详解(2):配置主数据库一、配置…...

(leetcode算法题)10. 正则表达式匹配

10. 正则表达式匹配 - 力扣(LeetCode) 此题的要求一个字符串 s 和一个字符规律 p之间支持 . 和 * 的正则表达式匹配 . 匹配任意单个字符 * 匹配零个或多个前面的那一个元素 所谓匹配,是要涵盖 整个 字符串 s 的,而不是部分字符串…...

Hive性能调优考量

Hive作为大数据领域常见的数据仓库组件,在设计和开发阶段需要注意效率。影响Hive效率的不仅仅是数据量过大,数据倾斜、job(小文件过多)或者磁盘I/O过多、MapReduce分配不合理等因素都会对Hive的效率有影响。对Hive的调优可以从架构…...

2024-12-29-sklearn学习(26)模型选择与评估-交叉验证:评估估算器的表现 今夜偏知春气暖,虫声新透绿窗纱。

文章目录 sklearn学习(26) 模型选择与评估-交叉验证:评估估算器的表现26.1 计算交叉验证的指标26.1.1 cross_validate 函数和多度量评估26.1.2 通过交叉验证获取预测 26.2 交叉验证迭代器26.2.1 交叉验证迭代器–循环遍历数据26.2.1.1 K 折26.2.1.2 重复 K-折交叉验…...

Spring Boot + MinIO 实现分段、断点续传,让文件传输更高效

一、引言 在当今的互联网应用中,文件上传是一个常见的功能需求。然而,传统的文件上传方式在面对大文件或不稳定的网络环境时,可能会出现性能瓶颈和上传失败的问题。 传统文件上传,就像是用一辆小推车搬运大型家具,一…...

获取用户详细信息-ThreadLocal优化

Thread全局接口可用,不用再重复编写。所以为了代码的复用,使用Thread。把之前的内容(函数的参数和map与username)注释掉,换为Thread传过来的内容(map与username)。 因为Thread需要在拦截器里面…...

R语言6种将字符转成数字的方法,写在新年来临之际

咱们临床研究中,拿到数据后首先要对数据进行清洗,把数据变成咱们想要的格式,才能进行下一步分析,其中数据中的字符转成数字是个重要的内容,因为字符中常含有特殊符号,不利于分析,转成数字后才能…...

Go语言方法和接收器类型详解

Go语言方法和接收器类型详解 1. 方法接收器类型 1.1 值接收器 值接收器方法不会改变接收器的状态,因为Go语言会在调用时复制接收器的值。因此,任何对接收器成员变量的修改都只会影响副本,而不会影响原始结构体实例。 type Person struct …...

Linux常用命令总结

目录 查询java服务的pid查询pid上的进程占用的端口方法 1:使用 lsof 查询端口方法 2:使用 netstat 查询端口方法 3:使用 ss 命令查询端口 system相关命令 查询java服务的pid JPS查询pid上的进程占用的端口 要根据进程 ID(PID&am…...

Linux总结之CentOS Stream 9安装mysql8.0实操安装成功记录

Linux总结之CentOS Stream 9安装mysql8.0实操安装成功记录 由于网上很多的mysql8.0安装教程都是老版本或者安装过程记录有问题,导致经常安装到一半需要删除重新安装。所以将成功的实操安装过程记录一下,方面后面查阅,大家还有问题的可以在此讨…...

ROS2软件架构全面解析-学习如何设计通信中间件框架

前言 ROS(Robot Operating System) 2 是一个用于开发机器人应用的软件平台,也称为机器人软件开发工具包 (SDK)。 ROS2是ROS1的迭代升级版本 ,最主要的升级点是引入DDS(Data Distribution Service)为基础的…...

基于微信小程序的校园自助打印系统

博主介绍:java高级开发,从事互联网行业六年,熟悉各种主流语言,精通java、python、php、爬虫、web开发,已经做了多年的设计程序开发,开发过上千套设计程序,没有什么华丽的语言,只有实…...

Linux命令——3.网络与用户

文章目录 一、网络1.网络测试与诊断2.网络接口配置3.无线网络配置4.防火墙与网络管理6.防火墙管理1)firewalld命令2)iptables命令 二、用户和群组1.管理员模式2.用户账户管理1)useradd创建2)usermod修改3)userdel 删除…...

2、redis的持久化

redis的持久化 在redist当中,高可用的技术包括持久化,主从复制,哨兵模式,集群。 持久化是最简单的高可用的方法,作用就是备份数据。即将数据保存到硬盘,防止进程退出导致数据丢失。 redis持久化方式&…...

建造者模式 Builder Pattern

在创建一个对象的时候,构造器参数有点多,而且有些参数还是可选的,再者还有不少同类型的,那就更应该使用 builder 模式了。 使用 Builder 模式的初衷是 把易变性(mutability)移动到Builder类,而…...

制作一个类似ChatGPT的AI对话网站,模型能力使用ChatGPT

要快速搭建一个类似ChatGPT的AI对话网站,并且使用类似ChatGPT的模型能力,可以考虑以下技术和工具: ### 1. **使用现有的AI模型平台** - **OpenAI API**: 如果你希望使用类似于ChatGPT的能力,OpenAI提供了强大的API服务&#xff08…...

LinuxC高级day2

1.在家目录下创建目录文件,dir a.dir下创建dir1和dir2 b.把当前目录下的所有文件拷贝到dir1中, c.把当前目录下的所有脚本文件拷贝到dir2中 d.把dir2打包并压缩为dir2.tar.xz e.再把dir2.tar.xz移动到dir1中 f.解压dir1中的压缩包 g.使用tree工具&#x…...

Word格式修改

经常修改格式,留下这篇汇总 Word的累加符号上下标变右标指定目录:word如何取消封面或者目录下方的页码,页码从正文开始加参考文献:【Word】怎样给论文添加引用参考文献删空白页: word中无法删除空白页怎么办&#xff…...

深度学习-稀疏卷积

步骤: 1、构建输入输出哈希表; 输入哈希表的键为激活点的索引,值为激活点的坐标;输出哈希表的键为激活点对应的输出点的索引,值为输出点的坐标。 2、构建规则书; 规则书的每一行包含4个值,分别是…...

Microsoft Visual Studio中的/MT, /MTd,/MD,/MDd分别是什么意思?

1. /MT,/MTd,/MD,/MDd的含义 /MT,/MTd,/MD,/MDd是 Microsoft Visual C 编译器的运行时库链接选项。它们决定了程序如何链接 C 运行时库(CRT)。具体含义如下: /MT&#x…...

交换机关于环路、接口绑定、链路聚合的相关知识

文章目录 1、对交换机SW-1进行配置,仅允许Host-1通过Ethernet0/0/1接口与Host-3和Host-4通信,Host-2无法与其他主机通信。2、关闭生成树协议,验证环路造成的影响3、关闭生成树协议通过链路聚合实现两条链路正常通信并提高链路可靠性。 内容包…...

5.微服务灰度发布落地实践(rocketmq增强)

文章目录 前言发送端灰度增强订阅端灰度增强 前言 上一篇分析了,在灰度发布实现中为什么要对消息队列灰度发布进行增强。本篇主要介绍如何实现rocketmq 灰度发布的增强. 发送端灰度增强 订阅端灰度增强...

32单片机从入门到精通之开发环境——库文件(六)

每个人都有自己的追求和梦想,但要实现这些梦想并不容易。在追逐梦想的路上,我们会遇到各种困难和挫折,甚至会感到无助和失望。然而,正是这些困难和挫折让我们更加坚韧和坚定地追求自己的目标。不要害怕失败,失败只是暂…...

大电流和大电压采样电路

大电压采样电路: 需要串联多个电阻进行分压,从而一级一级降低电压,防止电阻损坏或者短路直接打穿MCU。 为什么需要加电压跟随器:进行阻抗的隔离,防止MCU的IO阻抗对分压产生影响: 大电流检测电路&#xff…...

用户态和内核态?

目录 一、定义与特点 二、功能与权限差异 三、安全性与稳定性 四、系统调用与交互 五、参考 用户态和内核态是操作系统中的两种基本运行状态,它们各自具有不同的特点和权限,共同构成了操作系统的运行基础。以下是对用户态和内核态的详细解释&#x…...

Qt天气预报系统设计界面布局第四部分左边

Qt天气预报系统设计 1、第四部分左边的第一部分1.1添加控件1.2修改控件名字 2、第四部分左边的第二部分2.1添加控件2.2修改控件名字 3、第四部分左边的第三部分3.1添加控件3.2修改控件名字 4、对整个widget04l调整 1、第四部分左边的第一部分 1.1添加控件 拖入一个widget&…...

【Spring MVC 常用注解】注解驱动开发的魔法

在 Spring MVC 中,注解可以说是开发者的“魔法棒”,通过简单的注解配置,开发者能够实现请求处理、参数绑定、响应返回等复杂功能,真正做到“少写代码多干活”。 我们接下来就来一起看看 Spring MVC 中常用的注解,它们的…...

FFmpeg 4.3 音视频-多路H265监控录放C++开发二十一.4,SDP协议分析

SDP在4566 中有详细描述。 SDP 全称是 Session Description Protocol, 翻译过来就是描述会话的协议。 主要用于两个会话实体之间的媒体协商。 什么叫会话呢,比如一次网络电话、一次电话会议、一次视频聊天,这些都可以称之为一次会话。 那为什…...

STM32 高级 WIFi案例1:测试AT指令

需求描述 测试AT指令是否能够正常控制ESP32的wifi,比如重启、读取设备信息等。 思路: stm32通过串口usart2向ESP32发布命令。ESP32通过串口1返回信息。 配置: 第一步:对ESP32芯片烧录可以读取stm32命令的固件(fac…...

Mono里运行C#脚本18—mono_image_load_names

前面已经分析完成加载CLR的流表,接着下来就是使用前面分析的数据,更进一步来处理了。下面就是通过函数mono_image_load_names获得程序集的名称和模块名称。 在CLI定义的文档里,表Assembly : 0x20: Assembly表结构信息,以下是该表各列的简要说明: HashAlgId: 这是一个4字…...

Java和Python区别: 应用领域与性能抉择的深度解析

文章目录 1. 引言2. 语言特性对比:灵活性与严谨性的碰撞3. 应用场景分析:专注任务的工具选择3.1 数据库交互:Java 的优势所在3.2 图像识别与计算:Python 的专长3.3 Web 开发 4. 高并发请求处理:架构设计与硬件选择4.1 …...

SQL Server详细使用教程(包含启动SQL server服务、建立数据库、建表的详细操作) 非常适合初学者

SQL Server详细使用教程(包含启动SQL server服务、建立数据库、建表的详细操作) 非常适合初学者 文章目录 目录 前言 一、启动SQL server服务的三种方法 1.不启动SQL server服务的影响 2.方法一:利用cmd启动SQL server服务 3.方法二:利用SQL Serv…...

基于Docker+模拟器的Appium自动化测试(二)

模拟器的设置 打开“夜神模拟器”的系统设置,切换到“手机与网络”页,选中网络设置下的“开启网络连接”和“开启网络桥接模式”复选框,而后选择“静态IP”单选框,在IP地址中输入“192.168.0.105”,网关等内容不再赘述…...

CSS系列(47)-- Animation Timeline详解

前端技术探索系列:CSS Animation Timeline详解 ⏱️ 致读者:探索动画时间线的艺术 👋 前端开发者们, 今天我们将深入探讨 CSS Animation Timeline,这个强大的动画控制特性。 基础概念 🚀 时间线定义 …...

1、pycharm、python下载与安装

1、去官网下载pycharm 官网:https://www.jetbrains.com/pycharm/download/?sectionwindows 2、在等待期间,去下载python 进入官网地址:https://www.python.org/downloads/windows/ 3、安装pycharm 桌面会出现快捷方式 4、安装python…...

【翻译】优化加速像素着色器执行的方法

中文翻译 在回复我的 Twitter 私信时,我遇到了一个关于如何提高像素/片段着色器执行速度的问题。这是一个相当广泛的问题,具体取决于每个 GPU/平台和游戏内容的特性,但我在本帖中扩展了我“头脑风暴”式的回答,以便其他人也觉得有用。这不是一份详尽的清单,更像是一个高层…...

ZLib库使用详细教程 以及标准ZLib函数和QT自带压缩函数比较

1. 下载Zlib 官网下载地址如下:http://www.zlib.net/ 2. 利用cmake编译zlib 有两种方法可以打开cmake-gui winR输入cmd打开命令行,在命令行中输入cmake-gui可以直接打开应用界面找到你一开始安装cmake的文件夹,在bin子文件夹中双击cmake-…...

android stdudio环境: gradle一直安装失败

一、一直显示如下错误 The specified Gradle distribution file:/home/wangqingyuan/.gradle/wrapper/dists/gradle-8.6-bin/gradle-8.6-bin.zip does not exist. 经分析,是因为应用本身设置了gradle版本的地址为本地: 应用目录:gradle/gra…...

2024年12月31日Github流行趋势

项目名称:free-programming-books 项目地址url:https://github.com/EbookFoundation/free-programming-books项目语言:HTML历史star数:344575今日star数:432项目维护者:vhf, eshellman, davorpa, MHM5000, …...

音视频入门基础:MPEG2-TS专题(24)——FFmpeg源码中,显示TS流每个packet的pts、dts的实现

音视频入门基础:MPEG2-TS专题系列文章: 音视频入门基础:MPEG2-TS专题(1)——MPEG2-TS官方文档下载 音视频入门基础:MPEG2-TS专题(2)——使用FFmpeg命令生成ts文件 音视频入门基础…...

设计模式の状态策略责任链模式

文章目录 前言一、状态模式二、策略模式三、责任链模式 前言 本篇是关于设计模式中的状态模式、策略模式、以及责任链模式的学习笔记。 一、状态模式 状态模式是一种行为设计模式,核心思想在于,使某个对象在其内部状态改变时,改变该对象的行为…...

TI毫米波雷达原始数据解析之Lane数据交换

TI毫米波雷达原始数据解析之Lane数据交换 背景Lane 定义Lane 确认确认LVDS Lane 数量的Matlab 代码数据格式参考 背景 解析使用mmWave Studio 抓取的ADC Data Lane 定义 芯片与DCA100之间的数据使用LVDS接口传输,使用mmWave Studio 配置过程中有一个选项是LVDS L…...

Python-Pdf转Markdown

使用pdfminer.sixmarkdownify pdfminer.six可以提取Pdf文本内容markdownify可以将文本内容写markdown文件 安装 pip install pdfminer.six pip install markdownify实现 from pdfminer.high_level import extract_text from markdownify import markdownifydef pdf2markdo…...

win32汇编环境下,双击窗口程序内生成的listview列表控件的某行,并提取其内容的示例程序

;运行效果 ;双击后 ;上源码,仔细研究里面的几条备注就理解原理了 ;提取窗口程序内生成的listview列表控件的内容示例程序 ;抄下面源码,可以在radasm里面直接编译运行。主要的部分加了备注。 ;>>>>>>>>>>>>>>…...