一种基于RS485的高精度对时方法与流程

文档序号:23068708发布日期:2020-11-25 18:49阅读:1087来源:国知局
一种基于RS485的高精度对时方法与流程

本发明涉及电力设备对时技术领域,尤其涉及一种基于rs485的高精度对时方法。



背景技术:

目前,电力设备的对时方法主要有:以太网对时、irig-b对时、gps对时和普通rs485对时方法。

以太网ntp对时:优点是时钟精度可以达到毫秒级,无需额外硬件支持,缺点是不支持以太网的简单设备无法实现,且时间精度与设备处理器的处理速度有很大相关性,精度无法保证。

以太网ieee1588协议对时:优点是时钟精度高,最高可达100纳秒,缺点是需要支持ieee1588的硬件接口电路。

irig-b(简称b码对时):优点是对时精度高,可以通过ttl和rs422逻辑电平传输,主要缺点是需配置专用对时通道,对于简单设备也不太适合。

gps对时:优点是对时精度高,对时逻辑简单,主要缺点是需要设备配置gps模块电路,且配置的天线需要处于空旷的位置,成本高,安装复杂,安装位置有限制。

普通rs485对时:通过发送包含时间信息的报文对设备进行对时,优点是成本低,缺点是对时精度差,一般能达到秒级。



技术实现要素:

本发明提出了一种基于rs485的高精度对时方法,其目的是:克服现有技术高精度对时成本高且不通用、低精度对时无法满足对时要求的问题。

本发明技术方案如下:

一种基于rs485的高精度对时方法,用于保持对时主设备及被对时设备之间时间同步,其步骤为:

步骤1、对时主设备通过rs485向被对时设备发送第一对时报文进行秒级对时,所述第一对时报文包含对时主设备的秒级绝对时间;

步骤2、被对时设备接收到第一对时报文并解析,将解析出的秒级绝对时间写入实时时钟,并开启被对时设备内部实时时钟的秒中断输出,同时发送第一对时响应报文给对时主设备;

步骤3、被对时设备配置好定时器,每次发生实时时钟的秒事件时执行毫秒定时器清零,定时器中保存毫秒信息;将实时时钟的秒级时间与定时器的毫秒级时间组合成被对时设备的毫秒级的待校正时间;

步骤4、对时主设备接收到被对时设备的第一对时响应报文后,通过rs485向被对时设备发送第二对时报文进行毫秒级对时,所述第二对时报文包含绝对时间时钟沿以及与该时钟沿对应的毫秒级绝对时间;

被对时设备接收第二对时报文并解析出毫秒级绝对时间,并得到绝对时间时钟沿对应的待校正时间,将毫秒级绝对时间与该待校正时间之间的差值作为校正值,并向对时主设备发送第二对时响应报文;被对时设备使用该校正值对待校正时间进行校正;

步骤5、对时主设备接收到被对时设备的第二对时响应报文后,对时操作完成。

进一步地,步骤4中发送第二对时报文的方式为:对时主设备发送第二对时报文的报头,然后对时主设备的cpu将rs485的串口发送引脚配置为通用输出功能且保持高电平,获取绝对时间的时钟沿并记录此时的毫秒级绝对时间,同时通过串口发送引脚输出低电平脉冲,然后再将该引脚转换为串口发送功能发送剩余报文,剩余报文内容包括所述毫秒级绝对时间。

被对时设备在接收到第二对时报文的报头后,被对时设备的cpu将rs485的串口接收引脚配置为通用输入功能,关闭中断后通过轮询的方式查询该引脚产生的跳变沿,在跳变沿发生时记录当前的待校正时间,在检测到脉冲结束后将该引脚转换为串口接收功能以接收剩余报文,收到报文并解析出毫秒级绝对时间后,计算所述校正值。

进一步地,对时主设备通过gps对时、以太网ieee1588协议对时或irig-b协议对时获取绝对时间。

进一步地,对时主设备的cpu通过输入端口或者内部寄存器的标志位访问到绝对时间秒或者毫秒的跳变。

进一步地,被对时设备的cpu通过输入端口或者内部寄存器的标志位访问实时时钟电路秒的跳变。

进一步地,对时主设备和被对时设备的cpu寄存器或输入端口访问速度比目标对时精度高一个数量级。

相对于现有技术,本发明具有以下有益效果:(1)对时主设备与被对时设备通过获取绝对时间时钟沿、改变rs485引脚配置及手动拉低电平的方法实现了跳变沿法对时,提高了对时精度,且无需额外增加专用对时电路,通用性高,成本低;(2)被对时设备的硬件层面无需做改动,已有产品可通过升级软件的方法实现高精度对时,兼容老旧设备;(3)本发明还可进一步通过调整rs485硬件电路信号的传输延时,实现更高精度的对时。

附图说明

图1为本发明的流程图;

图2为本发明的实施例的结构示意图。

具体实施方式

下面结合附图详细说明本发明的技术方案:

图2为本发明实施例的结构示意图,对时主设备和被对时设备通过rs485总线相连接。

所述对时主设备包括带天线的gps电路、cpu(型号为stm32f407)和rs485收发电路(驱动芯片型号为thvd1500)。所述gps电路的串口与cpu的串口相连接,用于cpu读取秒级绝对时间,gps电路的秒脉冲信号直接接入cpu的输入端口,用于cpu获取秒的跳变;rs485收发电路的发送接收端口与cpu相连。

所述被对时设备包括实时时钟电路(芯片型号为rx8025t)、cpu(型号为stm32f407)和rs485收发电路(驱动芯片型号为thvd1500)。所述实时时钟电路通过i2c通信接口与cpu相连,cpu可通过该接口获取当前时间信息,实时时钟芯片通过秒中断引脚通知cpu秒跳变时刻;rs485收发电路的发送接收端口与cpu相连。

所述对时主设备与被对时设备的cpu运行主频为168mhz,输入输出端口访问速度高达84mhz;rs485差分信号通过差分总线引出至设备外部,差分信号与cpu发出的信号之间延时小于350纳秒。所述实时时钟芯片的守时精度常温下高达3.8ppm(对应一天最多相差0.3秒)。所述rs485总线,常见的铜导线电信号传输速率一般大于200000km/s,对于2000米的485总线,传输延迟小于10us。

如图1,本发明所述的对时方法包括如下步骤:

步骤1:对时主设备通过rs485向被对时设备发送第一对时报文进行秒级对时,所述第一对时报文包含对时主设备的秒级绝对时间,用于被对时设备的cpu校正其内部的实时时钟,将对时误差限制在1秒以内。其中,对时主设备的秒级绝对时间通过如下方式获取:在确认gps接收信号强度满足条件时,对时主设备的cpu通过串口读取gps当前时间,最小单位精确到秒。

步骤2:被对时设备接收到第一对时报文并解析,通过i2c接口将解析出的秒级绝对时间写入实时时钟芯片rx8025t,并开启rx8025t的秒中断输出,同时发送第一对时响应报文给对时主设备。

步骤3:被对时设备配置好定时器,每次发生实时时钟的秒事件时执行毫秒定时器清零,定时器中保存毫秒信息;将实时时钟的秒级时间与定时器的毫秒级时间组合成被对时设备的毫秒级的待校正时间。

步骤4:对时主设备接收到被对时设备的第一对时响应报文后,通过rs485向被对时设备发送第二对时报文进行毫秒级对时,所述第二对时报文包含绝对时间时钟沿以及与该时钟沿对应的毫秒级绝对时间。具体发送方式为:对时主设备发送第二对时报文的报头,然后对时主设备的cpu将rs485的串口发送引脚配置为通用输出功能且保持高电平,获取绝对时间的时钟沿并记录此时的毫秒级时间作为毫秒级绝对时间,同时将rs485的发送引脚拉低,拉低适当时间(小于对应串口波特率的一个字节时长)后,拉高该引脚,随后将该引脚转换为串口发送功能;一定时间延迟(给被对时设备一定的准备时间)后,将第二对时剩余报文数据通过rs485发送给被对时设备,剩余报文内容包括所述毫秒级绝对时间。具体地,对时主设备可通过如下方式获取绝对时间的时钟沿:(1)cpu轮询gps的秒脉冲端口电平,获取端口电平发生跳变的时刻;(2)cpu监测具有ieee1588对时功能的物理层芯片的ptp时钟沿并通过mii或rmii接口读出时间戳;(3)cpu对irig-b协议进行解码提取出时钟沿,并解析对时报文的时间戳。

被对时设备在接收到第二对时报文的报头并解析成功后,被对时设备的cpu将rs485的串口接收引脚配置为通用输入功能,关闭中断后通过轮询的方式查询该引脚产生的跳变沿,在跳变沿发生时记录当前时刻作为待校正时间,在检测到脉冲结束后将该引脚转换为串口接收功能以接收剩余报文,收到报文并解析出毫秒级绝对时间,将毫秒级绝对时间与该待校正时间之间的差值作为校正值,并向对时主设备发送第二对时响应报文;被对时设备使用该校正值对待校正时间进行校正。

步骤5:对时主设备接收到被对时设备的第二对时响应报文后,对时操作完成。

此时被对时设备的时间精度达到毫秒级,被对时设备的实时时间,由实时时钟芯片的秒级时间、定时器的毫秒级时间和校正时间组成,三者之和作为校正后的时间。

通过上述的对时方法,即可实现被对时设备的毫秒级对时,该方法可通过扩展规约的形式实现,不影响正常规约的通信功能。本发明通过rs485进行跳变沿法对时,误差精度要比通过包含绝对时间信息的报文数据对时的精度高很多,且无需额外增加专用对时电路,满足通用性高、成本低的要求;被对时设备的硬件层面无需做改动,已有产品可通过升级软件的方法实现高精度对时,兼容老旧设备。

另外可通过控制整个通信回路的硬件延时、提高cpu运行主频等方法,提高对时精度至亚毫秒甚至微秒级。延时包括印制板线路的延时、485差分线上的延时、485驱动器上的延时,通过优化整个信号传输通道的延时(如缩短485线长度、使用更高速率的485驱动器等)即可达到更高精度的对时。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1