作者:Di Pu, Andrei Cozma, and Tom Hill
无线系统的概念与该工作设计的实现之间存在显着差距。弥合这一差距通常涉及具有各种不同技能集(如RF,SW,DSP,HDL和嵌入式Linux)的工程师团队,并且在许多情况下,由于难以协调这些不同设计实体的工作,项目在开发阶段的早期就脱轨了。
在这篇由四部分组成的文章中,我们将研究平台和工具的进步,这些平台和工具允许开发人员快速仿真和原型化无线系统,同时建立和维护可部署的生产路径。作为该过程的真实示例,我们将制作一个无线SDR平台的原型,该平台接收和解码自动相关监视广播(ADS-B)信号,使我们能够检测和报告在我们附近飞行的商用飞机的位置,高度和速度。在这种情况下,所需的资源是MATLAB和Simulink以及集成和嵌入硬件/软件的技能。硬件平台将是ADI公司/赛灵思软件定义无线电(SDR)原型系统。使用 MATLAB 和 Simulink 将执行以下任务:
用于解码ADS-B消息的信号处理算法设计
生成 C 和 HDL 代码
使用目标收发器和 FPGA 上的记录和实时数据验证 HDL 代码
最终结果将是运行在具有生产价值的硬件上运行的工作RF SDR设计,我们将将其带到当地机场并验证其性能和功能。
本文由四部分组成,第一部分将讨论ADI公司/Xilinx SDR原型设计系统、其功能和优势,并简要介绍工具流程。第二部分将回顾自动相关监视广播 (ADS-B) 信号,并解释如何在仿真中以 MATLAB 和 Simulink 解码其信息。第三部分将描述和展示如何使用硬件在环 (HIL) 和目标收发器捕获信号,但仍在 Simulink 中的主机上进行信号处理以进行验证。第四部分将展示如何采用第 2 部分中开发并在第 3 部分中验证的算法,并使用 MathWorks 的 HDL Coder 和嵌入式编码器生成代码并将其部署到生产硬件中,最后我们将在机场使用真实世界的 ADS-B 信号操作该平台。
介绍
随着人们需要通信的方式和方法呈指数级增长,轻松且经济高效地修改无线电设备已成为业务关键。基于这一要求,软件定义无线电技术最近被广泛采用,因为它带来了推动通信发展的灵活性、成本效益和能力。1SDR系统的目的是在软件和可重编程逻辑中尽可能多地实现调制/解调和数据处理算法,以便只需更新软件和可重编程逻辑即可轻松重新配置通信系统,而无需对硬件平台进行任何更改。
随着赛灵思 Zynq 等片上系统 (SoC) 器件的出现。全可编程 SoC 结合了 CPU 的多功能性和 FPGA 的处理能力,设计人员可以将 SDR 系统的数据处理功能整合到单个器件中,同时集成额外的处理任务。数据调制/解调算法等处理密集型任务被卸载到器件的可编程逻辑上,而数据解码和渲染、系统监控和诊断以及用户界面等任务则推迟到处理单元。
与此同时,几十年来,无线系统原型设计一直是一个讨论话题,但由于 MathWorks 的 MATLAB 和 Simulink 等建模和仿真工具的发展,直到最近几年才演变成 FPGA 的完整设计流程——从模型创建到完整实现。无线系统原型设计通过将设计任务从实验室和现场转移到桌面,正在改变工程师和科学家的工作方式。2现在,可以对整个无线系统(如SDR系统)进行建模,使工程师能够观察系统的行为,并在现场实际实施之前对其进行调整。这有几个好处,例如加速系统集成和减少对设备可用性的依赖。此外,一旦 SDR 系统的 Simulink 模型完成,就可以自动生成 C 和 HDL 代码,以便在 Zynq SoC 上实施,从而节省时间并避免引入手动编码错误。通过将系统模型链接到快速原型设计环境,允许SDR系统在现实条件下运行,可以进一步降低风险。
本系列文章由四部分组成,第一部分将讨论ADI公司/Xilinx SDR快速原型系统、其功能和优势,并简要介绍工具流程。本文展示了ADI公司的RF IC技术和参考设计硬件和软件如何降低设计技能子集,从而使客户能够降低风险并缩短上市时间。
Zynq 特别提款权
需要先进的 SDR 系统来执行数据处理、通信和用户界面任务的组合,这些任务具有不同的处理带宽要求和实时约束。选择用于实现此类系统的硬件平台必须具有健壮性和可扩展性,同时允许未来的系统改进和扩展。Xilinx Zynq-7000 全可编程 SoC 通过提供高性能处理系统与可编程逻辑相结合来满足这些要求,如图 1.3 所示 可编程逻辑和处理系统的结合可提供卓越的并行处理能力、实时性能、快速计算速度和连接多功能性。
图1.赛灵思 Zynq SoC 框图。
Zynq SoC 的处理系统端由双核 ARMCortex-A9 处理器、NEON 协处理器和浮点扩展组成,可加速软件执行。嵌入式Linux或实时操作系统可以部署在双核ARM处理器上,以充分利用系统的功能。该处理器是独立的,无需配置可编程逻辑即可使用,这对于希望开始并行开发代码的软件开发人员以及将设计FPGA结构的硬件开发人员来说是一个关键要素。®®
在可编程逻辑方面,该器件具有多达 444,000 个逻辑单元和 2,200 个 DSP 切片,可提供大量处理带宽,使 Zynq 器件能够应对各种具有挑战性的信号处理应用。五个高吞吐量 AMBA-4 AXI 高速互连将可编程逻辑与处理系统紧密耦合,有效带宽相当于 3,000 多个引脚。®4
AD9361 用于SDR的捷变宽带RF收发器IC
近年来,ADI公司向市场推出了革命性的SDR产品,以支持不断发展的SDR要求和系统架构。ADI公司在该领域最重要的产品是AD9361/AD9364集成RF捷变收发器。AD9361 (2 × 2)5和AD9364 (1×1)6是高性能、高度集成的射频收发器 IC,适用于 SDR 架构中的无线通信基础设施、国防电子系统、RF 测试设备和仪器仪表以及通用软件定义无线电平台等应用。这些器件将射频前端与灵活的混合信号基带部分和集成频率合成器相结合,通过为处理器或FPGA提供可配置的数字接口来简化设计导入。这些芯片的工作频率范围为70 MHz至6 GHz,覆盖大多数许可和非许可频段,通过改变采样速率、数字滤波器和抽取,支持低于200 kHz至56 MHz的通道带宽,所有这些器件均可在AD9361和AD9364器件中编程。7图2所示为AD9361器件的框图。
图2.AD9361原理框图
为了帮助客户缩短上市时间和整体开发工作,ADI公司更进一步,在无缝FPGA连接的完整生态系统中提供SDR解决方案,为完整的无线电系统设计提供快速原型设计和开发环境。AD-FMCOMMSx-EBZ 快速开发和原型开发板是一系列高速模拟 FMC 模块,集成了 AD9361 或 AD9364 捷变射频收发器 IC 或可无缝连接到 Xilinx FPGA 开发平台生态系统的分立信号链。这些电路板完全可通过软件定制,无需任何硬件更改,并附带可下载的Linux驱动程序和裸机软件驱动程序、原理图、电路板布局和设计辅助参考资料,所有这些都包含在各自的ADI公司wiki站点上。表 1 总结了不同 FMCOMMSx 平台的功能。
表 1.FMCOMMSx 平台
平台 |
特征 |
AD-FMCOMMS5-EBZ |
这款SDR快速原型开发板集成了两个AD9361 2×2捷变收发器IC,可为4个接收器通道和4个发射器通道提供完全同步功能,支持创建4×4 MIMO系统的任何子集。可容纳 70 MHz 至 6 GHz 和 2.4 GHz 宽带调谐端口。 |
AD-FMCOMMS4-EBZ |
这款 1 × 1 SDR 快速原型开发板集成了捷变型 RF 收发器 IC,可通过软件配置为在 2400 MHz 至 2500 MHz 区域内实现最高 RF 性能,也可以通过软件配置为在 AD9364 的 70 MHz 至 6 GHz 完整 RF 调谐范围内工作,用于系统原型设计和开发。 |
AD-FMCOMMS3-EBZ |
这款 2 × 2 版本的 SDR 快速原型开发板集成了捷变型 RF 收发器 IC AD9361,支持 AD9361 的 70 MHz 至 6 GHz 全 RF 调谐范围。该套件非常适合寻求具有广泛调谐功能的统一开发平台的无线通信 SDR 系统架构师。 |
AD-FMCOMMS2-EBZ |
这款2×2 SDR快速原型开发板集成了AD9361捷变RF收发器IC,经过调谐,可在2400 MHz至2500 MHz范围内实现最高RF性能。该套件非常适合寻求在此定义的RF频谱范围内满足AD9361数据手册规格的优化系统性能的RF工程师。 |
Zynq SDR 快速原型制作平台
参考设计
ADI公司与FMCOMMSx平台一起提供了一个完整的Vivado框架,具有Linux和裸机软件基础设施,既可用于原型设计,也可用于最终生产系统的一部分。图3显示了ADI公司支持FMCOMMSx板的Zynq基础设施。
图3.ADI HDL和软件基础设施。
此高级图表显示了 ADI 参考设计如何在 Xilinx Zynq SoC 上进行分区。HDMI输出用于在显示器上显示Linux接口,而键盘和鼠标可以通过USB 2.0端口连接到系统。ARM Cortex-A9处理系统运行ADI公司提供的Ubuntu Linux。这包括与ADI公司FMCOMMS硬件(IIO示波器)接口所需的Linux IIO驱动程序。8用于监视和控制的用户空间应用程序,Libiio服务器9它允许对 TCP 进行实时数据采集和系统控制,以及远程计算机上运行的客户端,以及包含由嵌入式编码器为控制器的 Simulink 模型生成的 C 代码的可选用户应用程序。
软件基础架构
所有ADI Linux驱动程序都基于Linux工业I/O(IIO)子系统,该子系统现在包含在所有主线Linux内核中。IIO Scope是由ADI公司开发的开源Linux应用程序,运行在双ARM Cortex-A上。9内核位于赛灵思 Zynq 内部,能够显示从连接到赛灵思 Zynq 平台的任何 ADI FMC 卡采集的实时数据。数据可以显示为时域、频域或星座图。支持不同的流行文件格式,如逗号分隔值或.mat MATLAB数据文件,以保存捕获的数据以供进一步分析。IIO示波器提供图形用户界面,用于更改或回读ADI公司FMC卡的配置。libiio服务器允许实时数据采集和系统控制传输控制协议(TCP)以及远程计算机上运行的客户端。10服务器在 Linux 下的嵌入式目标上运行,并通过 TCP 管理目标和远程客户端之间的实时数据交换。该库抽象了硬件的低级细节,并提供了一个简单而完整的编程接口,可用于高级项目。其模块化架构、精心设计的 API 和内置网络功能允许用户创建应用程序,这些应用程序不仅可以在连接 IIO 设备的系统上运行,还可以通过网络远程运行。最初针对Linux,现在也可以通过使用库的远程后端在Windows下使用。它用C语言编写并在LGPL下授权,具有C#,Python和MATLAB的绑定。MathWorks IIO 客户端11可作为系统对象集成到本机 MATLAB 和 Simulink 应用程序中。它旨在通过以太网与连接到运行ADI Linux发行版的FPGA/SoC平台的ADI硬件系统交换数据,使MATLAB或Simulink模型能够执行以下功能:
将数据流式传输到目标或从目标流式传输数据
控制目标的设置
监控不同的目标参数
IIO 系统对象在 MATLAB 和 Simulink 中都可用,具体取决于用户是从 MATLAB 脚本调用它还是将其合并到 MATLAB 系统块中。ADI为FMCOMMS平台提供的Linux软件和HDL基础设施是SDR应用原型设计的绝佳环境,以及MathWorks和Xilinx提供的工具,它还包含可集成到SDR系统中的生产就绪组件,有助于减少从概念到生产所需的时间和成本。
为了帮助客户快速轻松地使用 IIO 系统对象,我们提供了几个基于此接口的 MATLAB 和 Simulink 示例,例如信标帧接收器、12QPSK发射器和接收器,13以及LTE发射器和接收器。14在这些示例中,FMCOMMSx平台由IIO系统对象配置,并用作RF前端,通过空中发送或接收模拟信号。这些信号通过IIO系统对象流向目标或从目标流出。所有其他信号处理都在 MATLAB 或 Simulink 中进行。图 4 是信标帧接收器示例的屏幕截图,其中显示了 IIO 系统对象与其他 Simulink 模块之间的典型连接。
图4.信标帧接收器示例的屏幕截图。
MathWorks 对 Zynq 的支持
MathWorks 对基于 Zynq 的 SDR 的支持主要来自以下四个方面:
1. AD9361 模拟模型
由于AD9361是一款集成RF收发器芯片,因此无法进行信号探测和内部工作监控。出于这个原因,MathWorks和ADI公司共同开发了AD9361的SimRF™模型,该模型允许对芯片的运行进行仿真,以便客户能够准确了解引擎盖下的情况,以及芯片在不同测试条件下的性能,这些条件在现实生活中难以复制。SimRF 提供元件库和仿真引擎,用于使用等效基带或电路包络模块(如放大器、混频器和 S 参数模块)设计射频系统。它是对AD9361 RF收发器进行建模的有用且合适的工具。图5所示的系统级捷变RF收发器AD9361模型完全复制了AD9361的功能,并作为MathWorks硬件支持包提供给用户。15
SimRF 模型已在实验室中通过功率谱测量进行了验证。确定了收发器在不同频率和功率水平下的噪声和非线性特性。然后设计模型以生成相同的特征,从而在整个设计范围内验证它们。
使用AD9361收发器SimRF型号,用户可以执行以下操作:
预测射频缺陷对测试信号的影响
使用参考音和 LTE 信号
生成或导入测试矢量,并评估非线性、噪声、增益和相位不平衡、频谱泄漏以及RF发射器和接收器引入的其他缺陷的影响
添加干扰信号并在时域或频域中评估结果
图5.捷变射频接收器AD9361的MathWorks SimRF模型。
2. 通信和DSP系统工具箱功能
MathWorks 产品,如通信系统工具箱,™16信号处理工具箱,™17 DSP系统工具箱,™18和模拟射频19提供行业标准算法和应用程序,用于系统地分析、设计和调整 SDR 系统。所有这些工具都提供了创建高保真SDR模型的方法,这些模型可用于在实际物理实现之前验证通信系统的行为和性能。
3. Zynq 的 Simulink 工作流程
MathWorks 的 MATLAB 和 Simulink 是用于多域仿真和基于模型的设计的环境,非常适合使用通信算法仿真 SDR 系统。通信算法调整增益、频率偏移、定时偏移和其他性能变量,通常是为了在发射器和接收器系统之间实现更好的同步。在进行昂贵的硬件测试之前,使用仿真评估通信算法是确定SDR设计适用性并减少算法开发时间和成本的有效方法。图 6 描述了通过以下步骤设计通信算法的高效工作流程:
使用基于模型的设计环境提供的库构建准确的 SDR 模型。
模拟系统行为以验证系统是否按预期运行。
生成 C 代码和 HDL 以进行实时测试和实施。
使用原型硬件测试通信算法。
一旦通过原型硬件上的仿真和测试证明SDR系统的性能令人满意,就可以安全地将系统实施并将其部署到最终生产系统上。
图6.通信算法设计的工作流程。
4. 同步墨水平台与 Zynq SDR 套件的集成
一旦SDR系统在仿真环境中使用嵌入式编码器等工具得到全面验证®20和 HDL 编码器™21从MathWorks,用户可以使用嵌入式编码器和VHDL或使用HDL Coder生成C代码或Verilog,然后将代码部署到原型硬件进行测试,然后部署到最终生产系统上。此时,指定了软件和硬件实现要求,例如定点和定时行为。自动代码生成有助于减少从概念到实际系统实施所需的时间,并避免引入手动编码错误,确保实际的SDR实现与模型相匹配。图 7 描述了在 Simulink 中对 SDR 系统进行建模并将其传输到基于 Xilinx Zynq SoC 的最终生产系统上所需步骤的真实过程。
图7.从模拟到生产的路径。
第一步是在 Simulink 中对 SDR 系统进行建模和仿真。在此阶段,通信算法被划分为将在软件中实现的块和将在可编程逻辑中实现的块。分区和仿真完成后,SDR 模型将使用嵌入式编码器和 HDL 编码器转换为 C 代码和 HDL。基于 Zynq 的原型系统用于验证通信算法的性能,并帮助在进入实际生产阶段之前进一步调整 SDR 模型。在生产阶段,自动生成的C代码和HDL被集成到复杂的生产系统框架中。该工作流程可确保通信算法一旦进入生产阶段,就会得到充分验证和测试,并为系统的稳健性提供很大的信心。Zynq 嵌入式编码器和 HDL 编码器硬件支持包为集成硬件/软件设计、仿真和验证提供了一个框架,可将基于模型的设计集成到工作流程中,从而实现快速设计迭代周期,并帮助及早检测和纠正设计和规范错误,从而更轻松地对 Zynq 平台进行编程。
结论
本文阐述了现代 SDR 系统的要求和趋势,以及 MathWorks、Xilinx 和 ADI 公司为满足这些要求并帮助推动实现性能更高的 SDR 解决方案而向市场推出的工具和系统。通过将 MathWorks 基于模型的设计和自动代码生成工具与功能强大的 Xilinx Zynq SoC 和 ADI 集成射频收发器相结合,SDR 系统的设计、验证、测试和实施可以比以往更加有效,从而获得更高性能的无线电系统并缩短上市时间。ADI公司的FMCOMMS平台与Avnet Zynq-7000 AP SoC配对,为使用MathWorks的MATLAB和Simulink设计的SDR算法提供了出色的原型设计环境。FMCOMMS平台附带一组开源参考设计,旨在为任何想要评估系统并帮助启动任何新SDR项目的人提供一个起点。
审核编辑:郭婷
-
ADI
+关注
关注
144文章
45814浏览量
249042 -
SDR
+关注
关注
7文章
233浏览量
50427 -
无线电
+关注
关注
59文章
2132浏览量
116356
发布评论请先 登录
相关推荐
评论