仿真实例1——正弦函数仿真(ROM)

2024-05-31 20:48
文章标签 函数 仿真 实例 rom 正弦

本文主要是介绍仿真实例1——正弦函数仿真(ROM),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欲观原文,请君移步微信

对于FPGA来说,产生三角函数,幂函数,指数函数或者log函数等,如果真的使用乘法器来撘电路,那是极其消耗DSP资源的
,所以一般情况下都是采用LUT进行查表获取的。
所以产生一个正弦波形的实现步骤如下:
1.正弦函数的在给定取值范围内的函数值
2.将正弦函数的函数值存入ROM或者RAM中(初始化)
3.从ROM或者RAM中读出函数值

1.matlab获取正弦函数值

t=[0:0.1:90];##产生第一象限0°~90°之间的正弦函数值
x=pi*t/180;
sin_vale=sin(x);
fid=fopen('sin.mif','wt');##待写入的文件
fprintf(fid,'width=14;\n');
fprintf(fid,'depth=1024;\n');
fprintf(fid,'address_radix=uns;\n');
fprintf(fid,'data_radix=dec;\n');
fprintf(fid,'content begin\n');
for j=1:901i=j-1;k=round(sin_vale(j)*16384);if(k==16384)k=16383;endfprintf(fid,'%d,\n',k);
end
fprintf(fid,'end;\n');
fclose(fid);

产生的sin.mif文件如下图所示

 

2.将sin.mif文件存入ROM中

选择IP->Block Memory Generator,第一步在Memory type选择Single port Rom

 
选择端口的宽度Port A为14,选择端口深度Port A为1024


然后选择COE文件Editor,将刚才matlab生成的数据填写Vector即可。

3.读ROM进行仿真

仿真ROM IP,编写testbench文件。

`timescale 1ns / 1ps
module sin;parameter DW=15;parameter AW=10;parameter ADDR_MAX=900;parameter const_half_pi = ADDR_MAX - 1; //90°parameter const_pi = ADDR_MAX*2 - 1; //180°parameter const_double_pi = ADDR_MAX*4 - 1; //360°reg [AW+2-1:0] address_tmp;reg [AW-1:0] address;reg clk;wire [DW-1:0] q_tmp;reg [DW+1-1:0] q_tmp1;wire [DW-1:0] q;initialbeginclk<=0;address_tmp<= {AW+2{1'b0}};endblk_mem_gen_0 sin_test (.clka(clk),    // input wire clka.addra(address),  // input wire [9 : 0] addra.douta(q_tmp)  // output wire [14 : 0] douta);always #10 clk = ~clk;always @(posedge clk)if(address_tmp == const_double_pi)beginaddress_tmp <= {AW+2{1'b0}};address <= {AW{1'b0}};endelsebeginaddress_tmp<=address_tmp+1'b1;if(address_tmp<=const_half_pi)address <= address_tmp[AW-1:0];  //the first quadrandelse if(address_tmp <= const_pi)  //the second quadrandaddress <= const_pi - address_tmp;else if(address_tmp <= (const_pi+const_half_pi))//the third quadrandaddress <= address_tmp-const_pi;elseaddress <= const_double_pi-address_tmp;endalways @(posedge clk)beginif(address_tmp<=const_pi)q_tmp1<={1'b0,q_tmp};else    q_tmp1<={DW+1{1'b0}}-{1'b0,q_tmp};endassign q = q_tmp1[DW-1:0];
endmodule

仿真波形如下图

小编寄语:其实对于ROM来说,原先是需要一个COE文件的,而且只能进行读取,不能写入,现在的verilog语法已经可以对RAM或者寄存器初始化,所以以后很可能不需要ROM了。

 

 

这篇关于仿真实例1——正弦函数仿真(ROM)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1019013

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

STM32内部闪存FLASH(内部ROM)、IAP

1 FLASH简介  1 利用程序存储器的剩余空间来保存掉电不丢失的用户数据 2 通过在程序中编程(IAP)实现程序的自我更新 (OTA) 3在线编程(ICP把整个程序都更新掉) 1 系统的Bootloader写死了,只能用串口下载到指定的位置,启动方式也不方便需要配置BOOT引脚触发启动  4 IAP(自己写的Bootloader,实现程序升级) 1 比如蓝牙转串口,

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据