废话不说了,下面进入正题,学习FPGA经历了这么几个阶段:①、Verilog语言的学习,熟悉Verilog语言的各种语法。
②、FPGA的学习,熟悉QuartusII软件的各种功能,各种逻辑算法设计,接口模块(RS232,LCD,VGA,SPI,I2c等)的设计,时序分析,硬件优化等,自己开始设计简单的FPGA板子。
③、NiosII的学习,熟悉NiosII的开发流程,熟悉开发软件(SOPC,NiosIIIDE),了解NiosII的基本结构,设计NiosII开发板,编写NiosIIC语言程序,调试板子各模块功能。
先来说说第一个阶段,现在主要的硬件描述语言有VHDL,Verilog两种,在本科时老师一般教VHDL,不过现在Verilog用的人越来越多,其更容易上手(与C语言语法比较类似),也更灵活,现在的IC设计基本都用Verilog。
像systemC,systemVerilog之类的应该还在萌芽阶段,以后可能会有较大发展。
鉴于以上原因我选择了Verilog作为我学习的硬件描述语言。
其实有C语言的基础,学起Verilog的语言很简单,关键要有并行的概念,所有的module,assign,always都是并行的,这一点与软件语言有明显不同。
这里推荐几本评价比较好的学习Verilog的书籍:①、《verilog数字系统设计教程》,这本书对于入门是一本很好的书,通俗易懂,让人很快上手,它里面的例子也不错。
但本书对于资源优化方面的编程没有多少涉及到。
②、《设计与验证VerilogHDL》,这本书虽然比较薄,但是相当精辟,讲解的也很深入,很多概念看了这本书有种豁然开朗的感觉,呵呵。
学习Verilog其实不用看很多书,基本的语法部分大家都一样,关键是要自己会灵活应用,多做练习。
Verilog语言学了一段时间,感觉自己可以编点东西,希望自己编的程序在板子上运行看看结果,下面就介绍我学习的第二个阶段。
刚开始我拿了实验室一块CPLD的开发板做练习,熟悉QuartusII的各种功能,比如IP的调用,各种约束设置,时序分析,Logiclock设计方法等,不过做到后面发现CPLD的资源不太够(没有内嵌的RAM、不能用SignalTapII,LE太少等),而实验室没有FPGA开发板,所以就萌生了自己做FPGA开发板的意图,刚好Cadence我也学的差不多了,就花了几天时间主要研究了FPGA配置电路的设计,在板子上做了Jtag和AS下载口,在做了几个用户按键和LED,其他的口全部引出作为IO口,电路比较简单,板子焊好后一调就通了(心里那个爽啊...)。
我选的FPGA是cycloneII系列的EP2C5,资源比以前的FPGA多了好几倍,还有PLL,内嵌的RAM,可以试试SignalTapII,用内嵌的逻辑分析仪测试引脚波形,对于FPGA的调试,逻辑分析仪是至关重要的。
利用这块板子我完成了项目中的几个主要功能:RS232通信,指令译码,配置DDS,AD数据高速缓存,电子开关状态设置等,在实践中学习起来真的比平时快很多,用到什么学什么动力更大。
这个时候我主要看的数据有这几本感觉比较好:①、《AlteraFPGA/CPLD设计(基础篇)》:讲解一些基本的FPGA设计技术,以及QuartusII中各个工具的用法(IP,RTL,SignalProbe,SignalTapII,TimingClosureFloorplan,chipEditor等),对于入门非常好。
②、《AlteraFPGA/CPLD设计(高级篇)》:讲解了一些高级工具的应用,LogicLock,时序约束很分析,设计优化,也讲述了一些硬件编程的思想,作为提高用。
③、《FPGA设计指南--器件,工具和流程》:这本书看了他的目录忍不住就买了,这本书讲述了FPGA设计的各个方面,虽然每个方面都是点到为止,但能让你有个整体的概念,了解FPGA的所有设计功能,了解FPGA开发的整个流程。
2025/11/11 0:01:05 131.03MB FPGA 学习 文档 合集
1
ROS2编程基础课程文档ROS2(机器人操作系统2)是用于机器人应用的开源开发套件。
ROS2之目的是为各行各业的开发人员提供标准的软件平台,从研究和原型设计再到部署和生产。
ROS2建立在ROS1的成功基础之上,ROS1目前已在世界各地的无数机器人应用中得到应用。
特色缩短上市时间ROS2提供了开发应用程序所需的机器人工具,库和功能,可以将时间花在对业务非常重要的工作上。
因为它是开源的,所以可以灵活地决定在何处以及如何使用ROS2,以及根据实际的需求自由定制,使用ROS2可以大幅度提升产品和算法研发速度!专为生产而设计凭借在建立ROS1作为机器人研发的事实上的全球标准方面的十年经验,ROS2从一开始就被建立在工业级基础上并可用于生产,包括高可靠性和安全关键系统。
ROS2的设计选择、开发实践和项目管理基于行业利益相关者的要求。
多平台支持ROS2在Linux,Windows和macOS上得到支持和测试,允许无缝开发和部署机器人自动化,后端管理和用户界面。
分层支持模型允许端口到新平台,例如实时和嵌入式操作系统,以便在获得兴趣和投资时引入和推广。
丰富的应用领域与之前的ROS1一样,ROS2可用于各种机器人应用,从室内到室外、从家庭到汽车、水下到太空、从消费到工业。
没有供应商锁定ROS2建立在一个抽象层上,使机器人库和应用程序与通信技术隔离开来。
抽象底层是通信代码的多种实现,包括开源和专有解决方案。
在抽象顶层,核心库和用户应用程序是可移植的。
建立在开放标准之上ROS2中的默认通信方法使用IDL、DDS和DDS-IRTPS等行业标准,这些标准已广泛应用于从工厂到航空航天的各种工业应用中。
开源许可证ROS2代码在Apache2.0许可下获得许可,在3条款(或“新”)BSD许可下使用移植的ROS1代码。
这两个许可证允许允许使用软件,而不会影响用户的知识产权。
全球社区超过10年的ROS项目通过发展一个由数十万开发人员和用户组成的全球社区,为机器人技术创建了一个庞大的生态系统,他们为这些软件做出贡献并进行了改进。
ROS2由该社区开发并为该社区开发,他们将成为未来的管理者。
行业支持正如ROS2技术指导委员会成员所证明的那样,对ROS2的行业支持很强。
除了开发顶级产品外,来自世界各地的大大小小公司都在投入资源为ROS2做出开源贡献。
与ROS1的互操作性ROS2包括到ROS1的桥接器,处理两个系统之间的双向通信。
如果有一个现有的ROS1应用程序,可以通过桥接器开始尝试使用ROS2,并根据要求和可用资源逐步移植应用程序。
1
上次说了dds的原理,这次我们用FPGA来实现dds。
因为dds在da之前都是数字器件,所以我们可以用FPGA来实现dds的前两个部分。
2025/8/31 3:41:20 292KB FPGA DDS ISE 文章
1
直接数字合成(DDS)是一种重要的频率合成技术,具有分辨率高、频率变换快等优点,在通信等领域有着广泛的应用前景。
本系统采用直接频率信号合成器(DDS)AD9850与STC89S52单片机相结合的方法,以AD9850为频率合成器,以单片机为进程控制和任务调度的核心,设计了一个信号发生器。
实现了输出频率在10HZ~20MHZ范围可调,输出信号频率稳定度优于10-3的正弦波、方波和三角波信号,输出信号无明显失真。
本文给出了AD9850芯片和STC89S52单片机的硬件组成原理框图、单元电路分析及软件流程,并通过严格的实测数据分析圆满完成了本设计任务。
2025/8/17 13:14:14 269KB DDS 单片机 信号发生器
1
基于QuartusII的dds信号发生器.rar.rar
2025/7/21 5:18:12 10.04MB Quartus
1
经过我测试通过的,用VHDL编写DDS,模块鲜明,非常适合新手学习
2025/6/7 17:35:36 398KB FPGA DDS LPM_ROM 数字频率
1
基于DDS任意波形发生器的完整项目代码。
经过难证的。
对于毕业设计,工程开发都有很好的参考价值。
2025/6/7 4:54:25 2.3MB FPGA DDS 任意波形发生
1
2012山东省电子设计竞赛E题源程序,DDS输出波形,FFT处理得出结果。
2025/5/19 22:48:46 1.58MB stm32 dds fft
1
DDS工作原理及性能分析基于DDS技术的智能信号发生器的设计
2025/3/30 3:32:35 309KB DDS工作原理及性能分析
1
DDS开发者必备手册
2025/3/20 5:52:26 969KB OpenDDS 中文版 开发指南 帮助文档
1
共 115 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡