×

基于DSP DUC的短波阵列信号发生器设计分析

消耗积分:1 | 格式:rar | 大小:0.2 MB | 2017-10-27

分享资料个

 一、引言
  阵列信号处理作为数字信号处理领域的一个重要分支,广泛应用于雷达、声纳、通信、地震勘探和医用成像等众多领域;短波频段则常用于短波测向和波束合成技术。
  在短波频段,阵列信号处理设备通常包括短波天线阵、短波多波道接收机、后端阵列信号处理机3个主要组成部分。其中,短波天线阵接收空间短波信号,短波接收机对HF信号作模拟下变频,阵列信号处理机则对短波多波道接收机输出信号作数字采样并进行相应的阵列信号处理算法,给出最终运算结果。
  短波天线阵由于短波频段的限制,通常天线单元的体积比较大,天线阵的孔径也比较大,占地往往近十亩;而且为了达到比较好的接收效果,短波天线阵对周边电磁环境的要求也相当高。这都给短波阵列信号处理机研制过程中的调试和试验带来了极大的不便,同时也很不利于阵列信号处理机针对不同阵列流型短波信号的各种DSP算法研究和验证。
  针对短波阵列信号处理设备研制、调试的实际情况,笔者选用数字信号处理器芯片(DSP)和数字上变频器芯片(Digital UpConverter,DUC)设计了一个模拟短波天线阵输出信号的阵列信号发生器,可以在实验室环境下取代短波天线阵,产生各种不同阵列流型相对应的短波阵列信号,提供阵列信号处理机DSP算法的调试和验证条件。
  二、设计思路
  按照设计构想,本阵列信号发生器应该能够灵活地产生对应不同阵列形式(携带有不同阵列形式对应的幅度差和相位差)、基本覆盖1~30MHz频段范围的短波阵列信号。
  如果采用传统的模拟上变频威廉希尔官方网站 实现射频输出,很难满足设计构想,因此笔者采用软件无线电的思想,选用了数字上变频器(DUC),在数字域作上变频,然后通过D/A变换产生短波高频模拟信号。为了实现不同阵列形式所带来的幅度差和相位差,笔者选用了DSP芯片,在数字域对多个信号加入不同的幅度及相位差。
  如图1所示,阵列信号发生器的总体设计思路为:以DSP和DUC为核心,利用外部音频信号输入的A/D采样数据作为调制信号数据,由DSP对预制的载波信号(较低频率)作数字调制运算,并根据可选的不同阵列流型对已调数字信号分别加上9个不同的幅度差和相位差后,经FPGA分别送到9个DUC中,经数字上变频及D/A变换后输出9路短波阵列信号。
  基于DSP DUC的短波阵列信号发生器设计分析
  在设计中由于实际的音频调制信号要经过DSP芯片的数字调制运算,再分配到9个DUC中,因此使用一个大规模的FPGA逻辑芯片作为DSP芯片和9个DUC芯片之间的数据交换接口。
  
  三、器件选择
  1.DSP
  作为本设计的核心器件,DSP芯片的运算能力要求比较高,同时又存在运算过程中大量数据交换的特点,经过综合比较,笔者选用了Analog Device公司的SHARC-DSP系列中的ADSP-21060。
  ADSP-21060是32位浮点DSP,使用40 MHz主时钟,运算能力可达120 MFLOPS;片内带有4 Mbit的双口SRAM(对本设计,则不需要外部另行扩充存储器,所有运算所需存储空间均由内部支持,大大减少与外部存储器交换数据的DSP时间开销);支持10个DMA通道供片内SRAM和外部存储器、串口等交换数据(本设计利用其DMA通道传递音频采样数据)。
  2.串行A/D
  本设计之所以采用串行A/D对外部输入音频进行数字采样,主要是考虑到外部输入信号应不间断地进入DSP的内存中,可利用ADSP-21060的串口DMA方式传递数据。因此笔者选用了Analog Device公司的双声道串行音频采样器AD1847。
  3.数字上变频器
  DUC的主要功能是对输入数据进行频率变换、频谱搬移,即在数字域实现混频。笔者选用了Analog Device公司的AD9857作为本设计的DUC。
  AD9857是14位正交数字上变频器(QDUC),最高工作时钟为200 MHz,内部集成有高速直接数字合成器(DDS)、数字内插滤波器、时钟倍频威廉希尔官方网站 以及用户可编程功能;而且内部集成有一个14位数模转换器(DAC),可以直接输出模拟高频信号。
  由于AD9857把数据传输路径从模拟领域转移到数字领域,在物理上模拟威廉希尔官方网站 功能与数字部件是分开的,因此当修改威廉希尔官方网站 参数或系统升级时,只需通过AD9857的SPI串行编程端口对内部寄存器做一些简单的修改,不需要改变硬件威廉希尔官方网站 即可实现。
  4.FPGA
  由于本设计中存在大量的高速数据交换,因此作为DSP和DUC数据接口的FPGA规模要求比较大,笔者选用的是Altera公司FLEX系列中的EPF10K50E。
  EPF10K50E典型逻辑门数为5万门,片内含有40 kbit的RAM,可满足较大量的数据缓存和数据交换要求。
  四、 设计实现
  在设计实现中,本设计的主要工作集中在DSP程序编制和FPGA软件调试两个方面。
  1.DSP程序
  DSP作为整个设计的主控者,主要完成以下3个方面的功能:
  首先,DSP对串行A/D采样器AD1847进行简单的配置,如采样率、数据格式等,并配置自身的接收串口,设置为链式DMA方式,从而在一块指定的内存区间不间断地重复存储和刷新音频采样数据;
  其次,DSP将对DMA存储空间的数据作数字调制运算,载波信号使用的是预制的几组较低频率(如5 kHz、10 kHz等)的余弦信号之一;然后对已调数字信号根据不同的阵列流型添加不同的幅度、相位差,构成带有幅度和相位差别的阵列信号;最后将阵列信号数据按照不同的端口地址,以并行的方式写入FPGA中各自对应的暂存FIFO中,由FPGA负责将其分配至各个DUC数据端口;
  再次,DSP对9个DUC内部寄存器的配置,包括上变频倍数、输出载波频率、频谱搬移方式、输出模拟信号幅度等。DSP对于DUC的配置是以向不同地址的外部端口写入并行数据字的方式进行的,再通过FPGA的数据转换功能转变为串行SPI数据格式,分别对每个DUC作寄存器配置。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'基于DSP DUC的短波阵列信号发生器设计分析',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);