利用simlink转化HDL-verilog

首先在simlink中找到HDL CODER

打开红色Blank DUT,进入里面绿色的子系统开始设计系统

例如设计一个正弦信号发生器,里面用到了add、memory、relation operator、switch、constant、cos模块,cos模块选择了cordic算法,使用cordic那么输入值的范围为【-2pi,2pi】,超过则错误,memory起到累加的效果,in1是每次累加的值,当累加值大于2pi则将其变为in1-2pi,这是因为cosx=cos(x-2pi)

之后记得将constant这些模块设置为定点数,如果是浮点数则需进行额外设置,暂时没学

这些所用的模块都在HDL里面选择

设置定点小数这里选择了有符号32位,20位小数,表示为sfix32_en20,例如对模块2*pi设置,如下

fixdt(1,32,20)中,1就是有符号,0是无符号,32是所用比特数,20就是小数用了多少比特数,其中在使用乘法器、除法器、减法器等,根据定点小数运算,输出的定点小数位数会变化,例如例子中的加法器输出会变成sfix33_en20,可以点击加法器调整

想其他模块的data type选择inherit via internal rule就行了,系统根据输入自动分配数据类型。采样率也许设置,否则仿真会不对,如果采样率是inf转hdl会报错:Delay balancing unsuccessful because Signal rate of value inf foun

之后进行转化

或者

选择verilog并选择你hdl转化到那个文件夹(folder)

转化成功后会输出如下

点击蓝色链接便可以看到Verilog程序,将其代入vivado进行测试,其中tb文件如下

复制代码
module tb;

reg clk;
reg reset;
reg clk_enable;
reg signed [31:0] In2;
wire ce_out;
wire signed [31:0] Out1;
HDL_DUT M
          (clk,
           reset,
           clk_enable,
           In2,
           ce_out,
           Out1);
initial clk=1;
always #10 clk=~clk;

initial begin
reset=1;
clk_enable=1;
In2=32'h19999;
#100;
reset=0;
end
endmodule

输出仿真结果正确如下

相关推荐
hai3152475432 小时前
RISC-V CVA6 AXI适配器+DMA桥蜂鸟E203处理器的总线接口单元(BIU)仲裁器
驱动开发·fpga开发·硬件架构·硬件工程·精益工程
高速上的乌龟7 小时前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.3 Hololink 顶层模块深度全解析
linux·fpga开发
吃好睡好便好10 小时前
矩阵的乘法运算
数据结构·人工智能·学习·线性代数·算法·matlab·矩阵
Ricky055311 小时前
搭载实时 FPGA 处理系统的航天器上用于海上监视的超分辨率YOLO目标检测技术(意大利2026年研究)
yolo·目标检测·fpga开发
kaizq12 小时前
在线设计模仿平台StepFPGA应用实践
fpga开发·verilog编程·在线设计仿真·小脚丫stepfpga·图形化设计·risc-v_soc·ima-copilot-ds
listhi52015 小时前
基于MATLAB的自适应粒子群算法(APSO)实现大规模分类特征选择
算法·matlab·分类
cjie22116 小时前
图像缩放需要哪些参数和端口
计算机视觉·fpga开发
思尔芯S2C16 小时前
FPGA Prototyping That Creates Useful Pre-Silicon Evidence
fpga开发
可编程芯片开发16 小时前
基于PSO粒子群优化的配电网可靠性指标matlab仿真
matlab·pso粒子群优化·配电网可靠性
啄缘之间16 小时前
10.【学习】SPI & UART 验证环境与测试用例
开发语言·经验分享·学习·fpga开发·测试用例·verilog