IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> Vivado使用Cordic IP计算e^ix(复e指数函数) -> 正文阅读

[网络协议]Vivado使用Cordic IP计算e^ix(复e指数函数)

原理

根据欧拉公式
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 Outputs



initial
begin
    forever #(PERIOD/2)  clk=~clk;
end

initial
begin
    #(PERIOD*2) rst_n  =  1;
end

correlation  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;
end

endmodule

仿真

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

reference

pg105

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-04-27 11:39:57  更:2022-04-27 11:40:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 2:41:58-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码