CORDIC Translate

随便记录一下下:

Cordic IP核使用说明以及避坑记录-CSDN博客

本次只用到了Translate,记录一下自己遇到的坑坑

实际配置:

`timescale 1ns / 1nsmodule cordic_tb();reg clk;wire m_axis_dout_tvalid;reg s_axis_cartesian_tvalid = 0;wire [31 : 0] s_axis_cartesian_tdata;wire [31 : 0] m_axis_dout_tdata;wire [15:0] x_abs   = m_axis_dout_tdata[15:0];  //abs(15:0) fix16_14; wire [15:0] x_phase = m_axis_dout_tdata[31:16]; //Phase(31:16) fix16_13;reg [15:0] x_r = 0;reg [15:0] x_i = 0;always #10 clk = ~clk;reg [5:0] cnt ;reg [1:0] index;always@(posedge clk) if(cnt==22) begin cnt <= 0;  index <= index + 1;endelse    cnt <= cnt + 1;always@(posedge clk) case (index)2'b00: begin x_r <= 16'b0011_0000_0000_0000; x_i <= 16'b0011_0000_0000_0000; end //fix16_14   0.75+0.75i    12'b01: begin x_r <=~16'b0100_0000_0000_0000 + 1'b1; x_i <= 16'b0011_0000_0000_0000; end //fix16_14   -1+0.75i   22'b10:begin x_r <=~16'b0001_0000_0000_0000 + 1'b1; x_i <=~16'b0010_0000_0000_0000 + 1'b1; end //fix16_14   -0.25-0.5i  32'b11: begin x_r <= 16'b0001_0000_0000_0000; x_i <=~16'b0010_1000_0000_0000 + 1'b1; end //fix16_14   0.25-0.625i   4endcaseassign s_axis_cartesian_tdata = {x_i, x_r}; initial beginclk = 0;index = 0;cnt = 0 ;index = 0 ;s_axis_cartesian_tvalid <= 0;#100 s_axis_cartesian_tvalid <= 1;end    cordic_translate cordic_ (.aclk(clk),                                        // input wire aclk.s_axis_cartesian_tvalid(s_axis_cartesian_tvalid),  // input wire s_axis_cartesian_tvalid.s_axis_cartesian_tdata(s_axis_cartesian_tdata),    // input wire [31 : 0] s_axis_cartesian_tdata.m_axis_dout_tvalid(m_axis_dout_tvalid),            // output wire m_axis_dout_tvalid.m_axis_dout_tdata(m_axis_dout_tdata)              // output wire [31 : 0] m_axis_dout_tdata  );    //input  Real(15:0) fix16_14; Imag(31:16) fix16_14//output Real(15:0) fix16_14; Phase(31:16) fix16_13 endmodule

// 调试后还是比较简单捏~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/46581.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

快速上手electron

官方文档: https://www.electronjs.org/zh/docs/latest/ 搭建项目 新建文件夹并初始化项目 mkdir my-electron-app && cd my-electron-app npm init -y注意:新生成的package.json的author(作者)和description(描述)字段要填写补全,不然后期打包会打不了 将package.…

使用Redis实现签到功能:Java示例解析

使用Redis实现签到功能&#xff1a;Java示例解析 在本博客中&#xff0c;我们将讨论一个使用Redis实现的签到功能的Java示例。该示例包括两个主要方法&#xff1a;sign()和signCount()&#xff0c;分别用于用户签到和计算用户当月的签到次数。 1. 签到方法&#xff1a;sign()…

【DRAM存储器三十四】LPDDR4介绍--MR和IO结构

👉个人主页:highman110 👉作者简介:一名硬件工程师,持续学习,不断记录,保持思考,输出干货内容 参考资料:《镁光LPDDR4数据手册》 、《JESD209-4B》 目录 MR DDR3、DDR4、LPDDR4的IO结构变化 MR LPDDR4的MR包括保留未用的有64个,这个就不像以前一…

前端 JS 经典:二维数组转一维数组去重

前言&#xff1a;将数组[[1, 2], [2, 3], [1, 4]] 转为一维数组&#xff0c;且去重 1. 使用 Array.prototype.flat() 和 Set const twoDArray [[1, 2],[2, 3],[1, 4],];const oneDArray Array.from(new Set(twoDArray.flat()));console.log(oneDArray); // [1, 2, 3, 4] 2…

CUTLASS

文章目录 1、关于 CUTLASS2、CUTLASS 3.5中的新增功能3、性能4、兼容性4、操作系统5、硬件6、目标架构7、文档8、资源9、构建 CUTLASS10、项目结构11、CUTLASS模板库CUTLASS SDK示例工具测试 12、性能分析13、构建所有GEMM和卷积内核&#xff08;构建时间长&#xff09;14、构建…

银河麒麟高级服务器操作系统V10加固操作指南

1:检查系统openssh安全配置: 2:检查是否设置口令过期前警告天数: 3:检查账户认证失败次数限制: 修改/etc/pam.d/system-auth文件中deny的参数即可 4:检查是否配置SSH方式账户认证失败次数限制:

StarRocks部署高可用 FE 集群

一、准备工作 1.1 部署规划 这里我打算部署存算一体模式&#xff0c;三节点。即三个FE节点&#xff0c;三个BE节点。假设三台IP分别为&#xff1a;10.10.10.50、10.10.10.51、10.10.10.52 我将采用三台centos7.9进行部署&#xff0c;单台配置为128C 256G 3T。 1.2 服务器检查…

拓展神经网络八股(入门级)

自制数据集 minst等数据集是别人打包好的&#xff0c;如果是本领域的数据集。自制数据集。 替换 把图片路径和标签文件输入到函数里&#xff0c;并返回输入特征和标签 要生成.npy格式的数据集&#xff0c;在进行读入训练集。 只需要把图片灰度值数据拼接到特征列表&#xff0…

进程间通信(下)

system V共享内存 共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间&#xff0c;这些进程间数据传递不再涉及到内核&#xff0c;换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据 共享内存示意图 通过上面的图&#xff0c;我们不难想到…

java算法day14

java算法day14 222 完全二叉树的节点个数。110 平衡二叉树257 二叉树的所有路径124 二叉树中的最大路径和 222 完成二叉树的节点个数 解法1&#xff0c;层序遍历&#xff0c;迭代解法。 就是层序遍历的模板题。 /*** Definition for a binary tree node.* public class Tree…

linux的学习(三):用户权限,查找,压缩命令

简介 关于用户权限&#xff0c;查找和压缩解压缩命令的简单使用 用户管理命令 useradd useradd&#xff1a;添加新用户&#xff0c;要root权限才能使用 useradd -g 组名 用户名&#xff1a;可以添加到组 创建成功会在 /home下有用户的主目录 passwd passwd 用户名&#x…

【C语言】多进程服务器

多进程服务器 多进程服务器步骤代码 最后 多进程服务器 步骤 服务器使用父进程 fork 创建子进程来和客户端进行通信&#xff0c;父进程负责取出连接请求。并且父进程接收子进程退出信号&#xff0c;通过信号处理函数回收子进程 步骤&#xff1a; 1.首先屏蔽子进程退出信号 2.使…

【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第60集-agent训练资讯APP重点推荐AI资讯内容(含视频)

【WEB前端2024】3D智体编程&#xff1a;乔布斯3D纪念馆-第60集-agent训练资讯APP重点推荐AI资讯内容&#xff08;含视频&#xff09; 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。d…

php反序列化--2--PHP反序列化漏洞基础知识

一、什么是反序列化&#xff1f; 反序列化是将序列化的字符串还原为PHP的值的过程。 二、如何反序列化 使用unserialize()函数来执行反序列化操作 代码1&#xff1a; $serializedStr O:8:"stdClass":1:{s:4:"data";s:6:"sample";}; $origina…

Android Service的解析

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 Android服务&#xff0c;即Service&#xff0c;是Android四大组件之一&#xff0c;是一种程序后台运行的方案&am…

新增支持GIS地图、数据模型引擎升级、增强数据分析处理能力

为了帮助企业提升数据分析处理能力&#xff0c;Smartbi重点围绕产品易用性、用户体验、操作便捷性进行了更新迭代&#xff0c;同时重磅更新了体验中心。用更加匹配项目及业务需求的Smartbi&#xff0c;帮助企业真正发挥数据的价值&#xff0c;赋能决策经营与管理。 Smartbi用户…

js中使用原型链增加方法后,遍历对象的key-value时会遍历出方法

原因&#xff1a;js使用原型链实现方法时&#xff0c;这个方法默认是可迭代的&#xff0c;所以在遍历时就会被遍历出来&#xff0c; 例&#xff1a; Array.prototype.remove function(n){return this.slice(0,n).concat(this.slice(n1,this.length));}var cc ["cccaaaa…

五:C语言-操作符

五&#xff1a;操作符 1.关系操作符&#xff1a; 在C语言中用于比较的表达式&#xff0c;称为 “关系表达式” &#xff0c;里面使用的运算符就称为 “关系运算符” &#xff0c;主要有下面六个&#xff1a; 关系运算符描述>大于运算符<小于运算符>大于等于运算符&…

wifi信号处理的CRC8、CRC32

&#x1f9d1;&#x1f3fb;个人简介&#xff1a;具有3年工作经验&#xff0c;擅长通信算法的MATLAB仿真和FPGA实现。代码事宜&#xff0c;私信博主&#xff0c;程序定制、设计指导。 &#x1f680;wifi信号处理的CRC8、CRC32 目录 &#x1f680;1.CRC概述 &#x1f680;1.C…

定时器的计数模式 定时器中断时钟配置

目录 一&#xff0c;定时器的计数模式 二&#xff0c;定时器中断时钟的配置 三&#xff0c;输入和输出原理 四&#xff0c;PWM波的小简介 一&#xff0c;定时器的计数模式 1.1 定时器的计数模式分别有三种 1.2 定时器溢出的时间&#xff08;中断&#xff0c;事件产生的时间…