离散余弦变换(DCT)的DSP程序设计与实现_第1页
离散余弦变换(DCT)的DSP程序设计与实现_第2页
离散余弦变换(DCT)的DSP程序设计与实现_第3页
离散余弦变换(DCT)的DSP程序设计与实现_第4页
离散余弦变换(DCT)的DSP程序设计与实现_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、-作者xxxx-日期xxxx离散余弦变换(DCT)的DSP程序设计与实现【精品文档】DSP课程设计论文题 目 离散余弦变换(DCT)的DSP实现 专 业 电气工程及其自动化 姓 名 陈梦泽 班 级 11东电气 学 号 11811527 执行学期 2014-2015 离散余弦变换(DCT)的DSP实现一、实验目的 1. 掌握离散余弦变换的概念和实现方法; 2. 掌握用 C 语言或汇编语言编写 DSP 程序的方法; 3. 熟悉DCT原理;二、实验设备 1. 一台装有 CCS 软件的计算机; 2. DSP 实验箱的TMS320C5410 主控板; 3. DSP 硬件仿真器;三、实验原理论述 1、原理

2、 离散余弦变换(Discrete Cosine Transform,简称DCT变换)是一种与傅立叶变换紧密相关的数学运算。在傅立叶级数展开式中,如果被展开的函数是实偶函数,那么其傅立叶级数中只包含余弦项,再将其离散化可导出余弦变换,因此称之为离散余弦变换。对于给定的实际数据序列x(0),X(1) ,x(2). X( N-1 )的DCT(FDCT)算法如下:(1)其中:(2)二维离散余弦变换(FDCT):(3)其逆运算是:(4)其中 N= 8 为 8x8 DCT. 2、DCT的DSP 程序设计 无论是C语言还是汇编语言,程序流程均分为初始化、行变换、列变换和移位输出四个步骤。行、列变换具有相似性

3、,如果对行变换的结果矩阵转置,则列变换程序跟行变换一样。对于汇编而言,初始化部分主要初始化FP指针以指向前一函数地址,初始化数据和指针寄存器以保存返回数据等。由于DCT行变和列变换过程相似,且列变换是在行变换操作的基础上进行的。则可利用多种索引寻址寄存器的灵活组合,把行变换结果直接以转置方式存储而不增加实际的存储时间,这样行列变换可使用同一代码循环两次实现,减小了实际代码大小。本程序实现的是FDCT,可以使用2次一维DCT变换来实现二维DCT变换。 3、DCT的DSP实现二维DCT 变换时结果为两次无理数sqrt(8)相乘,产生了有理项,因此,在程序里首先多乘一次sqrt(8),然后在两次DC

4、T 变换结束以后,使用右移3位以达到正常输出。四、方案论证及系统设计 本次实习有两种方案,C语言和汇编语言实现,由于考虑到DSP程序的特点,我采用汇编语言实现。 1.打开CCS软件,编制程序简化行列变换的代码如下: 2.B0 = R0; B3 = R1; B2 = R2; LSETUP (DCT_START, DCT_END) LC0 = P0; DCT_START: LSETUP(ROW_START,ROW_END)LC1=P2; ROW_START: ROW_END: B1 = B0; B0 = B2; DCT_END:B2 = B1; 五、一维DCT变换流程图六、程序模块源程序DSP程序

5、: .mmregs .def entry .sect "INIT"* Initialise*entry NOP NOP SSBX SXM ; set sign extension mode SSBX OVM ; enable saturation LD #0, DP ; set data page STM 0FFE0h, PMST ; Init PMST reg. RSBX FRCT .include "fdct_dat.inc" ; FDCT data storage declarationMODE .SET 1 ; MODE=1 TEST ON SI

6、MULATORPAGE0 .SET 0PAGE4 .SET 4PAGE24 .SET 24dPAGE25 .SET 25dB0 .SET 0200hB1 .SET 0300hB2 .SET 060hPA1BIS .SET 1PA2BIS .SET 2PA3BIS .SET 3PA4BIS .SET 4PA5BIS .SET 5PA6BIS .SET 6* Initialization of the registers .sect"FDCT"INIT LD #PAGE24, DP ST #21407, E_P6 ST #8867, F_P6 ST #2000H, ROUND1

7、TBL: LD #PAGE25, DP ST #21407, E_P7 ST #8867, F_P7 ST #4000H, ROUND2 ST #40H, ROUND3START* IF MODE = SIMULATOR.IF MODE=1 STM #63, AR0 ; AR0= # of inputs to be taken - 1 STM #X, AR1 ; AR1= address of first inputBEG PORTR #PA1BIS, *AR1+ ; Read and store to addr(AR1) BANZ BEG, *AR0- ; Repeat above code

8、 64 times ; till all 64 pixels are read.ENDIF STM #3, AR0 STM #X, AR1 ; Reset AR1 to first input STM #Y00, AR2 ; Set AR2 to first Y blockDCT1 NOP NOP LD #PAGE24, DP LD *AR1+, 4, A ; + (16)*(X0) ADD *AR1+, 4, A ; + (16)*(X1) ADD *AR1+, 4, A ; + (16)*(X2) ADD *AR1+, 4, A ; + (16)*(X3) ADD *AR1+, 4, A

9、; + (16)*(X4) ADD *AR1+, 4, A ; + (16)*(X5) ADD *AR1+, 4, A ; + (16)*(X6) ADD *AR1, 4,A ; + (16)*(X7) STL A, Y00 ; = Y00 RPTZ A, #7 MACP *AR1-, COEF_F1, A SFTA A, 4 MAR *AR1+ ; (64)A*X0+B*X1+C*X2-D*X3-D*X4 ADD ROUND1, A ; -C*X5-B*X6-A*X7 + 4*ROUND1 STH A, 2, Y01 ; = Y01 LD ROUND1, -4, A ; (ROUND1)/1

10、6 LD E_P6, T MAC *AR1+0, A ; + X0*E_P6 MAS *AR1+, A ; - X3*E_P6 MAS *AR1+0, A ; - X4*E_P6 MAC *AR1-, A ; + X7*E_P6 LD F_P6, TMAC *AR1-, A ; + X6*F_P6 MAS *AR1-0, A ; - X5*F_P6 MAS *AR1-, A ; - X2*F_P6 MAC *AR1-, A ; + X1*F_P6 STH A, 6, Y02 ; Multiply prev summation by 16 ; = Y02 RPTZ A, #7 MACP *AR1

11、+, COEFF2, A ; 64(B*X0-D*X1-A*X2-C*X3+C*X4+A*X5 SFTA A, 4 MAR *AR1- ADD ROUND1, A ; +D*X6-B*X7) + 4*ROUND1 STH A, 2, Y03 ; = Y03 LD *AR1-, 4, A ; X7*16 SUB *AR1-, 4, A ; - X6*16 SUB *AR1-, 4, A ; - X5*16 ADD *AR1-, 4, A ; + X4*16 ADD *AR1-, 4, A ; + X3*16 SUB *AR1-, 4, A ; - X2*16 SUB *AR1-, 4, A ;

12、- X1*16 ADD *AR1, 4, A ; + X0*16 STL A, Y04 ; = Y04 RPTZ A, #7 MACP *AR1+, COEFF3, A ; 8(D*X0-C*X1+B*X2-A*X3+A*X4-B*X5 SFTA A, 4 ; +C*X6-D*X7) MAR *AR1- ADD ROUND1, A ; + 4*ROUND1 STH A, 2, Y05 ; = Y05 LD ROUND1, -4, A ; (ROUND1)/16 LD F_P6, T MAC *AR1-0, A ; + F_P6*X7 MAS *AR1-, A ; - F_P6*X4 MAS *

13、AR1-0, A ; - F_P6*X3 MAC *AR1+, A ; + F_P6*X0 LD E_P6, T MAS *AR1+, A ; - E_P6*X1 MAC *AR1+0, A ; + E_P6*X2 MAC *AR1+, A ; + E_P6*X5 MAS *AR1+, A ; - E_P6*X6 STH A, 6, Y06 ; Multiply prev summation by 16 ; = Y06 RPTZ A, #7 MACP *AR1-, COEF_F4, A ; 64(D*X0-C*X1+B*X2-A*X3+A*X4-B*X5 SFTA A, 4 ; +C*X6-D

14、*X7) MAR *AR1+ ADD ROUND1, A ; + 4*ROUND1 STH A, 2, Y07 ; = Y07 MAR *+AR1(8) ; Set AR1 to point to the next set ; of 8 inputsDCT3 NOP NOP* PLACE FDCT COEFFICIENTS IN FILE POINTED BY PA2 .IF MODE=1 STM #63, AR0 ; AR0= # of outputs - 1 STM #Z00, AR1 ; AR1= addr of first outputBEG1 PORTW *AR1+, #PA2BIS

15、 ; Send output value BANZ BEG1, *AR0- ; Repeat above process (64x).ENDIFEXITNOP B START ; Go to start of program. ; Grab another 64 pixelsCOEF_F1 .WORD -22725,-19266,-12873,-4520,4520,12873,19266,22725COEFF2 .WORD 19266,-4520,-22725,-12873,12873,22725,4520,-19266COEFF3 .WORD 12873,-22725,4520,19266,

16、-19266,-4520,22725,-12873COEF_F4 .WORD -4520,12873,-19266,22725,-22725,19266,-12873,4520* with: A = cos(?16)*?*16384 = 22725* B = cos(3?16)*?*16384 = 19266* C = cos(5?16)*?*16384 = 12873* D = cos(7?16)*?*16384 = 4520* E = cos(?8)*?*16384 = 21407* F = cos(3?8)*?*16384 = 8867*.END链接文件:-e entryMEMORY P

17、AGE 0: OCDARAM1: origin = 00080h length = 00880h /* on-chip DARAM */ OCDARAM2: origin = 00900h length = 00300h OCDARAM4: origin = 00C00h length = 00400h OCDARAM5: origin = 01000h length = 00400h EXTERNAL: origin = 01400h length = 0EB80h INTRVECS: origin = 0FF80h length = 00079h PAGE 1: MMREGS: origi

18、n = 00000h length = 00060h SPRAM: origin = 00060h length = 00020h OCDARAM1: origin = 00080h length = 00400h /* on-chip DARAM */ OCDARAM2: origin = 00480h length = 0077Fh OCDARAM4: origin = 00C00h length = 00400h OCDARAM5: origin = 01000h length = 00400h EXTERNAL: origin = 01400h length = 0EC00hSECTIONS INIT

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论