(FPGA代做)通过matlab生成mif文件生成正弦波、方波、锯齿波,并调用ROM.IP核生成仿真输出相应三种波形

(FPGA代做)通过matlab生成mif文件生成正弦波、方波、锯齿波,并调用ROM.IP核生成仿真输出相应三种波形通过matlab软件或者其他软件生成正弦波、方波、锯齿波等坡形数据;掌握ROMIP核的配置方法,知道IP核中每个参数的作用;将ROM的波形仿真输出在modelsim上进行验证正确性;技术文档:问题一:设计方法:通过matlab生成正弦波、方波、锯齿波等坡形数据的方式有很多种,考虑到后续需要调用IP核,本设计采用fprintf函数生成.mif文件。整体思路就是使用MATLAB中fprintf函数根据.mif文件的格式一句一句打印出来。以正弦波为例,正弦波的周期是,数据设计深度为

设计目标:

  1. 通过matlab软件或者其他软件生成正弦波、方波、锯齿波等坡形数据;
  2. 掌握ROM IP核的配置方法,知道IP核中每个参数的作用;
  3. 将ROM的波形仿真输出在modelsim上进行验证正确性;

技术文档:
问题一
设计方法:
通过matlab生成正弦波、方波、锯齿波等坡形数据的方式有很多种,考虑到后续需要调用IP核,本设计采用fprintf函数生成.mif文件。整体思路就是使用MATLAB 中fprintf函数根据.mif文件的格式一句一句打印出来。
以正弦波为例,正弦波的周期是 ,数据设计深度为256,将 平均等分成256份,其等距宽度为 ,因为数据位宽为8位,其所表示的数据在0-255之间。所以需要将 的幅值从-1到+1变化到0到255。也就是 。乘以128,幅值变化到-128到+128然后在加上128,范围就变到了0到256。

实验结果:
正弦波:
在这里插入图片描述
方波:

在这里插入图片描述

锯齿波:
在这里插入图片描述
问题2
设计方法:
Quartus中IP和的配置方法如下图所示
1、选择单端口rom
在这里插入图片描述
2、给IP核命名
在这里插入图片描述
3、next
在这里插入图片描述
4、next
在这里插入图片描述
5、加载生成的mif文件
在这里插入图片描述
6、next->finish
在这里插入图片描述
IP核的参数(以rom_rectangle)为例

 rom_rectangle (
    address,
    clock,
    q);

address 代表mif文件中的地址
clock:时钟
q:代表对应地址的输出

问题3
技术方案:编写tb仿真文件
波形选择模块(通过状态机实现模型选取00选择正弦波 01方波10锯齿波)

// 波形选择
   always@(posedge clk or negedge rst)
        if(rst==1'b0)
             wave<=2'b00; 
           else if(key[0]==1'b0)
              wave<=wave+1'b1;
            else 
              wave<=wave;
              
    always@(*)
          case(wave)
                  2'b00: data<=sin_data;
                  2'b01: data<=rectangle_data;
                  2'b10: data<=sawtooth_data;
                  default: data<=sin_data;
             endcase

例化rom模块

// 例化波形  
    rom_sin rom_sin1(
                .address(addr),
                .clock(clk),
                .q(sin_data));

    rom_rectangle rom_rectangle1(
                .address(addr),
                .clock(clk),
                .q(rectangle_data));        
    
    rom_triangle rom_triangle1(
                .address(addr),
                .clock(clk),
                .q(triangle_data));
                
    rom_sawtooth  rom_sawtooth(
                .address(addr),
                .clock(clk),
                .q(sawtooth_data));

仿真结果:
在这里插入图片描述
工程代码:添加链接描述

今天的文章(FPGA代做)通过matlab生成mif文件生成正弦波、方波、锯齿波,并调用ROM.IP核生成仿真输出相应三种波形分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/32852.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注