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

AI入门第一课:人工智能基础概念全解析 - 从零开始理解这个改变世界的技术

AI入门第一课:人工智能基础概念全解析 - 从零开始理解这个改变世界的技术

目录 * 为什么要了解人工智能? * 什么是人工智能?从图灵测试说起 * 人工智能的三次浪潮:从幻想到现实 * 第一次浪潮:符号主义的黄金时代 * 第二次浪潮:机器学习的崛起 * 第三次浪潮:深度学习的革命 * 机器学习的三大范式:监督学习、无监督学习和强化学习 * 监督学习:有老师指导的学习 * 无监督学习:自己发现规律的学习 * 强化学习:通过试错来学习 * 深度学习:模仿人脑的神经网络 * 神经网络的基本结构 * 从感知机到深度神经网络 * 卷积神经网络:专门为图像设计的网络 * 循环神经网络:处理序列数据的高手 * 人工智能的应用领域:改变世界的力量 * 医疗健康:AI医生的崛起 * 自动驾驶:重新定义出行方式 * 金融科技:智能理财的新时代 * 教育培训:个性化学习的新模式 * 娱乐媒体:内容创作的新可能 * 人工智能的局限性和挑战:理性看待AI * 数据依赖:AI的"食粮"问题 * 可解释性:

爆火的OpenClaw到底是个啥?一文看透这只“AI龙虾”的真面目与暗坑

爆火的OpenClaw到底是个啥?一文看透这只“AI龙虾”的真面目与暗坑

目录 前言 一、OpenClaw是什么?——它不是“最强大脑”,而是一双“手” 二、它能干什么?为什么让这么多人兴奋? 2.1 拥有“全局记忆”,它能越来越懂你 2.2 从“被动回答”到“主动干活” 2.3 深度的本地控制权 三、滤镜碎裂:这只“龙虾”背后的四个深坑 3.1 第一个坑:灾难级的安全隐患(最致命) 3.2 第二个坑:极不稳定的“办事能力” 3.3 第三个坑:令人咋舌的“烧钱”速度 3.4 第四个坑:大厂为什么不做?

Windows纯本地部署OpenClaude:从零搭建你的7×24小时AI助理,打通微信/飞书

无需云服务器,一台Windows电脑就能让AI助手24小时在线,还能通过手机随时指挥它干活 前言 之前写过一篇用云服务器部署OpenClaude的教程,不少读者反馈:“一定要买服务器吗?我只有一台Windows电脑行不行?” 答案是:当然可以! OpenClaude本来就是完全支持本地部署的开源AI助手框架。你只需要一台Windows电脑,就能跑起一个完整的AI服务,而且可以通过微信、飞书随时随地指挥它——查文件、开软件、管理电脑,甚至让它在你睡觉的时候帮你处理任务。 这篇文章将手把手教你在Windows环境纯本地部署OpenClaude,并打通飞书和企业微信,全程不需要买云服务器。 一、先搞懂:三种部署方式,你选哪个? OpenClaude支持三种部署模式,先看这张图快速理解区别: 部署方式架构优点缺点本地部署全在本地电脑无需服务器、免费、隐私安全电脑关机AI就下线云端部署全在云服务器7×24小时在线、稳定需要付费买服务器混合部署云端大脑+本地手脚24小时在线+能操作本地电脑架构复杂、需要两台机器 本文选择第一种:纯本地部署。虽然电脑关机时AI会下线,但

OpenClaw + cpolar + 蓝耘MaaS:把家里的 AI 变成“随身数字员工”,出门也能写代码、看NAS电影、远程桌面

OpenClaw + cpolar + 蓝耘MaaS:把家里的 AI 变成“随身数字员工”,出门也能写代码、看NAS电影、远程桌面

目录 前言 1 OpenClaw和cpolar是什么? 1.1 OpenClaw:跑在你自己电脑上的本地 AI 智能体 1.2 cpolar:打通内网限制的内网穿透桥梁 2 下载 安装cpolar 2.1 下载cpolar 2.2 蓝耘 MaaS 平台:给 OpenClaw 装上“最强大脑” 2.3 注册及登录cpolar web ui管理界面 2.4 一键安装 OpenClaw 并对接蓝耘 MaaS 3 OpenClaw + cpolar 的 N 种玩法 3.1 出门在外也能看家里 NAS