文章编号:1671-4598(2017)05-0021-05 DOI:10.16526/j. cnki.11-4762/tp.2017.05.007

中图分类号: TN911.71

文献标识码:A

# 分布式测试系统时间同步技术的研究

## 牟宗磊.宋

(北京理工大学 仿生机器人与系统教育部重点实验室,北京 100081)

摘要: 分布式测试系统是集计算机控制技术、网络通信技术与多传感器信息融合技术于一体的复杂测控系统; 与独立测试系统不同, 在网络化分布式测试系统中,各测试装置需按通信协议与网关节点通信以完成相应的测试;不同测试装置在接收网关节点发出的信号时, 由于传输距离不同会引起时延差;如果系统中的各个测试装置不具备统一的时间基准,那么得到的测试数据因为时钟差异将无法反映出 信息的真实情况;因此,整个网络中所有测试装置需要保持时间同步;针对分布式测试系统时间同步的需求,对信号传输过程中的时延 问题进行了研究,提出了一种基于 FPGA 的时延测量方法,对这种软硬件结合时延测量方法的实现原理进行了详细阐述,并进行了功能 仿真及试验验证。

关键词:分布式测试系统;时延差;时间同步;时延测量;功能仿真

## Research on Time Synchronization Technology in Distributed Test System

## Mou Zonglei, Song Ping

(Ministerial Key Laboratory of Biomimetic Robots and System, Beijing Institute of Technology, Beijing 100081, China)

Abstract: The distributed test system is a complicated measuring and controlling system based on computer controlling technology, network communicating technology and sensor technology. Different from the independent test system, in the network distributed test system, every test device need to communicate with the gateway node according to the communicating treaty to fulfill corresponding test. Different transmission distances will lead to delay difference when the gateway node has sent signals to different test devices. The test data can not reflect the true information for the reason of clock difference unless the test devices of the system own a unified time base. So all the devices in the whole test network should keep time synchronization. In the view of the requirement of time synchronization, the delay of signal transmission in the test system is studied, and also, a time delay measuring method based on FPGA is presented. The realization principle of delay measuring method from software and hardware is expounded in detail, and the function simulation and experiment verification are carried out. Keywords: distributed test system; delay difference; time synchronization; delay measurement; function simulation

#### 0 引言

分布式测试系统通常由分布在测试区域内的大量测试节点 构成,节点之间按相关协议共同协作完成复杂的测试任务[1]。 分布式测试系统的一个核心要求是各数据采集装置可以实现高 精度同步采集。在分布式测试系统中,为保证各个测试装置具 有统一的时间基准,一般只采用一个主节点时钟,其它从节点 时钟通过直接或者间接的方式同步于主节点时钟。当前,基于 硬件时间戳实现的高精度时间同步主要有两种方式,一种是基 于 GPS 的时间同步,另一种是基于高精度时间测量芯片 TDC -GP2 的时间同步<sup>[2]</sup>。这两种时间同步方式具有精度高的优 点,但应用成本高,需要在每个测试设备安装昂贵的芯片组 件。另外, GPS 模块对周围环境依赖性强, 不适用于复杂的 测试环境。

基于上述原因,本文对分布式测试系统的拓扑结构进行了 研究,在考虑线性拓扑结构网络中中间节点对时间同步精度影 响的情况下提出了一种适用于分布式测试系统的时间同步方 法。本方法实现简单、通用性强,在提供与 GPS 相同时间同 步精度的情况下,无需在测试装置上安装专用时钟芯片,只需 对主从节点间的信号传输进行时延测量,就可以统一各个数据 采集装置的时间基准,进而实现时间同步。

## 1 分布式测试系统组织体系

在分布式测试系统中,测控终端主要通过网关节点来实现 对分布在测试区域内能独立完成测试任务的各个数据采集装置 的集中控制,从而保证各个数据采集装置能够协调统一地完成 测试任务。待测试结束后,数据采集装置在测控终端和网关节 点的控制下通过无线或者有线传输的方式把采样数据回传给上 位机,进而对数据进行实时处理或者后续处理[3]。本文所提及 的基于光纤传输的分布式测试系统组织体系主要包括测控终 端、网关节点和数据采集装置三部分,如图1。



图 1 分布式测试系统组织体系简图

#### 1.1 测控终端

测控终端主要通过网络接收远程客户端的测试命令,同时

收稿日期:2016-11-29; 修回日期:2016-12-19。

作者简介:牟宗磊(1985-),男,山东日照人,博士研究生,主要从事 传感与机电控制方向的研究。

以有线传输的方式向网关节点发送测试命令和相关的配置参数,并且还能响应客户端处理与分析数据的请求,对网关节点 回传的数据做后续处理分析。

#### 1.2 网关节点

网关节点收到测控终端的测试命令之后,首先按通信协议 对命令完成译码,然后执行后续的相应工作程序。网关节点不 仅是整个系统的事件响应与调度中心,也是数据汇聚与交换中 心。在这样的组织体系中,网关节点不仅拥有同时管理与挂接 若干条测试链路的功能,而且能够合理且高效地将测控终端的 请求分配给对应链路上的数据采集装置,进而更高效地实现多 用户并发性测试请求和测试任务的协调性。

#### 1.3 数据采集装置

每个布设在测试区域内的数据采集装置都可作为一个微型 的测试系统。数据采集装置通常包含有传感器、信号调理放大 电路、电源模块、数据采集与存储模块、数据传输模块、核心 控制器等部件。应用于测试现场的数据采集装置采用时间同步 技术使得所有的测试节点在某些关键时刻能够协调完成采集数 据的任务,在短时间内完成用户的各种测试需求,并且快速释 放系统资源,以便再次进行测试响应。

#### 2 基于线性拓扑结构的时延测量

现有的分布式测试系统按通信媒介不同主要分为基于无线 的分布式测试系统和基于有线的分布式测试系统,网络拓扑结 构主要分为星型、树形、环形、总线型等拓扑结构。基于有线 传输方式的传输媒介主要有电缆和光纤两种,而基于光纤传输 的分布式测试系统因具有数据传输速度快、抗干扰强力强、安 全性能高、可靠度高等优点而广泛应用于各种复杂的测试环 境。本文所提及的分布式测试系统采用光纤传输模式。

在基于有线传输的分布式测试系统中,为提高时间同步精 度,一般只选用一个主节点时钟,其余从节点时钟通过直接或 者间接的方式同步于主节点时钟,协同完成分布式测试任务。 由于线性拓扑结构组网方式简单、易控制,被广泛应用于各种 有线分布式测试系统中。在线性拓扑结构中,部分从节点时钟 无法直接和主节点通信来实现时间同步,需要经过多个中间节 点的消息包转发才能逐级实现时间同步,如图 2。在消息包经 过多个中间节点转发的过程中,传输时间受主、从节点时钟精 度的共同影响误差较大,而且这种拓扑结构累积的时间误差将 会随着中间节点数量的增加而增大,导致时间同步精度显著降 低。在很多分布式测试系统中,我们不关注各个数据采集装置 开始采集的绝对时间,而只需准确获知各个采集装置相对于主 时钟的相对时间就可以统一时间基准,完成数据的后续处理工 作。因此,在组建好主从式线性网络拓扑网络结构后,采用相 关算法选择时间精度最高的主时钟设备,同时准确测得信号传 输过程中各个数据采集装置相对于主时钟的时延值,为网络中 的各个测试节点统一时间基准、实现时间同步,协作完成测试 任务提供了保障[4]。

#### 2.1 时延测量原理

基于对系统时延测量速度、功耗、体积及抗干扰能力等方 面的考虑,系统在具体实现上采用了 FPGA 作为主控芯片, 在每个测试装置上采用成对的光纤收发一体模块进行通信,各 个数据采集装置之间采用光纤进行串联通信,组成线性拓扑网 络结构。基于 FPGA 的时延测量原理图如图 3 所示,即将译



图 2 线性拓扑网络主从时钟结构

码控制模块、时钟控制模块、数据锁存模块以及数据传输模块 全部集中在 FPGA 芯片上,使各部分性能达到最佳状态<sup>[5]</sup>。



图 3 基于 FPGA 的时延测量原理图

FPGA 是整个时延测量系统的控制核心,选用 Altera 公司 的 Cyclone II 型系列 FPGA。具体测试时,启动信号和停止信 号首先要经过信号调理电路进行预处理,然后输送到 FPGA 数据锁存模块中进行测量。FPGA 内部具有基准时间逻辑电 路,这样就能捕获计数器当前的计数值,此值会被 FPGA 内 部的 RAM 存储器进行存储,然后经过数据传输模块把测量结 果传输给网关节点,网关节点汇聚各个测试装置的时延值后通 过光纤上传给测控终端。

2.1.1 译码控制模块

经过调理电路调理后的启动信号和停止信号分别作为待测信 号传输时延值的开始计数信号和停止计数信号,译码控制模块的 功能是将测控终端的命令最终转化为各种使能信号及读写信号, 从而完成对各相应寄存器的读写控制,进而实现对测试系统中各 个数据采集装置功能的控制。该逻辑功能的完成需要底层的硬件 驱动程序及相应的通信协议的密切配合,本系统根据自己定义的 硬件通信协议实现测控终端对各个功能模块的控制<sup>[6]</sup>。

2.1.2 时钟控制模块

时钟控制模块主要由外部温补晶振和 FPGA 内部 PLL (锁 相环)构成。测量过程中,充分利用 FPGA 内部丰富的时钟资 源和存储资源,借助 PLL 把板级的时钟进行倍频处理,从而可 以产生一个高频率、低抖动、稳定度高的基准参考时钟,从而 实现减小量化误差的目的。现场应用时可以根据测试需求对基 准时钟进行倍频或者移相,满足不同测试精度的需求。

#### 2.1.3 数据锁存模块

时延值的测量在 FPGA 内部转化为启动与停止两个脉冲 信号上升沿之间时间间隔的测量,被测时间间隔主要有以下三 部分组成:①采用脉冲计数法得到的基准时钟周期的整数倍 NT;②启动信号上升沿与毗邻的基准时钟上升沿之间的时钟 偏差 $\Delta T_1$ ;③截止信号上升沿与毗邻的基准时钟上升沿之间的 时钟偏差 $\Delta T_2$ 。设被测的时间间隔为 $\Delta T$ ,则有:

$$\Delta T = NT + \Delta T_1 - \Delta T_2 \tag{1}$$

这种时延测量方法测量的是信号在网关节点和数据采集装置之间传输一个回路的时延差,在不考虑光纤色散和时钟偏移的情况下,单向传输的时延差应为:

$$\overline{\Delta T} = \frac{NT + \Delta T_1 - \Delta T_2}{2} \tag{2}$$

N 次测量的平均时延值为:

$$\overline{\Delta T} = \frac{NT + \Delta T_1 - \Delta T_2}{2N} \tag{3}$$

式中,T为所选择主时钟的固有时钟周期。为了得到稳定的时 延测量数据,计数值在输出前需经过锁存器锁存缓冲,利用状 态机不同状态的跳转把高精度计数器中的数据赋值到数据锁存 寄存器中进行锁存。

2.1.4 数据传输模块

数据传输模块的作用主要是把所测时延值上传到网关节 点,具体实现过程为:把寄存器中的时延值写入 FIFO (先进 先出)中进行缓存,当接收到测控终端的数据上传指令时,通 过 Nios ii (软核处理器)中的 UART (通用异步收发传输器) 把 FIFO 中的时延测量值发送到网关节点,供上位机读取。

### 3 Modelsim 仿真及误差分析

为验证基于 FPGA 的时延测量算法各功能模块的正确性, 借助 Modelsim 软件对 FPGA 内部的状态机及各个模块进行了 功能仿真验证<sup>[7]</sup>。图 4 所示为时延测量算法的状态机结构图, 仿真的目的主要是验证时延测量算法所涉及的各个状态机能否 按相应条件正常跳转,以及能否实现高精度计数及数据锁存等 功能。为减小仿真时的计算运算量,缩短仿真程序执行时间, 对仿真程序进行了优化,只进行最必要部分的功能仿真,仿真 时所采用时钟频率 f = 100 MHz。



图 5~6 所示为 Modelsim 中截取的各个状态机跳转的时序 图。系统上电后状态机进入初始化状态(Idle),复位(Rst\_ n)完毕后进入开始状态(Start),等待时延测量指令的到来。 网关节点按照硬件通信协议对测试系统中的各个测试装置依次 进行时延测量,测试装置收到网关节点的指令后按照通信协议 对命令进行解析,只有当地址和命令分别与测试装置的节点号 和时延测量功能完全匹配时,测试装置才会响应时延测量。在 此,为简化仿真程序,采用地址(addr)匹配来进行时延测量 功能的仿真,如图 5 所示,当 addr 为该节点地址(el)时, 地址匹配成功,在下一个时钟上升沿,系统接收到时延测量启 动信号,状态机进入开始计数状态(Wait),等待时延结束信 号(ack1)的到来。为模拟信号在传输链路上的时间延迟,在 仿真程序中采用了 1490ns 的延时,即 1490ns 后计数模块接收 到结束信号,计数器停止计数,状态机跳转到数据锁存状态 (Waitt),把16位 count 寄存器中的数据锁存到16位 count\_ out 寄存器中等待输出。数据锁存完毕后,在下一个时钟周 期,状态机进入停止状态(Stop),本次时延测试结束,延时 1ms 后状态机自动进入开始状态,等待下次触发信号的到来进 行下一次时延测量。







从以上的功能仿真结果中可以看出,本模块的各部分功能 设计逻辑正确,状态机跳转正常,可以完成时延测量的功能。 在图 5~6中的功能仿真中,启动、停止信号的上升沿与时钟上 升沿严格同步,没有相位偏移。但是在真实工作状态下,晶振 受温度、老化、振动等因素的影响可能会发生频率的微变,导 致状态机跳转信号可能与时钟上升沿存在相位偏差。为了更加 真实地模仿实际工作情况,在 Modelsim 中我们对启动信号延迟 5 ns 于时钟上升沿、停止信号正常到达和启动信号正常到达、 停止信号延迟 5 ns 于时钟上升沿这两种情况进行了仿真。

从图 7~9 中的功能仿真中可以看出,当启动信号、停止 信号的上升沿与时钟的上升沿存在时钟相位偏差时,可能会导 致计数器中的数值存在±1个计数误差,导致所测时延值存在 一定误差。



#### 固广 开始值 5 师 加 1 时 仍 工 )

#### 4 试验验证及数据分析

为了验证整个时延测量电路精确度和系统稳定性,在线性 网络拓扑结构上的数据采集装置和网关节点之间进行了时延测



24

量,随机选择一条链路上的三个数据采集装置作为测试节点。 时延测量示意图如图 10 所示,其中网关节点作为1号节点,离 网关最近的测试装置作为2号节点,后面依次为3号节点和4 号节点,节点之间采用光纤进行连接,四个节点等间距布设。



时延测量启动信号由1号节点上的 FPGA 提供, 启动信 号沿光纤传输链路到达各测试节点,节点响应完毕后经过光纤 收发一体模块和光纤将停止信号送回 1 号节点上的 FPGA 中 进行测量。测得时延值锁存后通过串口发送到上位机中,在上 位机中借助 MATLAB 软件对测得的时延值进行分析<sup>[8]</sup>。在 115200 波特率下分别以 100 MHz、200 MHz 时钟频率测量 1 ~2 号节点 100 组时延值, 1~3 号节点 100 组时延值, 1~4 号节点 100 组时延值。借助 MATLAB 软件分别对测得的 100 组随机时延值数据进行分析, 画出不同时钟频率下所测时延值 的动态分布图,如图 11~12。

由图 11~12 可以看出,线性拓扑结构中 1~2 节点时延值 的总体均值为65 ns、1~3节点时延值的总体均值为130 ns,1 ~4节点时延值的总体均值为 195 ns,两节点间的时延测量误 差集中分布在某些值附近,误差波动随着测量晶振频率的提高 逐渐缩小,200 MHz 时误差波动范围最小误差约为 5 ns;时 延测量值随节点之间距离的增加呈线性增长趋势,没有随节点 之间的距离和测量次数的增加而呈发散趋势,证明这种时延测 量方式稳定可靠,可以满足分布式测试系统时间同步的要求。

#### 提高时延测量精度的措施 5

由仿真和试验实测数据看以看出,利用本测试方法实现时 间同步存在一定的测量误差,为进一步提高测试精度,降低误 差对时间同步带来的影响,主要从以下两个方面采取了措施以 提高时间同步精度。





图 12 200 MHz 时延值分布图

#### 5.1 多次测量求平均时延值法减小时延测量误差

单次时延测量存在一定的随机误差,多次测量求平均值的 方法是常用的提高测量精度的方法<sup>[9]</sup>。设测量次数为 N,第 i 次所测时延值结果为t<sub>i</sub>,时延测量是正态分布的平稳随机过 程,可用下式计算时延偏差的标准方差:

$$\sigma^{2} = \lim_{N \to \infty} \frac{1}{(N-1)^{2}} \sum_{i=1}^{N} (t_{i} - \bar{t})^{2}$$
(4)

其中,平均时延值:

$$\bar{t} = \lim_{N \to \infty} \frac{1}{N} \sum_{i=1}^{N} t_i \tag{5}$$

因此,采取多次测量求平均时延值的方法可将时延测量误 差减小到单次测量的 一倍,是一种行之有效的减小时间同步 误差的方法。

#### 5.2 洗用高精度晶振提高时延测量精度

在时延测量系统中,高精度的时钟频率是影响测量精度的 重要因素之一。FPGA 内部高精度计数器的基准信号源是由系 统板载石英晶振提供的,因此,进行高精度的时延测量,选择 一个频率性能稳定的晶振是至关重要的。衡量晶振性能的主要 参数有标称频率、频率温度稳定度、短稳、老化率等[10]。频 率温度稳定度是指晶振在正常工作的温度范围内,晶体输出频 率相对于基准温度的时频率变化值,是关于温度 K 的一个函 数,该值越小表明晶振受温度影响越小,性能越稳定。短稳即 短期频率稳定度,表现为短时间内(一般为毫秒级)晶体频率 值随机平均漂移情况,是关于时间 t 的一个函数。频率短期稳 定度一般通过阿伦方差来表示,即:

$$\sigma_a = \frac{1}{f_0} \sqrt{\frac{\sum_{i=1}^{m} (f_i' - f_i)^2}{2m}}$$
(6)

其中:  $\frac{1}{\epsilon}$  为低频噪声,  $f_i'$  和  $f_i$  分别为连续测量的两个瞬 时频率值,2m为测量次数,m一般取100。从阿伦方差定义 可以看出,标准差越小时短稳性能越好。本时延测量系统采用 的是标称频率 50 MHz 的带温补功能的晶振 (TCXO),频率 温度稳定度好,短稳好,可以有效提高时延测量精度。

#### 6 结论

本文所提及的分布式测试系统主要由测控终端、网关节点 和分布在测试区域内的数据采集装置组成,所提的时延测量技 术适用于分布式测控系统中实现网关节点和数据采集装置之间 的时间同步。本文从实现原理上对这种采用时延测量技术来实 现时间同步的方法给予了详细的阐述,并进行了功能仿真验证 以及试验验证。仿真及试验结论表明: 该测量方法简单、实 用,可以实现信号传输链路的高精度时延测量,是一种行之有 效的时延测量方法,可以准确获得信号传输到各个测试装置的 时延差,进而实现各测试装置的时间同步。该时间同步技术适 用于需要时间同步精度比较高的瞬态类信号分布式测试系统, 尤其适用于一些不能接受高成本时钟同步芯片或者不能接收到 (上接第 20 页)

系统通过 COM 接口进行双向异步信息交互,即 IIDS 系统可 以根据测试诊断情况通过 COM 接口实时搜索查询到 IETM 相 关内容,浏览系统也可以通过 COM 接口启动 IIDS 系统开展 动态故障诊断过程。另外,在测试性分析评估软件(TEAMS/ TADS)和 IIDS 系统之间增加对多信号流模型的导入接口,随 时可以通过接口直接获取模型数据和诊断树、测试一诊断依赖 性关系矩阵 (D矩阵),且不经其它修改即可直接开展静态/动 态故障诊断方法,避免前期所采用的诊断策略数据导入浏览系 统过程,降低复杂性。



图 3 交互式智能诊断系统 (IIDS) 故障推理界面

#### 4 结束语

针对静态故障树方法在舰船电子现场测试诊断中发现的问 题, 立足于 TEAMS 多信号流模型数据结构, 本文提出了基于 D-矩阵和 ROLLOUT 信息启发搜索算法的故障诊断策略树动 态生成方法,并开发了交互式智能测试系统 (IIDS) 软件平 台,提高了装备故障诊断的效率、准确性以及测试的通用性、 GPS 信号的复杂测试环境。

#### 参考文献:

- [1] 王 爽, 胡冬旭. 基于 FPGA 的分布式测控装置设计与应用 [J]. 国外电子测量技术,2015 (10):11-13.
- [2] 赵德平,韩建平. 基于 TDC\_GP2 的高精度时间差测量的关键技术 研究 [J]. 材料与冶金学报, 2014, 4: 016.
- [3] 支超有,姜丰收. 混合总线分布式测试技术研究及应用 [J]. 计算 机测量与控制,2012,20 (12):3139-3140.
- [4] 沈 艳. 分布式测试系统协作理论及其通信平台实时性研究「J]. 电子科技大学,2004,6.
- [5] 逄锦昊,苏 涛,杨 涛,等. 基于 FPGA 的多路高速数据传输同 步时延测量系统 [J]. 电子器件, 2015 (02): 447-451.
- [6] 王首浩, 仲 悦, 张 巍, 等. 一种用于分布式控制的光纤通信协 议设计与仿真「J]. 计算机测量与控制, 2014, 9: 101.
- 「7〕徐盛晨. 基于 FPGA 的实时数据采集与传输系统的设计 [D]. 北 京:北京邮电大学,2014.
- [8] 马文起, 耿虎军, 郭肃丽, 等. 一种基于 FPGA 和 Matlab 的时延测 量方法「J]. 无线电工程, 2014, 44 (11): 38-40.
- [9] 庄晓燕. 分布式测试系统时钟网络结构与同步算法研究 [D]. 成 都: 电子科技大学, 2013.
- [10] 洪 锋,张玉亮,杨博真,等.水下传感器网络时间同步技术综述 [J]. 电子学报, 2012, 41 (5): 960-965.

和灵活性。

但是在诊断推理过程中,故障诊断策略树的生成速度主要 依赖于 D-矩阵的大小和搜索算法的效率。虽然采用的 Rollout 算法效率较高, 但是当模型中故障模块数量和测试数目较 大时,故障推理时间仍然较长。因此,提高算法的搜索速度, 进一步提升故障诊断策略树的生成效率是本文后期需要进一步 关注和研究的重点。

#### 参考文献:

- [1] 林志文, 基于多信号模型的系统测试性分析与评估 [J]. 计算机 测量与控制, 2006, 2 (14): 222-224.
- [2] 何巨模, 林志文, 舰船装备综合测试诊断技术与工程 [M]. 北京: 国防工业出版社, 2013.
- [3] Deb S, Pattitpati K, Raghavan V, et al. A Multi-Signal Flow Graphs: A Novel Approach for System Testability Analysis and Fault Diagnosis [J]. IEEE Aerosp, Electron Syst Mag, 1995, 10 (5): 14-25.
- [4] Somnath Deb, Krishna Pattipati, and Roshan Shrestha, QSI' s Integrated Diagnostic Toolset [A]. Proceedings of the IEEE AU-TOTESTCON [C]. 1997.
- [5] Teams user guide [EB/OL]. Qualtech Systems, 2003, www. teamsQ-SI. com.
- [6] Fang Tu, Krishna R. pattipati, Rollout Strategies for Sequential Fault Diagnosis [J]. IEEE transactions on system, man, and cybernetics, part a: system and humans, 2003, 33 (1): 86-99.
- [7] Krishna R. Pattipati, Mark G. Alexandridis, Application of Heuristic search and Information Theory to sequential Fault Diagnosis [J], IEEE, 1989: 291-296.
- [8] 林志文,马力,基于多信号流模型和 Tomcat 服务器的远程综合诊 断技术 [J]. 计算机测量与控制, 2013, 21 (9): 180-186.
- [9] 杨智勇, 许化龙, 许爱强. 基于多信号模型的故障诊断策略设计 [J]. 计算机测量与控制, 2006, 14 (12): 1616-1619.