版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度安全生产月宣传品采购与分发合同
- 2024年度建设施工合同工程质量与工程款支付规定
- 2024年企业环保设施建设和运营合同
- 04版离婚合同:三个孩子的监护权、财产分配及赡养费
- 2024聘用驾驶员合同书
- 2024年建筑基础土石方作业合同
- 安利心态课件教学课件
- 催收员试用期转正工作总结(6篇)
- 2024年度ABC电子科技有限公司手机代理销售合同
- 2024年大型物流中心建设与运营合同
- 妊娠剧吐课件
- 电大学前教育本教育实习教学活动设计
- 河北省廊坊市各县区乡镇行政村村庄村名居民村民委员会明细
- 学校班级图书箱管理制度
- 写给老婆最催泪挽回感情的信范文(5篇)
- 煤化工企业设备设施风险分级管控清单参考模板范本
- 广东省中小学生学籍管理的实施细则
- IATF16949 年度内审审核方案
- 计算机应用基础(中等职业学校校本教材)
- 2022年广州中考物理真题及答案
- 教育评价学全套ppt课件完整版教学教程
评论
0/150
提交评论