百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

多通道输出可调的PCM信号源设计

ahcoder 2025-03-02 15:59 30 浏览

骈 洋,苏淑靖

(中北大学 电子测试技术重点实验室,山西 太原030051)

摘 要:针对遥测PCM模拟源输出信号单一及参数不可调的问题,提出了一种多通道波形输出可调的PCM信号源的设计。设计中以FPGA作为逻辑控制芯片,充分利用其灵活性、内部资源与特点。在对信号源设计方案和硬件电路简要描述的基础上,重点介绍了其通信协议和软件实现方法,最后对信号源进行了试验。试验结果表明,该信号源能够实现1 024以内任意通道输出波形可调的功能,并支持8位和16位字长可选。

中图分类号:TN919

文献标识码:A

DOI:10.16157/j.issn.0258-7998.2016.04.019

中文引用格式:骈洋,苏淑靖. 多通道输出可调的PCM信号源设计[J].电子技术应用,2016,42(4):67-69,77.

英文引用格式:Pian Yang,Su Shujing. The design of PCM signal source of multi-channel output adjustable[J].Application of Electronic Technique,2016,42(4):67-69,77.

0 引言

遥测模拟设备(即PCM信号源)能够完成遥测系统的基本测试,提供系统所需的外部检测信号。信号源输出的模拟信号主要由帧同步码组加上各个通道的数据按照一定的格式组成,并通过并串转换,实现PCM码流的串行输出,作为检测遥测设备的模拟信号发生器。

随着遥测技术在航天、航空、气象和卫星等领域的应用越来越多,对遥测设备的测试要求也越来越严格,传统的单一、低频、定频和参数不可调的遥测模拟设备已不能满足日益复杂的应用需求[1-4]。为了解决传统遥测信号源输出信号简单、通道不可调的问题,本文提出了一种基于FPGA的多通道输出可配置的通用PCM信号源。利用FPGA内部丰富的RAM和ROM资源及其特点,解决了使用外部EPROM输出PCM信号格式单一、固定的问题[5]

该设计能够实现1 024通道以内的任意通道数的参数配置,参数包括正弦波、方波、三角波、锯齿波、随机数和固定值等六种波形,固定值支持用户自定义,每个通道支持8位和16位字长可选。

1 信号源设计

参数可调的PCM信号源框图如图1所示,主要包括背板总线接口、LVDS通信模块、FPGA控制模块、输出驱动模块和电源模块。LVDS通信模块实现指令数据流的高速接收和解串功能,包括高速串化器和高速解串器两部分。FPGA则完成通道参数配置和数据存储等信号源基本功能实现的逻辑控制,电源模块提供信号源电路基本的电压信号,信号源的输出驱动电路实现PCM码流的单端输出和差分输出。

信号源工作原理:通过计算机配置每条通道的波形,并将配置后的参数进行打包,下发给PCM信号源卡;背板总线上的指令数据流经过LVDS解串后传输至FPGA逻辑控制单元,由其对指令进行接收和处理,并将数据流中的参数和用户定义的固定值写入内部RAM进行存储;当写入完成时分别读取各通道参数,根据参数值读取相应的波形数据;最后,将并行的波形数据并串转化,输出PCM串行码流。

在本设计中,通道个数即为PCM码的副帧长度,可定义范围为1~1 024。PCM信号源波形参数支持6种信号:正弦波、方波、三角波、锯齿波、随机数和固定值,其中固定值的内容可在计算机软件上编辑。

1.1 指令流接收电路

在PCM信号源指令数据流的接收电路上,采用了低压差分接口技术(LVDS)。通过连接背板总线,实现信号源与背板之间的高速数据通信。LVDS是一种效率极高的技术,具有低摆幅输出电压、高传输速率和低功耗的优点,使得其在高速数据通信电路设计中经常被使用[6,7]。因此,能够满足设计中对数据和指令的高速接收要求。在本设计中选用了集成高速串化器和解串器于一体的18位DS92LV18芯片,其具有支持15~66 MHz时钟、独立的发送器和接收器操作、内部PLL、线性回环和本地回环模式等特点。

1.2 输出驱动电路

为了提高PCM信号源的通用性,设计了单端或差分两种输出方式。单端输出之前,使用了一个ADuM1200双通道数字隔离器对输出信号进行隔离。其中ADuM120x系列隔离器支持低电压工作并能实现电平转换,具有很低的脉宽失真(<3 ns)和直流校正功能,自带的刷新电路保证了即使不存在输入跳变的情况下输出状态也能与输入状态相匹配的优点。差分输出则通过采用DS26C31M单端转差分驱动芯片来实现,该芯片是一个四路CMOS三态差分线驱动器,其满足RS-422的EIA标准需求,支持将输入的TTL或CMOS电平转换为RS-422电平输出。

2 协议与软件实现

为了实现多通道输出波形可配置的PCM信号源的设计,需要将计算机下发的基本参数配置信息和固定值接收和存储,这一过程主要通过逻辑控制单元实现。其中FPGA内部程序框图如图2所示,主要模块包括:指令接收和处理模块、参数信息存储模块、波形数据存储模块、数据产生模块和PCM码并串转换输出模块。当接收到指令数据流,信号源首先完成基本PCM输出参数(码率、字长、副帧帧数和同步字等)的配置。当各通道配置完成后,输出的并行数据经过FIFO缓冲,输入到PCM并串转换模块,将并行的8位数据信号转换为串行码流输出,此时转换时钟是FIFO读时钟的8倍。

2.1 参数包协议

参数可调信号源设计的关键之一,是设计一个信号源与计算机软件通信的协议。在本设计中,为了方便底层硬件的接收和存储,将配置的通道参数和固定值数据按照一定的格式进行打包下发。PCM信号源则根据接收到的参数包起始和结束标志信号完成各个通道参数的接收和存储过程,其主要下发的参数包格式如表1所示,其中数据类型data[9:8]用二进制表示,data[7:0]用十六进制表示。

其中将数据的高两位data[9:8]作为区分数据(“00”)、地址(“01”)、命令(“10”)和参数(“11”)的标志,data[7:0]则为具体的数值。8位波形参数范围为 “00~05”,分别对应正弦波、方波、三角波、锯齿波、随机数和固定值六种类型。信号源地址为“01”,起始命令为“20”,参数包结束命令为“21”,固定值默认16位。波形ROM中偶数地址存16位的高8位,奇数地址则为低8位,与固定值RAM相同。

2.2 数据包接收与存储

指令接收和处理模块首先记录下设置的副帧长度(即通道数p_max),作为判断参数存储完成的一个信号。在接收到通道配置数据包的起始命令(“20”)后,开始接收和存储通道参数进程。当通道参数_RAM写地址(addra)≤p_max以及包数据中高两位data[9:8]为“11”(参数标志)时,将此时data[7:0]写入参数存储模块。同时,判断参数类型,如果当前通道参数为固定值,则将参数后的两个低8位数据写入固定值RAM模块中进行存储,其他波形参数后的固定值数据忽略。这就保证了设置的通道固定值按顺序进行存储,便于数据产生单元读取。

如图3所示,数据包接收时保证固定值RAM和通道参数RAM读无效。当完成一次接收后,将写使能置零并保持写地址不变,同时反馈给通道配置与数据产生控制单元一个写完成标志flag。假设通道参数RAM中灰色部分为固定值参数,则固定值RAM中两个地址对应1个通道。为防止地址溢出,当写地址达到最大时,保持写地址最大,不执行加1操作。

2.3 多通道配置

各通道数据能够正确输出的前提是写完成标志flag=’1’,且读数据ROM或固定值RAM时通道参数已准备好。取数据之前,先按地址顺序访问参数RAM,判断出对应的波形。数据产生单元先输出帧头(EB 90或9A BC B5 2C),之后根据波形参数从对应的波形ROM中取出相应的数据。当输出完一个副帧长度数据后,开始下一副帧的输出。如果字长为16位,则每一帧需从每个波形ROM或固定值RAM中顺序读出2个数据,即每条通道由2个8位数据组成。字长为8位时,读取波形ROM高8位的数据或读取固定值RAM中的低8位固定数。图4是多通道配置的基本时序图。

多通道参数可配置主要是利用RAM可读写和ROM只读的特性来实现的,当参数或固定值写完之后,使写无效,之后读取参数和固定值时,将固定值RAM和通道参数RAM作为ROM进行循环读操作。此时,这两个RAM相当于ROM。

3 试验结果与性能验证

为了验证设计的PCM信号源的功能及其特性,将对应的PCM解码和传输卡插入背板,并将其数据输入与信号源的输出相连进行实验。PCM信号源产生的PCM串行码流解码后传送到计算机,通过计算机软件进行数据分析、波形显示和全帧显示,从而验证设计的准确性和可靠性。图5是测试多通道输出可调的PCM信号源时计算机记录和存储的一段数据,此时下发的配置参数为:副帧长度(通道数)为100,帧头为EB90,副帧帧数(行数)为10。图6为100通道16位字长时的一段数据,图7为1024通道8位字长、帧头为9A BC B5 2C的一段数据,图示中14 6F和65 43 4A D3为副帧帧结束的帧头。

可配置的通道数大小与FPGA内定义的p_max(副帧长度)信号有关,在本设计中p_max为10位,通道参数_RAM深度为1K,并且支持每个通道16位数据输出。通过多次进行不同设置的实验和计算机的分析,验证了所设计的多通道可调PCM信号源的正确性和可靠性。

4 结论

本文设计了一种多通道输出波形可调的PCM信号源,该信号源在设计中充分利用了FPGA内部的RAM和ROM逻辑资源及其特点。详细介绍了多通道可配置实现的协议及其软件设计方法,该设计已能够实现高达1 024个通道参数的配置,支持每条通道8位或16位的数据输出,码率范围为1 Mb/s~10 Mb/s。这种设计方法使得其在复杂多样化信号源、多通道可配置设计和PCM模拟应用中具有很高的应用价值和参考价值。

参考文献

[1] 张彦军,刘龙飞,刘薇.基于FPGA的通用PCM测试仪的设计[J].火力与指挥控制,2013,38(1):145-148.

[2] 高培先,乔东峰.脉冲编码调制模拟器设计[J].计算机测量与控制,2006,14(12):1700-1703.

[3] 杨聪伟.通用遥测信号源设计[J].航天器工程,2008,17(3):67-70.

[4] 冯文全,张晓林,蒋乐.内嵌高斯白噪声模块的可编程卫星信号模拟源[J].航空学报,2006,27(6):1189-1193.

[5] 任勇峰,秦丽,张斌珍.高速PCM码信号源及其解码电路的设计[J].测试技术学报,2001,15(2):71-74.

[6] 王冰,靳学明.LVDS技术及其在多信道高速数据传输中的应用[J].电子技术应用,2003,29(3):55-57.

[7] 崔中华,熊继军,沈三民.基于LVDS技术的实时图像测试装置的设计[J].电子技术应用,2010(4):84-86.

相关推荐

Linux ntp时钟同步问题(linux ntp同步命令)

有时候,操作系统会报linux的ntp时钟错误。从时钟源同步时间超时。我查看了一下ntp的时钟源,发现执行ntpq-p显示超时。执行nslookup时钟服务器域名,发现可以正常解析。执行了n...

linux服务器同步利器Rsync全介绍(付脚本)

1、认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之间的文件...

如何使用Rsync同步两个网站服务器的内容

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。如需学习视频,请复制以下信息到手机浏览器或电脑浏览器上:zc...

Linux TB级小文件同步备份解决方案

在某些电子档案存储的业务系统下,按照业务场景要求,需要将产生的所有电子影像资料永久存储,并支持备份;因为“钞能力”等原因,一般备份存储只有一个节点(即:一个备份存储服务器);这样就要求研发工程师,不...

CentOS7下使用Lsyncd实现文件实时同步

Lsyncd简单介绍Lsyncd使用文件系统事件接口(inotify或fsevents)来监视本地文件和目录的更改。Lsyncd在几秒钟内将这些文件事件整理核对后,然后生成一个或多个进程以将更...

如何手动同步Linux系统时间并与互联网时间保持同步?

在Linux系统中,正确的时间同步对于许多任务都是至关重要的。一些关键应用程序可能需要准确的时间戳才能正常工作,而一些安全功能也需要确保所有服务器的时间都是准确的。NTP服务可以自动同步系统时间和互...

Linux服务器Rsync定时同步一键化配置指南

1、主从服务器同时安装rsyncopenssh-clientaptupdate&&aptinstall-yrsyncopenssh-client2、主服务器安装好后输入以下命令生成密钥...

Linux系统如何使用NTPDATE命令设置时间同步

简介:咱们在使用Linux系统的时候,常常能发现用了一阵子之后,Linux系统的时间就对不上了。已经知道的情况是,安装Linux的时候选的时区是Asia/Shanghai,可这系统运行了一...

开源的Linux文件同步工具有哪些?(linux 文件夹 同步)

Linux系统之间经常需要文件同步,一个好的文件同步工具省时省力,这里介绍几款开源的Linux文件同步工具1.rsync:rsync是Linux上一个功能强大的命令行工具,可以在不同的服务器之间同...

Linux 系统使用 rsync + inotify 实现文件实时同步

Linux系统使用rsync+inotify实现文件实时同步简介inotify监控文件的变化后通知rsync进行文件的同步#配置免密登录ssh-keygen-trsaca...

Linux 远程数据同步工具详解(linux远程同步命令)

一、简介1认识Rsync(remotesynchronize)是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。Rsync使用所谓的“Rsync算法”来使本地和远程两个主机之...

构建基于 Linux 的 NTP 时间同步集群与时间安全防护实战指南

一、为什么时间同步对系统如此重要?在分布式系统、数据库复制、消息队列、审计日志、安全认证(如Kerberos)、容器编排等场景中,系统时间一致性是保障正确性与安全性的基础。一旦服务器间时间漂移,可能...

每日Linux学习:同步备份工具 rsync

rsync是一个用于高效同步文件和目录的工具。它通过仅传输变化的部分(增量传输)来节省时间和带宽,支持本地同步、远程同步(通过SSH),还能保留文件原有权限、时间戳等属性。本文通过几个常用的实例来...

Chromixium OS 1.0发布 基于Ubuntu发行版

Chromixium项目宣布chromixiumOS1发布,一款基于Ubuntu的Linux分支,chromixiumOS试图重新打造一款外观和感觉与ChromeOS相似的完...

iOS8.0.X~iOS8.1完美越狱!盘古团队出品

【巴士速递·移动情报站】最新消息,iOS8.1越狱了!!此次越狱依旧是iOS7时代我国的大神盘古团队带来的,而该次越狱支持最新的iPhone6、iPhone6Plus、iPadAir2和iPad...