Vivado使用Cordic IP计算e^ix(复e指数函数)

2023-10-08 17:40

本文主要是介绍Vivado使用Cordic IP计算e^ix(复e指数函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里写自定义目录标题

  • 原理
  • IP解析
  • 设置IP
  • HDL Code
  • Simulation
    • Code
    • 仿真
  • reference

原理

根据欧拉公式
e^(ix)=(cos x+isin x)

IP解析

在这里插入图片描述
1 选择功能为计算正余弦
2 并行(面积和速度的平衡)
3 流水线模式开到最大(不知道有啥用)
4 有符号小数(整数宽度为2(里面应该包含了一位符号位))
这个选项是默认的,而且我们用的是相位而不是坐标对,可以忽略这个选项
在这里插入图片描述
5 相位格式(以弧度为单位还是以pi为单位,1位符号位,2位整数位和N-3位小数位的补码)
在这里插入图片描述
不同的格式对应着不同的输入范围,
在这里插入图片描述
在这里插入图片描述
6 输入宽度(按需配置)

7 输出宽度(建议与输入宽度保持一致)
在这里插入图片描述
在这里插入图片描述
输入时为2qn,输出时为1qn

8 取整模式(这里计算的是小数,私以为取整模式不重要)
在这里插入图片描述
在这里插入图片描述
9 迭代次数(设置为0,自动确认)

10 精度(设置为0,自动确认)
11 Coarse Rotation 是否将输入范围从第一象限(-Pi/4 to + Pi/4)扩大到整个圈
12 补偿比例 sin函数下不生效

设置IP

在这里插入图片描述
在这里插入图片描述
高位表示正弦函数,低位表示余弦函数

HDL Code

module correlation(input clk,input rst_n,input [15:0]	phase_in	,input [ 0:0]	phase_vld);wire [15:0] sinx;wire [15:0] cosx;wire [ 0:0] out_vld;cordic_0 sin_cos (.aclk					( clk),                                // input wire aclk.s_axis_phase_tvalid	( phase_vld			),  // input wire s_axis_phase_tvalid.s_axis_phase_tdata		( phase_in			),    // input wire [15 : 0] s_axis_phase_tdata.m_axis_dout_tvalid		( out_vld			),    // output wire m_axis_dout_tvalid.m_axis_dout_tdata		( {sinx, cosx}		)      // output wire [31 : 0] m_axis_dout_tdata);
endmodule

Simulation

Code

module tb_correlation;// correlation Parameters
parameter PERIOD  = 10;// correlation Inputs
reg   clk                                  = 0 ;
reg   rst_n                                = 0 ;
reg   [15:0]  phase_in                     = 0 ;
reg   [ 0:0]  phase_vld                    = 0 ;// correlation Outputsinitial
beginforever #(PERIOD/2)  clk=~clk;
endinitial
begin#(PERIOD*2) rst_n  =  1;
endcorrelation  u_correlation (.clk                     ( clk               ),.rst_n                   ( rst_n             ),.phase_in                ( phase_in   [15:0] ),.phase_vld               ( phase_vld  [ 0:0] )
);initial
begin#(PERIOD*3)		phase_vld 	= 1'b1;#(PERIOD*0)		phase_in 	= 16'b1110_0000_0000_0000		; // -1#PERIOD			phase_in	= 16'b1110_1000_0000_0000		; // -0.75#PERIOD			phase_in 	= 16'b1111_0000_0000_0000		; // -0.5#PERIOD			phase_in 	= 16'b1111_1000_0000_0000		; // -0.25#PERIOD			phase_in 	= 16'b0000_0000_0000_0000		; // 0#PERIOD			phase_in 	= 16'b0000_1000_0000_0000		; // 0.25#PERIOD			phase_in 	= 16'b0001_0000_0000_0000		; // 0.5#PERIOD			phase_in 	= 16'b0001_1000_0000_0000		; // 0.75#PERIOD			phase_in 	= 16'b0010_0000_0000_0000		; // 1#PERIOD			phase_vld 	= 1'b0		;#(PERIOD*30)$finish;
endendmodule

仿真

设置输入输出格式
在这里插入图片描述
输入格式,有符号,13位小数位
在这里插入图片描述
输出格式
在这里插入图片描述
仿真结果
在这里插入图片描述

reference

pg105


都看到这儿了,点个赞呗
||
\/

这篇关于Vivado使用Cordic IP计算e^ix(复e指数函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

详解如何使用Python提取视频文件中的音频

《详解如何使用Python提取视频文件中的音频》在多媒体处理中,有时我们需要从视频文件中提取音频,本文为大家整理了几种使用Python编程语言提取视频文件中的音频的方法,大家可以根据需要进行选择... 目录引言代码部分方法扩展引言在多媒体处理中,有时我们需要从视频文件中提取音频,以便进一步处理或分析。本文

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

Spring Cloud之注册中心Nacos的使用详解

《SpringCloud之注册中心Nacos的使用详解》本文介绍SpringCloudAlibaba中的Nacos组件,对比了Nacos与Eureka的区别,展示了如何在项目中引入SpringClo... 目录Naacos服务注册/服务发现引⼊Spring Cloud Alibaba依赖引入Naco编程s依

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP