FPGA小白学习日志一:LED的点亮

1.工程准备

首先建立一个名为led的工程文件夹,文件夹下包含了doc、quartus_prj、rtl、sim四个子文件夹:

那么我们来分析各个文件夹包含了什么:

doc:该文件夹主要包含了文档资料、数据手册、Visio波形等,相当于档案库;
quartus_prj:该文件夹主要包括了使用Quartus II软件新建的工程,相当于操作台;
rtl:该文件夹主要放置生成硬件电路的代码,相当于原材料;
Sim:该文件夹放置对生成硬件电路代码的仿真文件,相当于质检室;

    这四个文件夹各自完成不同的分工,但是它们之间有什么联系呢?答案是:他们之间通过路径关联和文件引用,形成一个完美的FPGA开发闭环。quartus_prj作为工程中枢,向上访问doc读取说明,向下访问rtl获取硬件代码,向外访问sim获取仿真脚本;sim向上访问rtl在逻辑上验证硬件代码的正确性。

2.设计过程

   无论我们使用FPGA做什么类型的项目时,我们都要参照一个具体的流程,这里就介绍我自己的开发流程:

1.看手册和原理图,搞清楚我们需要实现什么功能,就像做饭时我们需要看食谱,要知道自己吃什么。
2.搞清楚要吃什么了以后,我们就要开始选食材,选调料了,这样我们才能炒出来一盘好菜,这就对应着我们要新建工程,选好工程对应的开发芯片。这里我用的是野火的Altera EP4CE10 征途Mini开发板。
3.接下来我们就要开始炒菜了,也就是说我们要去写代码,运用Verilog代码实现电路功能。
4.相信大家炒完菜之后都会用筷子夹起一些尝一尝,评定炒的这盘菜好不好吃,能不能上桌,要不要重炒,也就是说我们写完代码以后,要去编译代码、写仿真软件测试是否有逻辑错误。
5.菜没问题以后呢,我们就要盛出来上桌了,那么是要盛到盘子里呢还是盛到盆子里呢,不同的菜我们也要分配好容器才好,也就是说在我们测试仿真完以后啊,就要分配硬件引脚了,这样我们的工程才能正常跑出来。
   
   其实我们用FPGA做项目和炒菜流程是差不多的,这样有了具体的流程以后,我们就按着这个思路来实现led这个工程项目的实现。

3.工程实现

(1)看食谱

        首先,我们来看食谱,看看我们需要吃什么菜,这里要打开开发板的原理图,找到“按键”和“LED”这两个模块,这里取KEY1与LED1:

        


                                                                       按键电路

                               

                               

                                                                  LED电路

我们来分析一下这两个原理图,看看他们是怎么共同实现led灯点亮的:
 
当SW2按键松开时,1、2与3、4不导通,此时KEY1被拉低到GND低电平,发出低电平信号key_in为0,对应的FPGA输入引脚接收0信号,并给LED电路发送0信号,LED1电路收到0信号后,输出低电平信号led_out为0,led灯不亮;
当SW2按键按下时,1、2与3、4导通,此时KEY1被拉高到3V3高电平,发出高电平信号key_in为1,对应的FPGA输入引脚接收1信号,并给LED电路发送1信号,LED1电路收到1信号后,输出高电平信号led_out为1,led灯亮。

接着我们在VIsio中绘制我们led功能框图和波形图,这里我们就不过多介绍了,相信大家看完上述我们对led电路实现的解析后很容易理解下面两个框图。   


                


                                                             led功能框图

                   


          
                                                              led波形图
 

  记得做完以后保存到doc文件夹中。 就此,我们的工程前提工作已经就绪了,也就是说我们看完菜谱已经知道自己要吃什么了,接下来我们就要新建工程,开始备菜了。

(2)备菜

接着,我们在Quartus中新建工程,工程要放到quartus_prj文件夹中:       

               

            对于以下页面,野火官方文档中只做了简要说明,这里主播解释一下:其实就是把我们写好的代码文件和新建工程绑定在一起,Quartus只有在列表里看到了这个文件,才会去读取他,生成对应的电路。不过我们还没有开始写代码,所以目前就不用添加代码文件了。

                    

接下来是器件选择,我们这里也来做个解释:
1.Family是器件族,就是说我们使用的哪类芯片,这个在FPGA板芯片上有介绍,这里主播使用的是Cyclone IV E系列芯片
2.Packege是封装类型,这里我们选的是Any QFP封装,这时候就有读者要问了:“配置为什么和野火官方文档给的不一样呢”,其实主播这块板CPU型号是EP4CE10E22C8N ,我们来对这串数值进行拆解:

a)EP4CE是产品系列,也就是上面Family中选择的芯片型号:Cyclone IV 系列E型
b)后面的10就是10k个逻辑单元
c)再后面的E就是EQFP类型封装,归类在QFP大类下,所以我们在Package中选择的是Any QFP封装
d)22就对应着Pin count中的引脚数量,即144个
e)C对应着工作温度,0-85°,这个我们可做了解
f)8则对应着速度等级,也就是Speed grade中的8
g)N就是工艺标识,无铅工艺,这个我们也只做简要了解

    相信看完这个,大家已经懂得怎么去读一个FPGA CPU型号了,同时在主播给大家讲解的过程中,我们也把工程配置好了。对于下面的Available devices,我就不做详细解说了。主播要说的是,在新建工程中的配置一定要和CPU严格对应好,不然是很影响后面的编译结果的。
                                               


         


            
(3)炒菜

看完食谱备好食材了之后呢,我们就要开始炒菜了,也就是要写代码。但是要在哪里炒菜呢,在哪里写代码呢?当然就是Notepad++了。此时,我们在rtl文件夹下新建一个名为led.v的文本文件,然后用Notepad++打开。
           

  大家回想一下第一步在工程准备中我们对quartus_prj文件夹的介绍:“quartus_prj作为工程中枢.....向下访问rtl获取硬件代码”,也就是说,我们编写完代码以后,还要让quartus_prj这个文件夹访问提取使用才可以,那怎么才能实现这个流程呢?接下来我们就要回到Quartus软件,将我们编写的代码(led.v文本文件)添加到工程中,这样quartus_prj就可以访问rtl获取硬件代码了,具体的步骤主播就不展示了,在野火官方文档有详细介绍。至此,炒菜部分我们就完成了。

(4)品尝

      菜炒好以后呢,我们就要夹起一些品尝了,也就是说,我们要去对代码进行编译和仿
这里主播不做步骤解释了,我们来简要看一下这个任务栏(Task)是干啥的:

a)Start Project: 工程初始化,包含新建工程、选择芯片型号、添加源文件等等,也就是说我们可以从这里面新建工程、打开已有工程等等。
b)Create Design: 设计输入与文件管理的核心入口,就是说我们可以从这里面新建代码文件、打开已有代码文件等。
c)Assign Constraints: 主要是导入约束文件、进行引脚分配等。
d)Compile Design :这个负责代码语法检查-布局布线-生成下载文件-时序分析-下载到开发板,讲明白点就是做了一些我们“尝菜”的部分操作。    
e)Verify Design :则是整个工程的收尾操作,负责打包整个led工程,也就是归档,然后导出工程数据库                                                

                           

                                 

说完了这些,我们来看看RTL视图,所谓RTL视图,就是将我们写的代码转换成硬件电路:            

                                            


                       
可以看出,这和我们在Visio软件中设计的led电路是一样的,同时代码编译也是没有问题的。完成这一步之后呢,我们就要去做仿真测试了。那么有些读者就会问,明明RTL视图已经和我们的设计电路一样的,那为什么还要做仿真测试呢?其实RTL视图做的就是将我们的代码综合成硬件电路,但是我们是不知道电路输入和输出的状态的,因此我们就要跑仿真,证明代码逻辑在实际运行中是正确的。
此处的仿真代码与文件添加主播就不再多述了,但是主播要在这里向大家解释一下输出网表的概念,因为在官方文档中频繁出现。所谓输出网表,说白了就是把我们的代码翻译成FPGA能读懂的硬件电路而已,所以“输出网表的语言格式”就是Verilog语言咯,“输出网表的时间单位”就是做仿真时的时间单位。相信主播这样解释,大家更能理解得通。

                                                                    仿真波形

在得到仿真波形以后,对比我们在Visio中绘制的波形图,是一模一样的。也就是说,RTL视图和Modelsim的仿真,无论是硬件电路还是输入输出波形都与我们的初始设计高度吻合,因此,“品尝”这一步我们已经做好了。

(4)装盘
   
仿真这一步我们做的已经没有问题了,接着我们就要分配引脚了,就是具体看按键SW1和LED1具体分配在电路板上的哪些引脚。因为EP4CE10E22C8N型CUP是把key_in和led_out 两个分配到IOBANK_3里面了,因此主播的引脚配置和官方文档不太相同,如下:
key_in <Input> @ IOBANK_3
led_out <Output> @ IOBANK_3

                      

         最后呢,主播提醒大家一下,尤其是我们在分配引脚时,一定一定要参考手册或者原理图来,不然轻则工程无发实现,重则芯片烧毁。至此,我们已经装盘了,后续的步骤主播就不进行讲解了,还请大家参照官方文档来。本文章不仅记录主播的FPGA学习之路,还想能为各个读者提供部分个人解答,共同进步。

Read more

企业级招聘数据采集实战:基于 Bright Data AI Studio 的自动化爬虫方案

企业级招聘数据采集实战:基于 Bright Data AI Studio 的自动化爬虫方案

🤵‍♂️ 个人主页:@艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞👍🏻 收藏 📂加关注+ 目录 一、 引言 二、Bright Data AI Studio 概览 2.1 AI Studio 是什么 2.2 AI Studio 的核心能力拆解 2.3 为什么说 AI Studio 更适合企业级场景 三、实战部分 3.1 实战目标与采集场景说明 3.2 准备工作 3.3 采集数据 3.4 扩展采集任务

AI入门系列:AI新手必看:人工智能发展历程与现状分析

AI入门系列:AI新手必看:人工智能发展历程与现状分析

写在前面:为什么AI发展历史很重要? 记得刚开始学习AI的时候,我总觉得历史这种东西很枯燥,不如直接学习最新的技术来得实在。但后来我发现,了解AI的发展历程,就像了解一个人的成长经历一样,能帮助我们更好地理解现在的AI是如何走到今天的,也能帮助我们预测未来可能的发展方向。 有一次,我和一位从事AI研究多年的教授聊天,他告诉我:"现在的学生总想直接学习深度学习,但如果不了解符号主义AI的兴衰,就无法理解为什么深度学习会成功,也无法预见它可能面临的挑战。"这句话让我深受启发。 所以,在这篇文章中,我想和大家一起回顾一下AI的发展历程,不是为了考试背诵那些枯燥的年代和事件,而是为了让我们能够站在历史的高度,更好地理解现在的AI技术,以及它在我们生活中的应用。 人工智能的诞生:一个充满想象力的开始 说起AI的诞生,我们不得不提到1956年的达特茅斯会议。这次会议被公认为人工智能学科的诞生标志。 想象一下那个场景:一群来自不同领域的顶尖科学家,包括约翰·麦卡锡、马文·明斯基、克劳德·香农等,聚集在一起,讨论着一个看似疯狂的问题:"机器能思考吗?"他们相信,只要给机器输入足够多的规则

全网首发:DeepSeek + MCP 炒股实战,我用AI炒股两周,居然真赚了钱?附接入教程

全网首发:DeepSeek + MCP 炒股实战,我用AI炒股两周,居然真赚了钱?附接入教程

全网首发:DeepSeek + MCP 炒股实战,我用AI炒股两周,居然真赚了钱?附接入教程 今天这篇内容不夸张地说,是我今年最期待的一篇。因为它不仅能帮你把大模型用在炒股上,还真能跑出点效果——我自己已经偷偷用它赚钱两周了😏。 在开始实操之前,咱先把一个误区掰扯清楚。 你可能觉得,DeepSeek,ChatGPT、文心一言这些AI已经很聪明了,“只要提示词写的好就能用来炒股”。 我当初也这么想。直到我试着问了DeepSeek几轮后才知道,它回答的全是—— 这都2025年了,他居然用2023年的数据来回答我😂 所以不是AI不行,而是他们没有实时的数据,连个炒股的“前提条件”都不具备。就像让一个盲人猜红绿灯。 那为啥我的能行?很简单: 我给大模型接上了“眼睛”和“耳朵”——一个能看实时股价,一个能读财经舆情。 这俩东西连上之后,大模型的分析准确率、策略理解力和生成能力,直接质变。 今天花姐就手把手带你搭建一套“DeepSeek + MCP”的炒股系统,看完文章动动手就能复刻。 MCP是什么?一句话:让AI看得懂当下

Skill 构建指南:从零打造 AI 智能体扩展包

Skill 构建指南:从零打造 AI 智能体扩展包 引言 在人工智能时代,如何让智能体具备更强的专业能力和更丰富的工作流程?答案就是 Skill——一种为智能体设计的能力扩展包。本文将详细介绍如何从零开始构建符合规范的 Skill,让你的创意变成可分发的工具。 什么是 Skill? 核心定位 Skill 是被智能体加载和执行的能力扩展包,而非独立运行的应用程序。 执行模式 * Skill 在智能体的会话上下文中被动态加载 * 智能体读取 SKILL.md 的指导,调用 scripts/ 中的脚本,参考 references/ 中的文档 * Skill 的所有交互都通过智能体与用户的对话完成 Skill 提供的能力 * ✅ 专门工作流程(多步骤程序与条件逻辑) * ✅ 工具集成(文件格式与 API 的使用方式) * ✅ 领域专家知识(公司或系统特有的架构与逻辑) * ✅ 打包资源(脚本、参考、资产) Skill