【问题标题】:Generate frequency on FPGA在 FPGA 上生成频率
【发布时间】:2014-02-25 21:19:34
【问题描述】:

我希望从我的 FPGA 生成一个小信号。我想通过我板上的立体声输出它。后者将充当简单的 DAC。下面是一个简单的 Verilog 程序,它应该会发出哔声,但不会。

module music(clk, speaker);

input clk;
output speaker;

// Binary counter, 16-bits wide
reg [15:0] counter;

 initial 
    begin
    counter = 0;
    end

always @(posedge clk) counter <= counter+1;

// Use the most significant bit (MSB) of the counter to drive the speaker
assign speaker = counter[15];
endmodule

最终我想通过立体声输出输出一个非常低频的正弦波。 有没有关于如何做到这一点的示例代码......有什么想法吗?我正在使用 DE2i-150 板。谢谢!

【问题讨论】:

  • 这不是“reg[15:0] counter;”吗?做?请提供代码。
  • 时钟频率是多少?输出波形是否在可听频谱中?
  • 时钟频率为25MHz,输出应为380Hz左右的方波信号。

标签: verilog fpga


【解决方案1】:

我会使用异步重置来初始化计数器:

module music(clk, _reset, speaker);

input clk, _reset;
output speaker;

// Binary counter, 16-bits wide
reg [15:0] counter;

always @(posedge clk or negedge _reset) 
    if (_reset == 1'b0)
        counter <= 'b0;
    else 
        counter <= counter + 1;

// Use the most significant bit (MSB) of the counter to drive the speaker
assign speaker = counter[15];

endmodule

edaplayground 上的测试平台。

您可以使用时钟频率和计数器的上限来获得您想要的频率,即,而不是使用最高有效位,只需编写:

if (counter == UPPER_LIMIT) begin speaker = ~speaker; counter &lt;=0; end

这只会产生方波。为了生成正弦波,一种简单的方法是创建一个查找表。 See this.

【讨论】:

  • 我相信 initial x=0 在 FPGA 上是首选,因为异步复位触发器有限。而异步触发器在 ASIC 上是首选。
  • 同步重置怎么样?最初的 x=0 究竟是什么合成的?当芯片上电时,它的寄存器没有已知值,这就是为什么需要同步或异步复位的原因。诚然,在某些 FPGA 中,下载位文件也会初始化所有内存元素,因此可能会在没有复位信号的情况下逃脱,但该代码将是 FPGA 和板特定的。所以我相信,除非你的 FPGA 上的面积真的很短,否则最好使用复位信号。更多关于重置:eetimes.com/document.asp?doc_id=1278998
  • 一年前我会同意,但reg x=0; 或 intial 块似乎确实是为 FPGA 设置初始值的一种可接受的方式,并且经常在这个站点上从那些拥有更多 FPGA 的人那里得到建议比我有经验。
猜你喜欢
  • 2019-02-09
  • 2016-02-02
  • 2016-11-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-24
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多