使用xilinx vivado cordic IP的问题

使用xilinx vivado cordic IP的问题

在优数科技的ud PCIe-402板卡上调试arctan功能,发现存在的问题:

问题1:符号问题

         若输入IMAG为正,REAL的符号为负,则理论输出的符号为负。而实际ip-core输出的符号为正。原因是IP core输出只控制到±pai之间,固可自行进行符号调整。

问题2:精度问题

输出的arctan精度和用matlab计算的精度有偏差(可能几度~几十度),精度较差。

解决思路:

         首先怀疑输入数据溢出,故输入的数据位宽加1,更改为[16:0]:

        

         代码接口如下:

         仿真情况如下:

输入Y=-23170, X=23169

输出的理论值为:-6433

而实际输出的值为:-5021,误差为:1412/8192*180=31度

把精度调整为32bit,IP core设置如下:

仿真现象一样。

修改迭代次数:

仿真输出的结果也是-5021,没有变化。

把输出的数据位宽更改为18bit,IP core设置参数如下:

仿真结果如下:

输出值变为-20084,等效于-5021乘以4,即输出还是没有变化的。

当输入小信号时,精度正确:

把输入的输入Y=-23170, X=23169同步减少到:Y=-352, X=352

  理论值:-6433

  实际值:-6433,误差为0度

把输出的数据格式更改为:scaled radians,小信号(IMAG=-352, REAL=352)输入时:

大信号(IMAG=-23170, REAL=23169)输入时:

复位cordic IP的输出,重新生成IP,修改参数为:

迭代次数32,精度32:

大信号:

小信号:

再次修改参数为:

迭代次数18,精度32:

大信号:

小信号:

再次修改参数为:

迭代次数0,精度32:

大信号:

小信号:

从以上的测试来看,与迭代次数没有关系,主要是受精度影响。

最终参数设置如下:

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用Vivado Cordic IP的简单实例: 假设我们要计算正弦函数sin(x),其x是输入角度,输出结果是浮点数。我们可以使用Vivado Cordic IP计算sin(x)的值。 1. 在Vivado设计环境创建新的IP项目。 2. 在IP目录搜索Cordic IP核,并将其添加到设计。 3. 双击Cordic IP核,打开其属性选项卡。在这里,选择计算角度和输出数据类型为浮点数。 4. 将Cordic IP核FPGA的时钟信号和输入角度信号连接起来。 5. 在设计添加一个AXI GPIO核,用于输入角度值。 6. 在Xilinx SDK创建一个新的应用程序项目。 7. 编写C代码,从GPIO核读取角度值,并将其作为输入发送到Cordic IP核。然后,从Cordic IP核读取输出值,并将其转换为浮点数格式,最后计算sin(x)的值。 8. 在Vivado生成比特流文件,将其下载到FPGA设备进行测试和验证。 下面是C代码示例: ```c #include <stdio.h> #include <math.h> #include "xparameters.h" #include "xil_io.h" #define CORDIC_BASE_ADDR XPAR_CORDIC_IP_0_S00_AXI_BASEADDR #define GPIO_BASE_ADDR XPAR_AXI_GPIO_0_BASEADDR int main() { float x, y, z, sin_z; // 读取输入角度值 xil_printf("Enter the angle in degrees:\n"); scanf("%f", &x); z = x * M_PI / 180.0; // 将输入角度值发送到Cordic IP核 Xil_Out32(CORDIC_BASE_ADDR + 0x00, *(u32*)&z); // 从Cordic IP核读取输出值 y = *(float*)(CORDIC_BASE_ADDR + 0x04); // 计算sin(z)的值 sin_z = y; // 输出结果 xil_printf("sin(%f degrees) = %f\n", x, sin_z); return 0; } ``` 需要注意的是,此示例代码仅用于说明如何使用Vivado Cordic IP,实际应用可能需要更复杂的硬件设计和软件编程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值