CORDIC原理与FPGA实现(2)
CORDIC算法实现极坐标(polar)到直角坐标系(Cartesian)的变换。
1: function [horizonal,vertical]=polar2car(mag, pha);
2: x =mag;
3: y =0;
4: z=pha;
5: d=0;
6: i=0;
7: k = 0.6073; %K 增益
8: x = k*x;
9: while i<50
10: if z<0 d =-1;
11: else d = 1;
12: end
13: xNew=x-y*d*(2^(-i));
14: y=y+x*d*(2^(-i));
15: z=z-d*atan(1/2^(i));
16: i=i+1;
17:
18:
19: x=xNew;
20: end
21: horizonal = x;
22: vertical = y;
CORDIC算法实现直角坐标到极坐标系的变换。
1: function [mag, pha]= car2polar(x,y);
2:
3: %y =0;
4: %将直角坐标系中的点(x,y)旋转到x轴,旋转的角度即为其极坐标的相位,在x轴的长度等于极坐标的幅度
5: d=0; %可用于求相位,幅度
6: i=0;
7: z=0;
8: k = 0.6073; %K 增益
9:
10: while i<50
11: if y<0 d = 1;
12: else d = -1;
13: end
14: xNew=x-y*d*(2^(-i));
15: y=y+x*d*(2^(-i));
16: z=z-d*atan(1/2^(i));
17: i=i+1;
18:
19:
20: x=xNew;
21: end
22: x = x*k;
23: mag=x;
24: pha=z;
验证:
[a,b]= polar2car( 1,pi/3)
a =
0.5000
b =
0.8661
[a,b]= car2polar( 0.5000, 0.8661)
a =
1.0001
b =
1.0472
计算正切值atan只需将直角坐标变换为极坐标的程序中取出最后的角度值,即可得到反正切值。
1: function [ pha]= cordic_arcsin(c);
2:
3: %y =0;
4: %将点(1,0)旋转至其纵坐标=c,旋转的角度为角度 求反余弦也是同样道理
5: d=0;
6: i=0;
7: z=0;
8: x=1;
9: y=0;
10: k = 0.6073; %K 增益
11: xNew = x* k;
12: while i<100
13: if y<=c d = 1;
14: else d = -1;
15: end
16: x =xNew-y*d*(2^(-i));
17: y=y+xNew*d*(2^(-i));
18: z=z+d*atan(1/2^(i));
19: i=i+1;
20:
21:
22: xNew=x;
23: end
24:
25: %mag=x;
26: pha=z;
1: function [pha]= cordic_arccos(c);
2:
3: %y =0;
4: d=0;
5: i=0;
6: z=0;
7: x=1;
8: y=0;
9: k = 0.6073; %K 增益
10: xNew = x* k;
11: while i<100
12: if x>=c d = 1;
13: else d = -1;
14: end
15: x =xNew-y*d*(2^(-i));
16: y=y+xNew*d*(2^(-i));
17: z=z+d*atan(1/2^(i));
18: i=i+1;
19:
20:
21: xNew=x;
22: end
23:
24: %mag=x;
25: pha=z;
1: function [ pha]= cordic_arctan(x,y);
2:
3: %y =0;
4: %将点(x,y)旋转到x轴所需要的角度
5: d=0;
6: i=0;
7: z=0;
8: k = 0.6073; %K 增益
9: x = x*k;
10: while i<50
11: if y<0 d = 1;
12: else d = -1;
13: end
14: xNew=x-y*d*(2^(-i));
15: y=y+x*d*(2^(-i));
16: z=z-d*atan(1/2^(i));
17: i=i+1;
18:
19:
20: x=xNew;
21: end
22:
23: %mag=x;
24: pha=z;
1: function [sine,cosine] = cordic_sine(angle);
2: % Initialitation
3: %%angle=30 ;
4: x = 1;
5: y = 0;
6: z = angle;
7: d = 1;
8:
9: i = 0; % Iterative factor
10: k = 0.6073; %K Factor
11: xNew = k*x;
12: while i < 50
13: if z <=0 d =-1;
14: else d = 1;
15: end
16: x= xNew -d*y*2^(-i);
17: y=y+d*xNew*2^(-i);
18: z=z-d*atan(2^(-i));
19: i=i+1;
20: xNew=x;
21: end
22: cosine = x
23: sine = y
CORDIC原理与FPGA实现(2)的更多相关文章
- CORDIC原理与FPGA实现(1)
CORDIC算法的来历与用途大家网上随处可以见到,这里写 一下自己的理解. 将P(x,y)旋转角度a得到新的坐标P’(x’,y’).这里的坐标变换为: x’= x cos(a) – y sin(a) ...
- 【接口时序】8、DDR3驱动原理与FPGA实现(一、DDR的基本原理)
一. 软件平台与硬件平台 软件平台: 1.操作系统:Windows-8.1 2.开发套件:无 3.仿真工具:无 硬件平台: 1. FPGA型号:无 2. DDR3型号:无 二. 存储器的分类 存储器一 ...
- cordic算法的fpga实现
cordic算法参考:http://wenku.baidu.com/view/6c623aa8910ef12d2bf9e732.html 这是百度文库的一个文档,详细介绍了cordic算法的基本内容. ...
- 学习cordic算法所得(流水线结构、Verilog标准)
最近学习cordic算法,并利用FPGA实现,在整个学习过程中,对cordic算法原理.FPGA中流水线设计.Verilog标准有了更加深刻的理解. 首先,cordic算法的基本思想是通过一系列固定的 ...
- CORDIC算法(1):圆周旋转模式下计算三角函数和模值
CORDIC(Coordinate Rotation Digital Computer)坐标旋转数字计算机,是数学与计算机技术交叉产生的一种机器算法,用于解决计算机的数学计算问题.发展到现在,CORD ...
- FPGA入门1
FPGA入门知识介绍 近几年来,由于现场可编程门阵列(FPGA)的使用非常灵活,又可以无限次的编程,已受到越来越多的电子编程者的喜爱,很多朋友都想学习一些FPGA入门知识准备进行这个行业,现在关 ...
- 【接口时序】5、QSPI Flash的原理与QSPI时序的Verilog实现
一. 软件平台与硬件平台 软件平台: 1.操作系统:Windows-8.1 2.开发套件:ISE14.7 3.仿真工具:ModelSim-10.4-SE 4.Matlab版本:Matlab2014b/ ...
- 学习FPGA需要做哪些
有些人比较差,做了一些介绍,有误导成分.有些人水平太高,介绍的很好,但是很多人依旧听不懂,得到的肯定很少.学习FPGA,在不同层次的人明显有不同的答案. 熟悉硬件描述语言语法,不需要什么都会,但是要记 ...
- Xilinx 常用模块汇总(verilog)【01】
作者:桂. 时间:2018-05-07 19:11:23 链接:http://www.cnblogs.com/xingshansi/p/9004492.html 前言 该文私用,不定期更新,主要汇总 ...
随机推荐
- 2. npm 的使用
NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种: 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用户从NPM服务器下载并 ...
- ACdrea 1217---Cracking' RSA(高斯消元)
ACdrea 1217---高斯消元 Description The following problem is somehow related to the final stage of many ...
- Linux命令详解之–ls命令
今天开始为大家介绍下Linux中常用的命令,首先给大家介绍下Linux中使用频率最高的命令--ls命令. 更多Linux命令详情请看:Linux命令速查手册 linux ls命令用于显示指定工作目录下 ...
- PHP redis Api 中文文档
phpredis是php的一个扩展,效率是相当高有链表排序功能,对创建内存级的模块业务关系 很有用;以下是redis官方提供的命令使用技巧: 下载地址如下: https://github.com/ow ...
- SQL数据库基础(四)
聚合函数:sum,avg,max,min,count 使用方法示例: group by 分组的使用方法 分组的练习: 数学函数:ABS.ceiling.floor.power.round.sqrt. ...
- 每日微软面试题——day 6(打印所有对称子串)
每日微软面试题——day 6(打印所有对称子串) 分类: 2.数据结构与算法2011-08-14 14:27 9595人阅读 评论(15) 收藏 举报 面试微软string测试systemdistan ...
- 【JavaEE】SSH+Spring Security基础上配置AOP+log4j
Spring Oauth2大多数情况下还是用不到的,主要使用的还是Spring+SpringMVC+Hibernate,有时候加上SpringSecurity,因此,本文及以后的文章的example中 ...
- spring task定时器笔记
定时器有两种方式 1.延迟启动 <bean id="timerTaskRunnerChain" class="bingo.uam.task.TimerTaskRun ...
- 数组拷贝 copyOf()
Arrarys类的copyof方法与copyOfRange方法可以实现对数组的复制,前者是复制数组到指定的长度,后者将指定的长度复制到一个新数组中. 1.copyOf()方法 该方法提供了很多种重载形 ...
- xCode删除storyboard,新建window并启动
application:didFinishLaunchingWithOptions该函数是应用程序启动之后首次加载页面的函数,删除storyboard之后,需要在这里new出新的window,初始化, ...