FPGA是一个高度集成化的芯片,其学习过程既需要编程,又需要弄懂硬件电路和计算机架构。涉及到的知识和基础非常多,如果不合理地安排学习内容,学习过程会非常漫长和枯燥。这篇文章主要阐述了对于入门FPGA的一些经验分享,希望能够给想学FPGA的人一些引导,少走一些弯路。入门学习FPGA主要分为以下三个阶段:
在正式开始学习FPGA之前,这里希望各位拿一本数电书好好看一下(相关专业的应该都学过数电这门专业课)无论有没有学过,需要把基本的逻辑运算的规则,与或非、同或异或等都搞明白,了解数字电路的原理和基本常识,为后面的FPGA学习奠定良好的基础。这里推荐的数电教材是《数字电子技术基础(第六版)》,是由阎石主编、高等教育出版社2016年出版的教材。

当然,学习FPGA基础的储备肯定不只是数电,还有模电,数字信号处理等等,后续可以看你是要做哪个方向再进行知识的补充,这里的数电基础是必须的有的。
为了能更好的入门学习FPGA,小编根据自己的学习历程,整理了“三件套”学习方法来学习FPGA。
目前主流的FPGA开发工具主要是AMD的Vivado和英特尔的Quartus,这里建议初学者优先学习使用Quartus,也就是使用英特尔FPGA的开发板作为入门学习使用(Vivado的学习使用较为繁琐,建议先学Quartus)。 网上有很多关于FPGA的课程,包括像正点原子,野火,明德扬等等,他们视频配套的开发板也在某宝售卖。这里建议初学者选择野火的FPGA征途pro系列开发视频,视频使用的征途pro开发板采用的是英特尔的芯片,也就是使用Quartus作为开发工具。野火基于波形图的开发方式对初学者是极其友好的,并且野火的代码风格算是比较好的(代码风格很重要)。相关的配套视频也已经更新完毕,视频资源齐全也是小编推荐该课程的重要原因之一。野火的视频课程入门阶段看到第三十二讲SignalTap Ⅱ即可,后续课程多为进阶,按照需求观看,不必全部刷完(浪费时间)。


主流的硬件编程语言主要有Verilog,HDL和Systemverilog。目前用的比较多的还是Verilog,入门阶段小编也建议优先学习Verilog,网上的配套视频也基本是以Verilog为主。虽然在视频课程里对于Verilog的语法有讲解,这边建议通过书籍对于Verilog语法进行一个学习,不一定面面俱到但要有一定了解,后续的视频学习中遇到不理解的地方也可以当成一本工具书进行查询,这里推荐的是夏宇闻的《Verilog数字系统设计教程》。
HDLbits是一个Verilog刷题网站,这个刷题网站可以在线完成编译。是对于语法基础知识的一个巩固。网上有许多博主已经更新了全套的答案,后续小编也会更新答案和讲解。

这一阶段你已经熟练掌握了FPGA基本的开发流程和了解了Verilog语言的使用。对于Quartus和modelsim这些软件的使用已经得心应手。这时候小编的建议是开始转向对于Vivado的学习,这个软件会比Quartus复杂一些,但是换汤不换药。这时候先不建议购入赛灵思的开发板,目前野火的赛灵思视频课程没有更新完毕,但是对于用来熟悉Vivado足够了。大资金比较充裕的大家也可以选择正点原子的达芬奇开发板(比较贵),使用正点的开发视频进行Vivado。在你习惯了野火的波形法后,正点的视频不像野火那么通俗易懂,要做好心理准备。小编这里还是建议暂时不买板子,利用视频熟悉一下Vivado开发流程即可。

当然这一阶段对于野火的后续视频也可以继续开始有选择性的观看,比如一些串口通信对于以后找工作还是很有用处的。
总结下来入门阶段你们最起码需要掌握的东西:
(1) 基础知识:数电
(2)编程语言:Verilog
(3)开发工具:Quartus,Vivado,Modelsim
(4)FPGA开发流程
这些在上述推荐的学习方法中均涉及到,按照步骤来即可。
通过这三个阶段的学习,能够坚持下来对于入门FPGA完全足够了。 这也只是FPGA学习第一步,想要成为一名合格的FPGA工程师后续的学习是非常枯燥漫长的。关于FPGA的学习其实网络上的视频课程相对于软件学习是很少的,但是不乏一些好的书籍,在这里也是希望大家能够养成啃书的习惯,到后续进阶看芯片手册和一些书籍时会轻松很多。
后续会对FPGA进阶学习做出一些经验的分享。
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总
深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
ES一、简介1、ElasticStackES技术栈:ElasticSearch:存数据+搜索;QL;Kibana:Web可视化平台,分析。LogStash:日志收集,Log4j:产生日志;log.info(xxx)。。。。使用场景:metrics:指标监控…2、基本概念Index(索引)动词:保存(插入)名词:类似MySQL数据库,给数据Type(类型)已废弃,以前类似MySQL的表现在用索引对数据分类Document(文档)真正要保存的一个JSON数据{name:"tcx"}二、入门实战{"name":"DESKTOP-1TSVGKG","cluster_name":"elasticsear
我完全不是程序员,正在学习使用Ruby和Rails框架进行编程。我目前正在使用Ruby1.8.7和Rails3.0.3,但我想知道我是否应该升级到Ruby1.9,因为我真的没有任何升级的“遗留”成本。缺点是什么?我是否会遇到与普通gem的兼容性问题,或者甚至其他我不太了解甚至无法预料的问题? 最佳答案 你应该升级。不要坚持从1.8.7开始。如果您发现不支持1.9.2的gem,请避免使用它们(因为它们很可能不被维护)。如果您对gem是否兼容1.9.2有任何疑问,您可以在以下位置查看:http://www.railsplugins.or
如何学习ruby的正则表达式?(对于假人) 最佳答案 http://www.rubular.com/在Ruby中使用正则表达式时是一个很棒的工具,因为它可以立即将结果可视化。 关于ruby-我如何学习ruby的正则表达式?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1881231/
深度学习12.CNN经典网络VGG16一、简介1.VGG来源2.VGG分类3.不同模型的参数数量4.3x3卷积核的好处5.关于学习率调度6.批归一化二、VGG16层分析1.层划分2.参数展开过程图解3.参数传递示例4.VGG16各层参数数量三、代码分析1.VGG16模型定义2.训练3.测试一、简介1.VGG来源VGG(VisualGeometryGroup)是一个视觉几何组在2014年提出的深度卷积神经网络架构。VGG在2014年ImageNet图像分类竞赛亚军,定位竞赛冠军;VGG网络采用连续的小卷积核(3x3)和池化层构建深度神经网络,网络深度可以达到16层或19层,其中VGG16和VGG
文章目录1、自相关函数ACF2、偏自相关函数PACF3、ARIMA(p,d,q)的阶数判断4、代码实现1、引入所需依赖2、数据读取与处理3、一阶差分与绘图4、ACF5、PACF1、自相关函数ACF自相关函数反映了同一序列在不同时序的取值之间的相关性。公式:ACF(k)=ρk=Cov(yt,yt−k)Var(yt)ACF(k)=\rho_{k}=\frac{Cov(y_{t},y_{t-k})}{Var(y_{t})}ACF(k)=ρk=Var(yt)Cov(yt,yt−k)其中分子用于求协方差矩阵,分母用于计算样本方差。求出的ACF值为[-1,1]。但对于一个平稳的AR模型,求出其滞