DSP 数据的定标

合集下载

DSP定标问题解决

DSP定标问题解决

好,我先抛点玉吧DSP芯片的定点运算3.1 数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别说明,本书均以16位字长为例。

DSP芯片的数以2的补码形式表示。

每个16位数用一个符号位来表示数的正负,0表示数值为正,1则表示数值为负。

其余15位表示数值的大小。

因此二进制数0010000000000011b=8195二进制数1111111111111100b=-4对DSP芯片而言,参与数值运算的数就是16位的整型数。

但在许多情况下,数学_运算过程中的数不一定都是整数。

那么,DSP芯片是如何处理小数的呢?应该说,DSP芯片本身无能为力。

那么是不是说DSP芯片就不能处理各种小数呢?当然不是。

这其中的关键就是由程序员来确定一个数的小数点处于16位中的哪一位。

这就是数的定标。

通过设定小数点在16位数中的不同位置,就可以表示不同大小和不同精度的小数了。

数的定标有Q表示法和S表示法两种。

表3.1列出了一个16位数的16种Q表示、S表示及它们所能表示的十进制数值范围。

从表3.1可以看出,同样一个16位数,若小数点设定的位置不同,它所表示的数也就不同。

例如:16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示但对于DSP芯片来说,处理方法是完全相同的。

从表3.1还可以看出,不同的Q所表示的数不仅范围不同,而且精度也不相同。

Q越大,数值范围越小,但精度越高;相反,Q越小,数值范围越大,但精度就越低。

例如,Q0的数值范围是-32768到+32767,其精度为1,而Q15的数值范围为-1到0.9999695,精度为1/32768 = 0.00003051。

因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表示比较大的数值范围,必须以牺牲精度为代价;而想提高精度,则数的表示范围就相应地减小。

基于定点DSP的恒定V_F运算参数定标分析

基于定点DSP的恒定V_F运算参数定标分析

微 处 理 机M I CROPROCE SSORS基于定点DSP的恒定V/F运算参数定标分析*张全川,李 文(大连交通大学,大连116028)摘 要:分析了定点DSP的定标问题,给出了常用的QX表示方法及其处理技巧。

并以异步电机的恒定V/F速度闭环控制系统为例,对其运算参数进行恰当的定标与分析。

实验结果表明用Q 格式编写程序代码更加简洁、方便、实用。

关键词:定点DSP;定标;异步电机;恒定V/F控制中图分类号:TP235 文献标识码:A 文章编号:1002-2279(2009)02-0095-04Scaling Anal yses of Constant V/F Operation Para m eter B asedon Fixed-poi nt DSPZHANG Quan-chuan,LIW en(D alian J i aotong U ni ver sity,D ali an116028,Ch i na)Abstract:The paper analyzes the scali n g prob le m o f fi x ed-po int DSP and prov i d es expression m ethodand d isposal skill of Q fo r m a.t An exa m ple of contro l syste m based on constant V/F and speed closed loop of asynchronous mo tor w as presen ted to ana l y ze the sca li n g of Operation Para m eter. Experi m ent results de monstrate that using Q for m a t to co m pile code is lacon ic,conven ient and app lied.K ey w ords:Fi x ed-po i n t DSP;Scaling;Asynchronous m oto r;Constant V/F contro l1 引 言数字信号处理器(DSP)以其丰富的硬件资源、高速数据处理能力和强大的指令系统等优点迅速得到人们的关注与应用。

DSP芯片的定点运算

DSP芯片的定点运算
x float xq 2Q
浮点数 x=0.5,定标 Q=15, 则定点数=0.5*32768=16384
SuQian College
Q表示、S表示及数值范围
QHale Waihona Puke 示 Q15 Q14. . . . . .
Q1 Q0
S表示 S0.15 S1.14
. . . . . .
S14.1 S15.0
十进制数表示范围 -1≤X≤0.9999695 -2≤X≤1.9999390
. . . . . .
-16384≤X≤16383.5 -32768≤X≤32767
1 定点的基本概念
SuQian College
1、数的定标
在定点DSP芯片中,采用定点数进行数值运算, 其操作数一般采用整型数来表示
DSP芯片的数以2的补码形式表示 数的定标:Q表示法和S表示法 对定点数而言,数值范围与精度是一对矛盾, 一个变量要想能够表示比较大的数值范围,必须 以牺牲精度为代价。
SuQian College
Q表示法16进制数2000H
Q0表示为8192
SuQian College
0010000000000000

号 位 Q15表示为0.25
小数点的位置
0010000000000000
小数点的位置
浮点数与定点数的转换关系
浮点数转换为定点数
xq int x 2Q
定点数转换为浮点数

DSP定标方法

DSP定标方法

DSP芯片的定点运算3.1 数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别说明,本书均以16位字长为例。

DSP芯片的数以2的补码形式表示。

每个16位数用一个符号位来表示数的正负,0表示数值为正,1则表示数值为负。

其余15位表示数值的大小。

因此二进制数0010000000000011b=8195二进制数1111111111111100b=-4对DSP芯片而言,参与数值运算的数就是16位的整型数。

但在许多情况下,数学运算过程中的数不一定都是整数。

那么,DSP芯片是如何处理小数的呢?应该说,DSP芯片本身无能为力。

那么是不是说DSP芯片就不能处理各种小数呢?当然不是。

这其中的关键就是由程序员来确定一个数的小数点处于16位中的哪一位。

这就是数的定标。

通过设定小数点在16位数中的不同位置,就可以表示不同大小和不同精度的小数了。

数的定标有Q表示法和S表示法两种。

表3.1列出了一个16位数的16种Q表示、S表示及它们所能表示的十进制数值范围。

从表3.1可以看出,同样一个16位数,若小数点设定的位置不同,它所表示的数也就不同。

例如:16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示但对于DSP芯片来说,处理方法是完全相同的。

从表3.1还可以看出,不同的Q所表示的数不仅范围不同,而且精度也不相同。

Q越大,数值范围越小,但精度越高;相反,Q越小,数值范围越大,但精度就越低。

例如,Q0的数值范围是-32768到+32767,其精度为1,而Q15的数值范围为-1到0.9999695,精度为1/32768 = 0.00003051。

因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表示比较大的数值范围,必须以牺牲精度为代价;而想提高精度,则数的表示范围就相应地减小。

定点数的概念和表示方法

定点数的概念和表示方法

1.基本概念(1)计算机中定点数的三种表示方法:原码、补码和反码(2)在DSP中一般使用补码的形式来表示操作数(3)整型数的表示范围由DSP芯片的字长决定,比如16位或24位(4)注意,符号位的bit个数,不同的DSP芯片有不同的实现2.DSP如何处理小数以16位的字长DSP芯片为例子。

(1)定标由程序员规定,小数点位于16位中的哪一位,通过设定小数点的不同位置,就可以表示不同大小和不同精度的小数。

参与运算的是16位的整型数,并不存在真正意义上的小数点。

(2)定标的表示方法Q表示法:Q后面的数表示该数的小数点右边有几位S表示法:表示小数点前后两部分各占了几位数Q/S表示法能表示十进制数值的精度和范围:同一个16bit数,Q值不同,则表示的数也不同。

在此处键入公式。

例:2000HQ0:意思是小数点部分没有,那就是2000H=8192Q15:小数点部分占了15位,总共才16位,最高位是符号位,所以意思就是整数部分占了0位,即不存在整数部分【数的格式就是0.xxxx】,值就是2000H=0.125所以:同样一个16位的数,Q值不同,所能表示的数也不同,所能表示的数的范围和精度也不同,Q值越大,所能表述的数的范围就越小[对整数部分而言],但是精度越高【对小数部分而言】,反之,Q越小,能表示的数值越大,但是精度越低。

故对于DSP处理定点数来说,数值的表示范围和精度是一堆矛盾体。

3.小数和定点数和转换规则在实际处理中,大都处理浮点数,但是浮点数太消耗时间。

因此在DSP处理中,首先进行数值的转换,DSP芯片计算整型数会快很多。

小数F转定点整数A:A=Fx2Q定点整数A转小数F:F=Ax2−Q例:F=0.6,定标Q=15,对应的定点整数就是:0.6 x 215=0.6 x 32768=19660.8最终要得到一个整数,所以这里还有另一个规则,就是“向下取整”,那最终的结果就是19660。

A=19660,定标Q=15,对应的小数就是:19660 x 2−15=0.5997,可以发现转回去的值和0.6是有差异的。

DSP(知识点+思考题)

DSP(知识点+思考题)

DSP复习要点第一章绪论1、数的定标:Qn表示。

例如:16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示2、‟C54x小数的表示方法:采用2的补码小数;.word 32768 *707/10003、定点算术运算:乘法:解决冗余符号位的办法是在程序中设定状态寄存器STl中的FRCT位为1,让相乘的结果自动左移1位。

第二章CPU结构和存储器设置一、思考题:1、C54x DSP的总线结构有哪些特点?答:TMS320C54x的结构是围绕8组16bit总线建立的。

(1)、一组程序总线(PB):传送从程序存储器的指令代码和立即数。

(2)、三组数据总线(CB,DB和EB):连接各种元器件,(3)、四组地址总线(PAB,CAB,DAB和EAB)传送执行指令所需要的地址。

2、C54x DSP的CPU包括哪些单元?答:'C54X 芯片的CPU包括:(1)、40bit的算术逻辑单元(2)、累加器A和B(3)、桶形移位寄存器(4)、乘法器/加法器单元(5)、比较选择和存储单元(6)、指数编码器(7)、CPU状态和控制寄存器(8)、寻址单元。

1)、累加器A和B分为三部分:保护位、高位字、地位字。

保护位保存多余高位,防止溢出。

2)、桶形移位寄存器:将输入数据进行0~31bits的左移(正值)和0~15bits的右移(负值)3)、乘法器/加法器单元:能够在一个周期内完成一次17*17bit的乘法和一次40位的加法4)、比较选择和存储单元:用维比特算法设计的进行加法/比较/选择运算。

5)、CPU状态和控制寄存器:状态寄存器ST0和ST1,由置位指令SSBX和复位指令RSBX控制、处理器模式状态寄存器PMST2-3、简述’C54x DSP的ST1,ST0,PMST的主要功能。

答:’C54x DSP的ST1,ST0,PMST的主要功能是用于设置和查看CPU的工作状态。

•ST0主要反映处理器的寻址要求和计算机的运行状态。

3.DSP的数值运算基础介绍

3.DSP的数值运算基础介绍
9 同样的一个16位数,若Q值不同,则所表示的数也不同。 【例】不同Q值时的16进制数2000H的值。 若用Q0表示,则16进制数2000H = 8192 若用Q15表示,则16进制数2000H = 0.25 9 不同Q值所能表示的数的精度和范围都不同:①Q越大,表示的 数值范围越小,但精度越高;②相反,Q越小,表示的数值范围越 大,但精度越低。 9 不同Q值所对应的正最大值、负最大值和量化步长(即精度): • 正最大值: 2(15−Q) − 2−Q = (215 −1)× 2−Q • 负最大值: −2(15−Q) = −215 × 2−Q • 精度:
课程名称:DSP芯片及应用
Agenda: 3.1 引言 3.2 定点的基本概念 3.3 定点运算实现的基本原理 3.4 DSP定点算术运算实现的基本原理 3.5 非线性运算定点实现方法 3.6 浮点数的表示格式 3.7 基本的浮点运算 3.8 非线性浮点运算的快速实现 3.9 小结 3.10 习题与思考题
31引言32定点的基本概念33定点运算实现的基本原理34dsp定点算术运算实现的基本原理35非线性运算定点实现方法36浮点数的表示格式37基本的浮点运算38非线性浮点运算的快速实现39小结310习题与思考题muchunyang126com3934dsp定点算术运算实现的基本原理341定点乘法两个定点数相乘二进制乘法可分解为一系列的移位和加法
【例】浮点数x=0.6,定标Q=15,求对应的定点数xq?
【例】定点数19660,定标Q=15,求对应的浮点数x?
xq = (int ) x × 2Q = ⎢⎢⎣0.6× 215 ⎥⎥⎦ = ⎢⎣ 0.6×32768⎥⎦ = 19660 注: ⎢ ⎣ ⎥⎦ 表示下取整。
x = ( float ) xq × 2−Q = 19660× 2−15 = 19660 / 32768 = 0.599975585

dsp定点运算与定标

dsp定点运算与定标

DSP芯片的定点运算3.1 数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别说明,本书均以16位字长为例。

DSP芯片的数以2的补码形式表示。

每个16位数用一个符号位来表示数的正负,0表示数值为正,1则表示数值为负。

其余15位表示数值的大小。

因此二进制数0010000000000011b=8195二进制数1111111111111100b=-4对DSP芯片而言,参与数值运算的数就是16位的整型数。

但在许多情况下,数学运算过程中的数不一定都是整数。

那么,DSP芯片是如何处理小数的呢?应该说,DSP芯片本身无能为力。

那么是不是说DSP芯片就不能处理各种小数呢?当然不是。

这其中的关键就是由程序员来确定一个数的小数点处于16位中的哪一位。

这就是数的定标。

通过设定小数点在16位数中的不同位置,就可以表示不同大小和不同精度的小数了。

数的定标有Q表示法和S表示法两种。

表3.1列出了一个16位数的16种Q表示、S表示及它们所能表示的十进制数值范围。

从表3.1可以看出,同样一个16位数,若小数点设定的位置不同,它所表示的数也就不同。

例如:16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示但对于DSP芯片来说,处理方法是完全相同的。

从表3.1还可以看出,不同的Q所表示的数不仅范围不同,而且精度也不相同。

Q越大,数值范围越小,但精度越高;相反,Q越小,数值范围越大,但精度就越低。

例如,Q0的数值范围是-32768到+32767,其精度为1,而Q15的数值范围为-1到0.9999695,精度为1/32768 = 0.00003051。

因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表示比较大的数值范围,必须以牺牲精度为代价;而想提高精度,则数的表示范围就相应地减小。

定点DSP实现浮点运算时的定标问题

定点DSP实现浮点运算时的定标问题

程序变量的Q值确定--定点DSP实现浮点运算时的定标问题2008-08-27 18:45在前面几节介绍的例子中,由于x,y,z的值都是已知的,因此从浮点变为定点时Q值很好确定。

在实际的DSP应用中,程序中参与运算的都是变量,那么如何确定浮点程序中变量的Q值呢?从前面的分析可以知道,确定变量的Q值实际上就是确定变量的动态范围,动态范围确定了,则Q值也就确定了。

设变量的绝对值的最大值为|max|,注意|max|必须小于或等于32767。

取一个整数n,使满足2n-1<|max|<2n则有2-Q=2-15*2n=2-(15-n)Q=15-n例如,某变量的值在-1至+1之间,即|max|<1,因此n=0,Q=15-n=15。

既然确定了变量的|max|就可以确定其Q值,那么变量的|max|又是如何确定的呢?一般来说,确定变量的|max|有两种方法。

一种是理论分析法,另一种是统计分析法。

1. 理论分析法有些变量的动态范围通过理论分析是可以确定的。

例如:(1)三角函数。

y=sin(x)或y=cos(x),由三角函数知识可知,|y|<=1。

(2)汉明窗。

y(n)=0.54一0.46cos[nπn/(N-1)],0<=n<=N-1。

因为-1<=cos[2πn/(N-1)]<=1,所以0.08<=y(n)<=1.0。

(3)FIR卷积。

y(n)=∑h(k)x(n-k),设∑|h(k)|=1.0,且x(n)是模拟信号12位量化值,即有|x(n)|<=2^11,则|y(n)|<=2^11。

(4)理论已经证明,在自相关线性预测编码(LPC)的程序设计中,反射系数ki满足下列不等式:|ki|<1.0,i=1,2,...,p,p为LPC的阶数。

2. 统计分析法对于理论上无法确定范围的变量,一般采用统计分析的方法来确定其动态范围。

所谓统计分析,就是用足够多的输入信号样值来确定程序中变量的动态范围,这里输入信号一方面要有一定的数量,另一方面必须尽可能地涉及各种情况。

dsp数的定标名词解释

dsp数的定标名词解释

dsp数的定标名词解释DSP是数字信号处理(Digital Signal Processing)的缩写,是指利用数字技术对信号进行处理的一种方式。

数字信号处理是现代通信技术、音频处理、图像处理、雷达信号处理等众多领域中的关键技术之一,被广泛应用于各个领域。

DSP数的定标是指对数字信号进行精度补偿、峰值标定和校准,以确保测量结果的准确性和可靠性。

定标是指在已知标准参考信号下对DSP系统进行校正,使得系统能够正确地量化输入信号并进行相应的数字处理。

在DSP系统中,数的定标是非常重要且必要的一步。

它旨在确保DSP系统在各种环境和条件下的性能稳定和可靠性。

数的定标涉及到几个关键的步骤,下面将对这些步骤进行详细解释。

首先,数的定标需要确定DSP系统的量化精度。

量化精度是指系统可以采样和量化的最小输入变化。

通过在已知输入信号下对系统进行测试,可以确定系统可以准确测量的最小变化值。

这个步骤通常涉及选择适当的参考信号源,并在不同的输入水平下进行测试。

根据测试结果,可以确定系统的量化精度。

接下来,数的定标还需要考虑系统的峰值标定。

峰值标定是指确定DSP系统可以正确定量的最大输入信号。

这对于在系统使用过程中能够正确处理高幅度信号至关重要。

峰值标定可以通过将已知幅度的信号输入到系统中,并观察系统是否能够准确测量这些信号的幅度来实现。

通过对系统进行多个不同幅度的测试,可以确定系统的峰值标定值。

此外,校准也是数的定标的重要一环。

校准是指对DSP系统进行调整和校正,以确保其输出的准确性和稳定性。

校准通常涉及对系统的各个部分进行测试,并根据测试结果进行相应的调整。

校准可以包括对时钟源的校准、模数转换器的校准以及滤波器的校准等。

数的定标还需要考虑信号的线性性。

线性性是指系统对输入信号的响应与输入信号幅度成正比。

在进行数的定标时,需要检查系统的线性性,并在必要时进行校正。

这可以通过对多个不同幅度的输入信号进行测试来实现。

最后,数的定标也需要考虑对系统进行环境测试。

定点 DSP 处理浮点数

定点 DSP 处理浮点数

定点DSP处理浮点数BG6RDFTMS320C5509A是16位定点数处理器,其累加器是32位/40位的。

在定点处理器中处理浮点数需要对定点数进行定标。

下面所说的定点数都是指有符号数。

通常采用的定标有Q15和Q31,分别表示小数点后有二进制15位和二进制16位。

因此16位Q15最大能表示的数是1 2 ,32位Q31最大能表示的数是1 2 。

定标不同的数可以直接相乘,例如Q13*Q15=Q28。

两个定标不同的数不能直接相加,比如Q13+Q15,通常要将Q15右移两位,转换为Q13后再相加,当然这样损失了两位的精度。

DSP进行的乘累加操作常常Q15的数,这样结果为Q30,存储在累加器中。

为了将累加器的结果转换为更为常用的Q31定标,55x系列DSP在状态寄存器ST1_55中设置了FRCT 控制位,FRCT=1时,乘积自动左移一位,这样乘积变成了Q31。

对于累加器中Q31定标的数,直接取累加器中高16位,就能获得结果的Q15定标数。

很多时候Q15不能解决问题,比如IIR滤波器num, den系数中通常有大于等于1的系数,超过了Q15的范围,只能用Q14,Q13等定标。

这时乘累加操作就需要进行修正了,比如IIR滤波器中系数用Qx定标,输入数据和输出数据用Qy定标,Q Q Q ,为获得Qy的输出数据必须将累加器中的乘积右移x位,另外在乘累加操作开始前必须将输入数据在累加器中左移y位,进行对齐后才能进行乘累加。

当然,这种修正都是在没有考虑FRCT 的情况下。

在C5500 DSPLIB中iircas51函数中,FRCT设置为1,输入输出数据采用Q15定标,如果系数也是Q15定标,则程序运行无误,如果系数采用Q14及以下定标则会产生严重的问题。

以下是其代码片段:MOV *AR0+ << #16, AC1 ; HI(AC1) = x(n)||RPTBLOCAL loop2‐1 ;inner loop: process a bi‐quadMPYM *AR1+, AC1, AC0 ; AC0 = b0*x(n)MACM *AR1+, *(AR3+T0), AC0 ; AC0 += b1*x(n‐1)MACM *AR1+, *AR3, AC0 ; AC0 += b2*x(n‐2)MOV HI(AC1), *AR3 ; x(n) replaces x(n‐2)||AADD T1, AR3 ; point to next x(n‐1)MASM *AR1+, *(AR4+T0), AC0 ; AC0 ‐= a0*y(n‐1)MASM *AR1+, *AR4, AC0 ; AC0 ‐= a1*y(n‐2)MOV rnd(HI(AC0)), *AR4 ; y(n) replaces y(n‐2)||AADD T1, AR4 ;point to next y(n‐1)MOV AC0, AC1 ;input to next biquad从代码片段可以看出,累加器AC0为Q31定标,输出数据是累加器高16位。

DSP中数的定标

DSP中数的定标

1 数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别说明,本书均以16位字长为例。

DSP芯片的数以2的补码形式表示。

每个16位数用一个符号位来表示数的正负,0表示数值为正,l则表示数值为负。

其余15位表示数值的大小。

因此,二进制数0010000000000011b=8195二进制数1111111111111100b= -4对DSP芯片而言,参与数值运算的数就是16位的整型数。

但在许多情况下,数学运算过程中的数不一定都是整数。

那么,DSP芯片是如何处理小数的呢?应该说,DSP芯片本身无能为力。

那么是不是说DSP芯片就不能处理各种小数呢?当然不是。

这其中的关键就是由程序员来确定一个数的小数点处于16位中的哪一位。

这就是数的定标。

通过设定小数点在16位数中的不同位置,就可以表示不同大小和不同精度的小数了。

数的定标有Q表示法和S表示法两种。

表1.1列出了一个16位数的16种Q表示、S表示及它们所能表示的十进制数值范围。

从表1.1可以看出,同样一个16位数,若小数点设定的位置不同,它所表示的数也就不同。

例如,16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示 0.111111*********但对于DSP芯片来说,处理方法是完全相同的。

从表1.1还可以看出,不同的Q所表示的数不仅范围不同,而且精度也不相同。

Q越大,数值范围越小,但精度越高;相反,Q越小,数值范围越大,但精度就越低。

例如,Q0 的数值范围是-32768到+32767,其精度为1,而Q15的数值范围为-1到0.9999695,精度为1/32768=0.00003051。

因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表示比较大的数值范围,必须以牺牲精度为代价;而想精度提高,则数的表示范围就相应地减小。

DSP重点总结

DSP重点总结

一、电源与时钟设计二、线性、循环寻址线性寻址(AMR为0000 0000h):LDB/LDH/LDW分别对应1/2/4偏移量,一周期后地址数组加上n*偏移量,多周期后数据数组更新值。

循环寻址:先看AMR后四位,由A?或B?模式确定是循环寻址,地址偏移量同上计算,换算成十六进制。

然后算块尺寸(AMR前四位换成十进制,记为n,2的n+1次方即为块尺寸,换算成十六进制)。

将偏移量对块尺寸取余,为最终偏移量。

三、定点定标什么是定点数?定点数即小数点位置固定的数。

表示形式是:符号位整数部分.小数部分。

什么是定标?CPU在执行指令时,并不知道处理的数据是整数还是小数,也不能指出小数点的位置。

在编程时必须由程序员指出一个数的小数点处于哪一位,这就是定标。

为什么要定标?定点DSP芯片在运算中操作的数可能是整数、小数或混合小数,而CPU在执行数学运算的指令时并不知道当前所处理的数据是整数还是小数,更不知道小数点的位置,因此要由程序员确定一个数的小数点处于8位/ 16位/24位/32位中的哪一位。

如何定标?对于16位DSP来说,可以把小数点固定在D0~D15的任一位之后,若固定在最高位D15之后,则该数值是有符号小数;也可把小数点固定在最低位D0之后,则该数值是有符号整数;若把小数点放在位D1~D14的任一位之后,则该数值就是有符号混合小数,它可以含有i个整数位和15–i个小数位。

对于32位DSP来说,可把小数点固定在D0~D31中的任一位之后,这就是数的定标。

四、M EMORY伪指令用法MEMORY{RAM1: o=00000000h l=000xxxxxh(根据题目要求确定)RAM2: o=000xxxxxh l=000??????hSDPAM: o=80000000h l=01000000h}五、B ootloader大部分程序是大于1K字节的,程序会烧写在Flash上,上电时需要把Flash上的程序和已初始化数据搬移到RAM中以提供程序的执行速度。

定点DSPs的定标及其运算方法

定点DSPs的定标及其运算方法

数字信号处理器是一种实DSPs(Digital Signal Processors)时、快速的实现各种数字信号处理运算的微处理器。

由于它具有丰富的硬件资源、改进的并行结构、高速数据处理能力和强大的指令系统而在通信、航空、航天、雷达、工业控制、网络及家用电器等各个领域得到广泛应用。

分为DSPs 定点和浮点两种,系列是公司推出的位TMS320C2000TI 16定点。

本文以该种芯片为例,讨论定点的定标和DSPs DSPs 算术运算中的编程处理手段。

所讨论的这些问题在系DSPs 统设计中有实际的参考和应用价值。

一般来说,定点芯片价格低,运算中占用内存单元少,运算速度较快,但数的表示范围太小,且必须经过定标才能进行运算。

采用浮点数可使数值的表示范围大大提高,保证了运算精度,且编程时不必考虑小数点的位置。

但浮点芯片的价格要比定点芯片高的多。

本文讨论的定点芯片系列采用补码形式TMS320C2000来表示无符号或有符号整数、小数及混合小数。

它的表示形式是:符号位整数部分小数部分。

那么,在运算过程中,..定点怎样表示混合小数,又如何去处理这样的小数运DSPs 算呢?这就是下面所要讨论的问题。

定点数的定标1 计算机在运算中操作的数可能是整数,也可能是小数或混合小数。

然而,在执行算术运算指令时,并不知道当CPU 前所处理的数据是整数还是小数,更不能指出小数点的位置在哪里。

因此,在编程时必须由程序员指定一个数的小数点处于哪一位,这就是定标的概念。

通过定标可以在位位16(/8位位数的不同位置上确定小数点,从而表示出一个范/24/32)围大小不同且精度也不同的小数。

通常,定标方法有两种:表示法和表示法。

以位Q S 16数为例,表示法用Q Q 0、Q 1、…Q i 、…、Q 15分别表示小数点在D 0位之后、D 1位之后、…D i 位之后、…D 15位之后注(意: D 15位是符号位。

显然,)Q 0表示的是一个有符号的整数,而Q 15表示的是一个有符号的小数,其他各种情况表示了一个有符号的混合小数,它可以含有个整数位和个小i 15-i 数位。

一DSP定点算数运算 1 数的定标 在定点DSP芯片中,采用...

一DSP定点算数运算 1 数的定标 在定点DSP芯片中,采用...

一DSP定点算数运算1 数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别说明,本书均以16位字长为例。

DSP芯片的数以2的补码形式表示。

每个16位数用一个符号位来表示数的正负,0表示数值为正,l则表示数值为负。

其余15位表示数值的大小。

因此,二进制数0010000000000011b=8195 二进制数1111111111111100b= -4 对DSP芯片而言,参与数值运算的数就是16位的整型数。

但在许多情况下,数学运算过程中的数不一定都是整数。

那么,DSP芯片是如何处理小数的呢?应该说,DSP芯片本身无能为力。

那么是不是说DSP芯片就不能处理各种小数呢?当然不是。

这其中的关键就是由程序员来确定一个数的小数点处于16位中的哪一位。

这就是数的定标。

通过设定小数点在16位数中的不同位置,就可以表示不同大小和不同精度的小数了。

数的定标有Q表示法和S表示法两种。

表1.1列出了一个16位数的16种Q表示、S表示及它们所能表示的十进制数值范围。

从表1.1可以看出,同样一个16位数,若小数点设定的位置不同,它所表示的数也就不同。

例如,16进制数2000H=8192,用Q0表示16进制数2000H=0.25,用Q15表示但对于DSP芯片来说,处理方法是完全相同的。

从表1.1还可以看出,不同的Q所表示的数不仅范围不同,而且精度也不相同。

Q越大,数值范围越小,但精度越高;相反,Q越小,数值范围越大,但精度就越低。

例如,Q0 的数值范围是一32768到+32767,其精度为1,而Q15的数值范围为-1到0.9999695,精度为1/32768=0.00003051。

因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表示比较大的数值范围,必须以牺牲精度为代价;而想精度提高,则数的表示范围就相应地减小。

DSP定点和浮点数格式

DSP定点和浮点数格式
DSP 运算基础
• 1、 DSP的数据表示
• 2、定点数的格式与运算 • 3、浮点数的格式与运算
1、 DSP的数据表示
定点
格式
浮点 16位 24位 32位
字长
格式和字长决定了数据的精度和动态范围 格式和字长也在一定程度上决定了DSP处理器 的成本、功耗和编程难度
2、 定点数的格式与运算
• 1. 定点数的格式
例: (Q7) 01010011b 7 83/2 =0.6484375 浮点数
Qn格式的定点数Xn Qm格式的定点数Xm
n m (int) X n 2mn X m (int) X / 2 2 n

例:(Q7) 01010011b Q4定点数 7 83/2 =0.6484375 4 int(0.6484375 ×2 ) =int(10.375) =10=00001010b 4 10/2 =0.625≠ 0.6484375
3)定点数的除法运算
大多数DSP处理器不提供单周期除法指令 除法是乘法的逆运算,包括一系列移位和条件减法运 算,需要用除法子程序实现
例:8位字长的正整数相除 被除数为00001010b(10) 除数为00000011b(3)
① ② 00001010b - 00000110b 商数:00000001 余数:00000100b ③ 00001000b
饱和模式:110000000b(-128)
饱和模式:001111111b(127)
溢出是由于字长有限,运算结果超出数值的表示范围引 起的
饱和模式
定点数减法运算的原理与加法运算相同
2)定点数的乘法运算
DSP处理器都有硬件乘法器和乘法指令,可实现单周期乘 法运算 二进制乘法运算包含一系列的移位和加法运算 定点数乘法运算不要求相乘数有相同的Qn格式 两个相乘数分别为Qn和Qm格式,字长为N,结果为 Q(n+m)格式,字长为2N 根据n和m的不同取值,定点数乘法运算可以分成三种情况

dsp中的定标是什么意思?

dsp中的定标是什么意思?

dsp中的定标是什么意思?
分类:教育/科学 >> 科学技术 >> 工程技术科学
问题描述:
我在看关于DSP的书时常常会看到这个词,但不知道是什么意思。

例如:输出在送到DAC之前右移15位,这样实现输出的定标。

解析:
DAC是数摸转换器的缩写,输入端为计算得到的二进制数据,输出模拟信号。

那么,根据此理解,DSP程序运算过程中,并不考虑实际输出信号的大小,为计算方便,可能只是按照整数处理,在送到DAC以获得模拟信号输出的时候,需要符合实际的物理要求...所以才有移位操作...
----------------------------------------------
噢,找到一个帖子:61ic/Article/dspzh/200409/469
数的定标在定点DSP芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。

一个整型数的最大表示范围取决于DSP芯片所给定的字长,一般为16位或24位。

显然,字长越长,所能表示的数的范围越大,精度也越高。

如无特别...。

定点DSPs的定标及其运算方法

定点DSPs的定标及其运算方法

定点DSPs的定标及其运算方法
张卫宁;赵子婴
【期刊名称】《计算机工程》
【年(卷),期】2002(028)003
【摘要】分析了定点DSPs的定标问题,讨论了定点运算中的Qx值选择和解决数值超范围的方法,提出了定点DSPs加法的通用处理方法,并就定点运算程序设计中的一些具体问题进行了讨论.
【总页数】3页(P223-225)
【作者】张卫宁;赵子婴
【作者单位】山东大学信息科学与工程学院,济南,250061;山东大学信息科学与工程学院,济南,250061
【正文语种】中文
【中图分类】TP301.6
【相关文献】
1.G.729A+B语音编解码在新一代定点DSPs上的实现 [J], 谢廷贤;李娜
2.用定点DSP处理器实现浮点DSP仿真 [J],
DavidKatz;RickGentile;TomLukasiak
3.DSP运算方法研究 [J], 武乾文;冯妍
4.基于定点DSP的恒定V/F运算参数定标分析 [J], 张全川;李文
5.矢量控制中定点DSP软件定标分析 [J], 刘小虎;谢顺依
因版权原因,仅展示原文概要,查看原文内容请购买。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
DSP 数据的定标
一 DSP定点算数运算 1 数的定标 在定点 DSP 芯片中,采用定点数进行数值运算,其操作数一般采用整型数来表示。一个整型数 的最大表示范围取决于 DSP 芯片所给定的字长,一般为 16 位或 24 位。显然,字长越长,所 能表示的数的范围越大,精度也越高。如无特别说明,本书均以 16 位字长为例。 DSP 芯片的数以 2 的补码形式表示。每个 16 位数用一个符号位来表示数的正负,0 表示数值 为正,l 则表示数值为负。其余 15 位表示数值的大小。因此, 二进制数 0010000000000011b=8195 二进制数 1111111111111100b= -4 对 DSP 芯片而言,参与数值运算的数就是 16 位的整型数。但在许多情况下,数学运算过程中 的数不一定都是整数。那么,DSP 芯片是如何处理小数的呢?应该说,DSP 芯片本身无能为力。 那么是不是说 DSP 芯片就不能处理各种小数呢?当然不是。这其中的关键就是由程序员来确定 一个数的小数点处于 16 位中的哪一位。这就是数的定标。 通过设定小数点在 16 位数中的不同位置,就可以表示不同大小和不同精度的小数了。数的定标 有 Q 表示法和 S 表示法两种。表 1.1 列出了一个 16 位数的 16 种 Q 表示、S 表示及它们所能 表示的十进制数值范围。 从表 1.1 可以看出,同样一个 16 位数,若小数点设定的位置不同,它所表示的数也就不同。例 如, 16 进制数 2000H=8192,用 Q0 表示 16 进制数 2000H=0.25,用 Q15 表示 但对于 DSP 芯片来说,处理方法是完全相同的。 从表 1.1 还可以看出,不同的 Q 所表示的数不仅范围不同,而且精度也不相同。Q 越大,数值 范围越小,但精度越高;相反,Q 越小,数值范围越大,但精度就越低。例如,Q0 的数值范围 是一 32768 到+32767,其精度为 1,而 Q15 的数值范围为-1 到 0.9999695,精度为 1/32 768=0.00003051。因此,对定点数而言,数值范围与精度是一对矛盾,一个变量要想能够表 示比较大的数值范围,必须以牺牲精度为代价;而想精度提高,则数的表示范围就相应地减小。 在实际的定点算法中,为了达到最佳的性能,必须充分考虑到这一点。 浮点数与定点数的转换关系可表示为: 浮点数(x)转换为定点数(xq):xq=(int)x* 2Q 定点数(xq)转换为浮点数(x):x=(float)xq*2-Q 例如,浮点数 x=0.5,定标 Q=15,则定点数 xq=L0.5*32768J=16384,式中 LJ 表示下取 整。反之,一个用 Q=15 表示的定点数 16384,其浮点数为 163 幼*2-15=16384/32768= 0.5。浮点数转换为定点数时,为了降低截尾误差,在取整前可以先加上 0.5。
例 1.4 结果超过 16 位的定点加法 设 x=l5000,y=20000,则浮点运算值为 z=x+y=35000,显然 z>32767,因此 Qx=1,Qy=0,Qz=0,则定点加法为: x=30000;y=20000; temp=20000<<1=40000; temp=temp+x=40000+30000=70000; z=70000L>>1=35000; 因为 z 的 Q 值为 0,所以定点值 z=35000 就是浮点值,这里 z 是一个长整型数。当加法或加 法的结果超过 16 位表示范围时,如果程序员事先能够了解到这种情况,并且需要保持运算精度 时,则必须保持 32 位结果。如果程序中是按照 16 位数进行运算的,则超过 16 位实际上就是 出现了溢出。如果不采取适当的措施,则数据溢出会导致运算精度的严重恶化。一般的定点 DS P 芯片都没有溢出保护功能,当溢出保护功能有效时,一旦出现溢出,则累加器 ACC 的结果为 最大的饱和值(上溢为 7FFFH,下溢为 8001H),从而达到防止溢出引起精度严重恶化的目的。 2.2 乘法运算的 C 语言定点模拟 设浮点乘法运算的表达式为: float x,y,z; z=xy; 假设经过统计后 x 的定标值为 Qx,y 的定标值为 Qy,乘积 z 的定标值为 Qz,则 z=xy zq*2-Qx=xq*yq*2-(Qx+Qy) zq=(xqyq)2Qz-(Qx+Qy) 所以定点表示的乘法为: int x,y,z; long temp; temp=(long)x; z=(temp*y)>>(Qx+Qy-Qz); 例 1.5 定点乘法。 设 x=18.4,y=36.8,则浮点运算值为=18.4*36.8=677.12; 根据上节,得 Qx=10,Qy=9,Qz=5,所以 x=18841;y=18841; temp=18841L; z=(18841L*18841)>>(10+9-5)=354983281L>>14=21666; 因为 z 的定标值为 5,故定点 z=21666,即为浮点的 z=21666/32=677.08。 2.3 除法运算的 C 语言定点摸拟 设浮点除法运算的表达式为: float x,y,z; z=x/y; 假设经过统计后被除数 x 的定标值为 Qx,除数 y 的定标值为 Qy,商 z 的定标值为 Qz,则
z=x/y zq*2-Qz=(xq*2-Qx)/(yq*2-Qy) zq=(xq*2(Qz-Qx+Qy))/yq 所以定点表示的除法为: int x,y,z; long temp; temp=(long)x; z=(temp<<(Qz-Qx+Qy))/y; 例 1.6 定点除法。 设 x=18.4,y=36.8,浮点运算值为 z=x/y=18.4/36.8=0.5; 根据上节,得 Qx=10,Qy=9,Qz=15;所以有 z=18841,y=18841; temp=(long)18841; z=(18841L<<(15-10+9)/18841=3O8690944L/18841=16384; 因为商 z 的定标值为 15,所以定点 z=16384,即为浮点 z=16384/215=0.5。 2.4 程序变量的 Q 值确定 在前面几节介绍的例子中,由于 x,y,z 的值都是已知的,因此从浮点变为定点时 Q 值很好确 定。在实际的 DSP 应用中,程序中参与运算的都是变量,那么如何确定浮点程序中变量的 Q 值 呢?从前面的分析可以知道,确定变量的 Q 值实际上就是确定变量的动态范围,动态范ቤተ መጻሕፍቲ ባይዱ确定 了,则 Q 值也就确定了。 设变量的绝对值的最大值为|max|,注意|max|必须小于或等于 32767。取一个整数 n,使满 足 2n-1<|max|<2n 则有 2-Q=2-15*2n=2-(15-n) Q=15-n 例如,某变量的值在-1 至+1 之间,即|max|<1,因此 n=0,Q=15-n=15。 既然确定了变量的|max|就可以确定其 Q 值, 那么变量的|max|又是如何确定的呢?一般来说, 确定变量的|max|有两种方法。一种是理论分析法,另一种是统计分析法。 1. 理论分析法 有些变量的动态范围通过理论分析是可以确定的。例如: (1)三角函数。y=sin(x)或 y=cos(x),由三角函数知识可知,|y|<=1。 (2)汉明窗。y(n)=0.54 一 0.46cos[nπn/(N-1)],0<=n<=N-1。因为-1<=cos[2πn/(N1)]<=1,所以 0.08<=y(n)<=1.0。 (3)FIR 卷积。y(n)=∑h(k)x(n-k),设∑|h(k)|=1.0,且 x(n)是模拟信号 12 位量化值,即有 |x(n)|<=211,则|y(n)|<=211。 (4)理论已经证明,在自相关线性预测编码(LPC)的程序设计中,反射系数 ki 满足下列不等式: |ki|<1.0,i=1,2,...,p,p 为 LPC 的阶数。
表 1.1 Q 表示、S 表示及数值范围 Q 表示 S 表示 十进制数表示范围
Q15 S0.15 -1≤x≤0.9999695 Q14 S1.14 -2≤x≤1.9999390 Q13 S2.13 -4≤x≤3.9998779 Q12 S3.12 -8≤x≤7.9997559 Q11 S4.11 -16≤x≤15.9995117 Q10 S5.10 -32≤x≤31.9990234 Q9 S6.9 -64≤x≤63.9980469 Q8 S7.8 -128≤x≤127.9960938 Q7 S8.7 -256≤x≤255.9921875 Q6 S9.6 -512≤x≤511.9804375 Q5 S10.5 -1024≤x≤1023.96875 Q4 S11.4 -2048≤x≤2047.9375 Q3 S12.3 -4096≤x≤4095.875 Q2 S13.2 -8192≤x≤8191.75 Q1 S14.1 -16384≤x≤16383.5 Q0 S15.0 -32768≤x≤32767 2 高级语言:从浮点到定点 我们在编写 DSP 模拟算法时,为了方便,一般都是采用高级语言(如 C 语言)来编写模拟程序。 程序中所用的变量一般既有整型数,又有浮点数。如例 1.1 程序中的变量 i 是整型数,而 pi 是 浮点数,hamwindow 则是浮点数组。 例 1.1 256 点汉明窗计算 int i;+ float pi=3.14l59; float hamwindow[256]; for(i=0;i<256;i++) hamwindow=0.54-0.46*cos(2.0*pi*i/255); 如果我们要将上述程序用某种足点 DSP 芯片来实现,则需将上述程序改写为 DSP 芯片的汇编 语言程序。为了 DSP 程序调试的方便及模拟定点 DSP 实现时的算法性能,在编写 DSP 汇编程 序之前一般需将高级语言浮点算法改写为高级语言定点算法。 下面我们讨论基本算术运算的定点 实现方法。 2.1 加法/减法运算的 C 语言定点摸拟 设浮点加法运算的表达式为: float x,y,z; z=x+y; 将浮点加法/减法转化为定点加法/减法时最重要的一点就是必须保证两个操作数的定标 temp=x+temp; z=temp>>(Qx-Qz),若 Qx>=Qz z=temp<<(Qz-Qx),若 Qx<=Qz
相关文档
最新文档