FPFA.一种二倍频电路代码描述以及测量详情

一、前言

1、因为需要倍频电路所以找了个二倍频的电路,通过fpga实际测量发现经过倍频后的电路峰值降低。不过这个也正常,因为该电路只要过触发点就会开始发生波形变化,而电路的触发值不是峰值。​​​​​​​

2、继续对电路做倍频后信号做二倍频,发现已经无法继续倍频,因为峰值电压的降低后触发d触发器的电压已经距离峰值非常接近了,没有足够的高电平保持时间,而倍频后的时钟边沿斜率又大致跟原时钟一样。(如图黄、蓝信号为一次跟二次倍频结果,紫色为原时钟)​​​​​​​

3、所以使用触发器的倍频方法:二倍频后就到头了。暂时还没找到优化电路的方法。

4、电路图​​​​​​​

二、代码描述(模块名为文件名)

1、模块代码

复制代码
//倍频电路
module f_double(
    input clk_in,
    output clk_out
);
    reg Q_n;
    
    assign clk_out = ~(Q_n ^ clk_in);
    always @(posedge clk_out) begin
        Q_n = !Q_n;
    end

endmodule

2、顶层测试代码

复制代码
module da_qian_ju_shi_233(
    input clk_27Mhz,
    output clk1, clk2, clk3
);
    wire clk_54Mhz;

    assign clk3 = clk_27Mhz;

    f_double j1(
        .clk_in  (clk_27Mhz),
        .clk_out (clk_54Mhz)
    );
    assign clk1 = clk_54Mhz;

    reg clk_t = 1'b0;
    always @(posedge clk_54Mhz) begin
        clk_t <= !clk_t;
    end
    assign clk2 = clk_t;

//继续倍频失败
//    f_double j2(
//        .clk_in  (clk_t),
//        .clk_out (clk2)
//    );
endmodule
相关推荐
ChipCamp2 小时前
Chisel芯片开发入门系列 -- 18. CPU芯片开发和解释8(流水线架构的代码级理解)
开发语言·青少年编程·fpga开发·scala·dsp开发·risc-v·chisel
I'm a winner7 小时前
基于 Ubuntu 的 Linux 系统中 Vivado 2020.1 下载安装教程
linux·ubuntu·fpga开发
9527华安8 小时前
FPGA实现Aurora 8B10B数据回环传输,基于GTP高速收发器,提供6套工程源码和技术支持
fpga开发·aurora·gtp·高速收发器·sfp·8b10b
秋风战士10 小时前
通信算法之298: verilog语法generate和for介绍
fpga开发
hi9413 小时前
HBM Basic(VCU128)
fpga开发·hbm·高带宽内存
ARM+FPGA+AI工业主板定制专家15 小时前
基于ARM+FPGA多通道超声信号采集与传输系统设计
linux·人工智能·fpga开发·rk3588·rk3568·codesys
Origin-VI19 小时前
ZYNQ-按键消抖
fpga开发
风已经起了1 天前
FPGA学习笔记——简单的乒乓缓存(RAM)
笔记·学习·fpga开发
小眼睛FPGA1 天前
【盘古100Pro+开发板实验例程】FPGA学习 | 基于 UDP 的以太网传输实验例程
科技·单片机·学习·ai·fpga开发·fpga
cjie2211 天前
Verilog与SytemVerilog差别
fpga开发