FPGA 逻辑级数

一:优化逻辑级数主要就是减少组合逻辑

二:打开方式:

1:

2:在tcl输入如下指令:

report_design_analysis -logic_level_distribution -logic_level_dist_paths 5000 -name design_analysis_prePlace

3

4:

5:

三:如何优化逻辑级数

1:ila位宽太大

2:计数器位数太高

3:用流水线代替组合逻辑

3.1ng

3.2ok

复制代码
module Test_Logic_levels(
    input           i_clk,
    input           i_rst,
    input  [31:0]   i_data_A,
    input  [31:0]   i_data_B,
    output [31:0]   o_sum
);

// 拆分输入为高低16位
wire [15:0] A_low  = i_data_A[15:0];
wire [15:0] A_high = i_data_A[31:16];
wire [15:0] B_low  = i_data_B[15:0];
wire [15:0] B_high = i_data_B[31:16];

// 第一级:低16位加法结果+进位寄存器
reg [15:0] low_sum_reg;
reg        carry_reg; // 低16位加法的进位
// 第二级:高16位加法结果寄存器
reg [15:0] high_sum_reg;

// 输出拼接
assign o_sum = {high_sum_reg, low_sum_reg};

// 第一级:低16位加法(组合逻辑)+ 寄存器打拍
always@(posedge i_clk) begin
    if(i_rst) begin
        low_sum_reg <= 16'd0;
        carry_reg   <= 1'b0;
    end else begin
        // 低16位加法,计算和与进位
        {carry_reg, low_sum_reg} <= A_low + B_low;
    end
end

// 第二级:高16位加法(含低16位进位)+ 寄存器打拍
always@(posedge i_clk) begin
    if(i_rst) begin
        high_sum_reg <= 16'd0;
    end else begin
        // 高16位加法,加上低16位的进位
        high_sum_reg <= A_high + B_high + carry_reg;
    end
end

endmodule
相关推荐
博览鸿蒙16 小时前
FPGA 工程中常见的基础硬件问题
fpga开发
GateWorld20 小时前
FPGA 实现无毛刺时钟切换
fpga开发·实战·无毛刺时钟
Seraphina_Lily1 天前
从接口选型到体系结构认知——谈 CPU–FPGA–DSP 异构处理系统与同构冗余设计
fpga开发
Seraphina_Lily1 天前
CPU–FPGA–DSP 异构系统中的总线接口选型——为什么 CPU 用 eLBC,而 DSP 用 XINTF?
fpga开发
GateWorld1 天前
FPGA开发十年心路
fpga开发
ALINX技术博客2 天前
【ALINX 教程】FPGA Multiboot 功能实现——基于 ALINX Artix US+ AXAU25 开发板
fpga开发·fpga
Genevieve_xiao2 天前
【verilog】如何一小时成为verilog高手(并非
fpga开发
从此不归路2 天前
FPGA 结构与 CAD 设计(第3章)上
ide·fpga开发
Aaron15882 天前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
碎碎思2 天前
在 FPGA 上实现并行脉冲神经网络(Spiking Neural Net)
人工智能·深度学习·神经网络·机器学习·fpga开发