当前位置: 首页 > news >正文

【算法】Cordic算法的原理及matlab/verilog应用

一、前言

单片机或者FPGA等计算能力弱的嵌入式设备进行加减运算还是容易实现,但是想要计算三角函数(sin、cos、tan),甚至双曲线、指数、对数这样复杂的函数,那就需要费些力了。通常这些函数的计算需要通者查找表或近似计算(如泰勒级数逼近)等技术来转换为硬件易于实现的方式。

CORDIC(Coordinate Rotation Digital Computer, 坐标旋转数字计算方法)算法就是一种化繁为简的算法,通过基本的加减和移位运算代替乘法运算,逐渐逼近目标值,得出函数的数值解。

二、Cordic算法理论推导

理论推导参考:CORDIC算法理论详解_cordic算法详解-CSDN博客,这篇博客的推导仔细而全面。

Cordic算法的基石在于一个规律:从tan45°开始,角度每减半,tan值也接近减半。这一规律直接将三角函数运算变成2的幂运算,而这在数字电路中可直接用移位运算来实现。

三、Cordic算法 matlab实现

3.1 已知相位(角度)求坐标(正弦余弦)

function [sin_theta,cos_theta] = cordic_sincos(theta,n)
% n:iterations
% theta: -180~180
tan_table = 2.^-(0 : n-1);
angle_rad_lut = atan(tan_table);
%angle_deg_lut = rad2deg( atan(tan_table) );k = 1;
for i = 0 : n-1k = k*(1/sqrt(1 + 2^(-2*i)));
endx = k;
y = 0;
theta_tar = theta*pi/180;  % to be rad
z=theta_tar;% preprocess
if (theta_tar > pi/2)  theta_tar = theta_tar - pi/2;
elseif (theta_tar < -pi/2)theta_tar = theta_tar + pi/2;
endfor i = 0 : n-1   if (z > 0)  d =1;elsed=-1;endx_temp = x;y_temp =y;z_temp = z;x= x_temp - d*y_temp*2^(-i);y = y_temp + d*x_temp*2^(-i);z = z_temp - d*angle_rad_lut(i+1);endif (theta_tar > pi/2)  sin_theta = -x;cos_theta = y;
elseif (theta_tar < -pi/2)sin_theta = x;cos_theta = -y;
elsesin_theta = y;cos_theta = x;
end
end

3.2 已知坐标求相位

待实现

四、cordic算法的verilog实现

待实现

http://www.lryc.cn/news/335878.html

相关文章:

  • QT:信号与槽
  • 以动态库链接库 .dll 探索结构体参数
  • vue快速入门(三)差值表达式
  • RabbitMQ的交换机与队列
  • Spring的 IOC和AOP编程思想
  • Qt中显示hex数据的控件
  • python web 开发 - 常用Web框架
  • 设计模式——适配器模式06
  • 【鸿蒙开发】组件状态管理@Prop,@Link,@Provide,@Consume,@Observed,@ObjectLink
  • Web 前端性能优化之八:前端性能检测实践
  • 安装VMware ESXi虚拟机系统
  • Vue3实践之全局请求URL配置和请求参数说明
  • 类和对象—初阶
  • 【Linux】shell 脚本基础使用
  • nfs部署--相关记录
  • java国产化云HIS基层医院系统源码 SaaS模式
  • docker 部署 Epusdt - 独角数卡 dujiaoka 的 usdt 支付插件
  • 数据结构排序之冒泡、快速、插入、选择、堆、归并等排序及时间,空间复杂度等(超详解,绝对能满足你的需求,并能学到很多有用知识)
  • 如何在windows环境和linux环境运行jar包
  • 2602B吉时利2602B数字源表
  • Linux——fork复制进程
  • 李廉洋:4.10黄金原油晚间走势最新分析及策略。
  • 【头歌-Python】字符串自学引导
  • 44-技术演进(下):软件架构和应用生命周期技术演进之路
  • 【C++】C++中的list
  • uniapp:Hbuilder没有检测到设备请插入设备或启动模拟器的问题解决
  • 基于RBF的时间序列预测模型matlab代码
  • vue vue3 手写 动态加载组件
  • HTML:表单
  • 即插即用篇 | YOLOv5/v7引入Haar小波下采样 | 一种简单而有效的语义分割下采样模块