基于DSP实时相关叠加器系统设计.docVIP

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于DSP实时相关叠加器系统设计

基于DSP实时相关叠加器系统设计   在可控震源地震勘探中,实时相关叠加器是必不可少的重要仪器。它的主要功用是将记录的地震信号与震源的扫描信号在采集现场进行实时相关叠加处理,从而得到可用的地震勘探资料。实时相关叠加器作为一种实时现场数据处理机有两个最重要的指标。一个是数据吞吐率,其二是使用硬件的多少,如何使用最少的硬件而获得最大的吞吐率一直是设计者追求的目标。   随着电子技术和计算机技术的发展,目前仪器设计人员都倾向于采用数字信号处理器或专用大规模集成芯片作为相关器的核心处理器。采用这类可编程芯片来设计相关器,当核心处理器选定后,设计者的任务就是要选择一种合适的算法,在保证数据吞吐率的前提下,将算法移植到系统中去,并且不失算法的各项性能,成为该设备实际的核心问题。   本系统选用TI公司的TMS320C6713为核心处理器,配合CPLD,SRAM,FLASH等其他外围器件来实现相关叠加器的算法,C6713是一款高性能的浮点DSP芯片,它的时钟频率225MHZ,8ns的指令周期,最大处理能力能够可达到1350MFlops。      系统硬件的总体设计         图1实时相关叠加器系统硬件流程      实时相关叠加器的硬件设计流程见图1。   该系统主要由DSP,CPLD,SRAM,Flash及其他外围器件组成。该系统的工作原理为:采集信号输入时,CPLD作为接口和逻辑控制器件,将所采集到的数据存储在高速的SRAM中,并在采集完一道地震数据后通知DSP准备好。在数据处理阶段,DSP将SRAM中的数据分块取到其内部RAM中,作为相关识别算法的临时数据。其中所外接的Flash用于存放高达32K长的FFT的正余弦表(0~45度正余弦值)以及16~32K字的部分用于存放处理程序。C6713自带的片内RAM和ROM可用于存放经常使用的核心程序和数据。C6713通过RS232接口与上位机的通信,可通过接入一片UART芯片,完成与上位机的数据通信。      相关叠加器的算法实现      在可控震源地震勘探信号的实时相关处理中,用y(n)表示记录信号,用x(n)表示扫描信号,由于地震记录长度一般都很长,参考扫描信号相对要短的多,此时若直接采用时域相关,则需要的运算量很大。若直接采用基-2FFT算法,FFT的运算时间相对也要长的多,也不利于提高数据吞吐率。考虑到地震勘探中相关信号的特殊性,当记录长度比需要输出的相关点数要大得多时,可采用分段FFT法进行信号相关,其方法如下:   设N1为需要输出的相关长度,将长为L的扫描记录y(n)分为每段长为p的J段,则有L=Js,并使N=2k1≥N1+p,这里k1为某一正整数,将x(n),y(n)分为长为N的小段xj(n), yj (n),分法如下:      则有      则      同时按照循环相关与线性相关的关系,当满足N=2k1≥N1+p时,可由计算循环相关来计算线性相关,因而可用FFT快速计算。   结合该算法,下面给出了实现该算法的程序流程图。      图2 相关叠加器的算法程序流程图      程序存储空间分配      对于在PC机上执行算法,是不用考虑存储空间的分配问题的。因为系统有足够的存储空间供使用,而目的存储空间的分配是由操作系统来完成的。但是在嵌入式系统中,虽然也有很小的嵌入式的操作系统可用,然而对于这种需要大量的数据处理的场合,存储空间很少的情况(C6713片内RAM 32K),操作系统根本无法完成存储的分配。所以所有的存储空间的分配都必须手动处理。   编译器在处理分配内存时,对于函数内部的局部变量,存储空间一般在堆栈上生成;用malloc等C函数可以在全局堆栈上动态地分配内存;但是在DSP系统中用这个函数一般避免使用malloc,因为它会把原来很大的一块连续内存区域逐渐地分割成许多非常小而且彼此又不相邻的内存块,影响程序的内存分配。所以对于原先数据空间中比较大的局部数组变量,应该手动为它们分配空间,而不是在堆栈上生成,这样可以保证空间分配的灵活性。   下面是实际的片内存储空间的简单划分:   VECT 0X0080-0X0100 中断向量   PROG 0X0100-0X1000 程序段   SWAP_PROG 0X7e00-0X17FF程序交换段   SWAP_DATA 0X1800-0X1FFF数据交换段   DATA0X2000-0X7cFF 数据段   STACK 0X7e00-0X7FFF 堆栈段   VECT是系统引导以后重定位的中断向量表。程序段是那些必须放在片内的程序部分,主要是涉及硬件接口和c函数的一些初始化代码。相关器算法代码实际是放在片外,但是执行是在片内,

您可能关注的文档

文档评论(0)

bokegood + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档