基于SparkRoad的《Verilog数字系统设计教程·第三版(夏宇闻)》学习(1)——绪论
绪论·思考题:
1.什么是信号处理电路?它通常由哪两大部分组成?
信号处理电路是进行一些复杂的数字运算和数据处理,并且又有实时响应要求的电路。
它们通常是由高速专用数字逻辑系统或专用数字信号处理器所构成,通常包括高速数据通道接口和高速算法电路。(书2.数字信号处理 提及)
2.为什么要设计专用的信号处理电路?
因为有的数字信号处理对时间的要求非常苛刻,以至于用高速的通用处理器也无法在规定的时间内完成必要的运算。通用微处理器芯片是为一般目的而设计的,运算的步骤必须通过编程编译后生成的机器码指令加载到存储器中,然后在微处理器芯片的控制下,按时钟的节拍,逐条取出指令分析指令和执行指令,直到程序的结束。微处理器芯片中的内部总线和运算部件也是为通用目的而设计,即使是专为信号处理而设计的通用微处理器,因为它的通用性也不可能为某一特殊的算法来设计一系列的专用的运算电路,而且其内部总线的宽度也不能随便的改变,只有通过改变程序,才能实现这个特殊的算法,因而其算法速度也受到限制,所以要设计专用的信号处理器。
3.什么是实时处理系统?
实时处理系统是具有实时响应的处理系统。
实时操作系统和分时操作系统
4.为什么要用硬件描述语言来设计复杂的算法逻辑电路?
因为现代复杂数字逻辑系统的设计都是借住于EDA工具完成的,无论电路系统的仿真和综合都需要掌握硬件描述语言。
5.能不能完全用C语言来代替硬件描述语言进行算法逻辑电路的设计
不能,因为基础算法的描述和验证通常用C语言来做。如果要设计一个专用的电路来进行这种对速度有要求的实时数据处理,除了以上C语言外,还须编写硬件描述语言进行仿真以便从电路结构上保证算法能在规定的时间内完成,并能通过与前端和后端的设备接口正确无误的交换数据。
(有点联想到交大的那篇HLS语言发展的论文)
为什么在算法逻辑电路的设计中需要用C语言和硬件描述语言配合使用来提高设计效率?
首先C语言很灵活,查错功能强,还可以通过PLI编写自己的系统任务,并直接与硬件仿真器结合使用。C语言是目前世界上应用最为广泛的一种编程语言,因而C程序的设计环境比VerilogHDL更完整,此外,C语言有可靠地编译环境,语法完备,缺陷缺少,应用于许多的领域。比较起来,Verilog语言只是针对硬件描述的,在别处使用并不方便。而用Verilog的仿真,综合,查错等大部分软件都是商业软件,与C语言相比缺乏长期大量的使用,可靠性较差,亦有很多缺陷。所以只有在C语言的配合使用下,Verilog才能更好地发挥作用。C语言与VerilogHDL语言相辅相成,互相配合使用。这就是即利用C语言的完整性又要结合Verilog对硬件描述的精确性,来更快更好地设计出符合性能要求的硬件电路系统,从而来提高效率。