基於GPS北斗衛星授時系統和NTP網路授時伺服器的設計與開發

来源:https://www.cnblogs.com/yfcs999/archive/2020/01/08/99poikdkekdidsll.html
-Advertisement-
Play Games

準確的時間是天文觀測所必需的。天文望遠鏡在特定時間內的準確指向、CCD曝光時間的控制以及不同波段觀測數據所進行的高精度同步比對等應用需要系統至少有亞毫秒的時間準確度。然而就目前來看,一般的電腦和嵌入式設備所使用的晶體振蕩器的精度為幾個或者幾十個ppm(百萬分之一秒),並且會受溫度漂移的影響,使得每... ...


基於GPS北斗衛星授時系統和NTP網路授時伺服器的設計與開發

安徽京準科技提供@請勿轉載@@ 更多資料請參考—— ahjzsz.com

天文觀測設備對於控制系統的時間準確度有嚴格要求。為此,採用搭建高精度NTP伺服器的方法實現系統校時。基本思路是從NMEA018 3數據中提取時間信息,通過PPS信號來保證高精度。具體實現方法是採用GPS接收模塊G591來構造硬體電路,軟體部分需要NTP伺服器軟體和GPS的正確安裝和配置。對照實驗表明,基於GPS的NTP伺服器校時精度可以達到微秒量級,工作性能穩定而可靠。

0
引言
準確的時間是天文觀測所必需的。天文望遠鏡在特定時間內的準確指向、CCD曝光時間的控制以及不同波段觀測數據所進行的高精度同步比對等應用需要系統至少有亞毫秒的時間準確度。然而就目前來看,一般的電腦和嵌入式設備所使用的晶體振蕩器的精度為幾個或者幾十個ppm(百萬分之一秒),並且會受溫度漂移的影響,使得每天的誤差能夠達到秒級,若再考慮元器件的老化或外界干擾等因素,誤差可能會超過10 s,如果不及時校正,其誤差積累將不可忽視。
網路時間協議NTP(Network Time Protocol)是美國特拉華大學的MILLS David L.教授在1982年提出的,其設計目的是利用互聯網資源傳遞統一和標準的時間。目前,使用GPS信號實現校時的研究工作很多,大多只是通過讀取GPS模塊解碼出的串列數據,提取其中的時間信息來糾正系統時鐘,該過程並不涉及NTP的使用,精度較低,一般為幾十到幾百毫秒。對此,本文充分利用了NTP伺服器軟體對GPS時鐘源的支持,採用串列數據和秒脈衝相結合的方式來校準時間,校時精度大為提高。

1 GPS同步時鐘的校時方式
1.1 GPS介紹
GPS(Global Positioning System,全球定位系統)是20世紀70年代美國研製的新一代衛星導航、授時、定位系統。24顆專用的GPS衛星上都各自帶有原子鐘,能夠全天候向地面廣播精確的UTC標準時間。在許多通用GPS解碼晶元解碼出的數據流中,除了有位置信息,還包含時間信息(年月日時分秒)和PPS(Pulseper Second,秒脈衝信號),PPS標識了時間信息的起點,其精確度可以到微秒量級。
1.2 校時方式介紹
NTP是用來使電腦時間同步化的一種協議,其同步時鐘源不僅僅局限於網路的時間伺服器,還包括時鐘設備,如石英鐘,原子鐘,GPS接收器等。NTP伺服器軟體將這些時鐘源抽象成相應的數據結構,對應於不同的記憶體地址,通過讀取該地址中的信息,進行統計學演算法的處理來同步電腦的時鐘。
使用GPS作為同步時鐘源的校時方案主要有三種:脈衝同步方式、串列同步方式和綜合方式。本文采用的GPSD校時方案是綜合方式。三種方式的對照如表1所示。

 


1.3 基於GPSD的綜合校時
GPSD(GPS Daemon)是一個守護進程軟體,用來處理GPS接收單元解碼出的數據。基於GPSD綜合校時的具體過程如圖1所示。GPS天線接收GPS信號,傳遞給G591晶元進行解碼,每秒輸出NMEA0183協議格式的數據和PPS信號,MAX 232完成電平轉換之後,分別經由串口的RXD和DCD端傳遞給電腦;GPSD軟體經過處理,將準確的時間信息寫到特定記憶體段中;NTP伺服器軟體通過共用記憶體的方式讀取該地址段中的時間信息,進而完成校正系統時鐘的工作。

 


基於GPSD綜合校時方案是一種優勢互補的校時方式。這種方式繼承了NMEA串列校時方式可以獲取時間信息的優勢,同時利用了PPS脈衝校時延時估計誤差小、精度高的特點,是一種簡便有效的校時方案。

2 系統設計實現
2.1 硬體平臺
GPSD綜合校時方案需要的硬體設備分為三個部分:GPS天線、GPS接收器和與GPS接收器連接的電腦,其相應的功能和應用如下:
(1)GPS天線用於接收GPS信號。本文采用的是磁吸式GPS天線,使用時要水平放置,最好置於開闊地,如天窗、窗臺、陽臺等;
(2)GPS接收器由電源、GPS接收和電平轉換三個模塊構成如圖2所示。GPS接收模塊採用JRC(Japan Radio Company)設計的G591晶元,該晶元支持多達210 PRN通道,輸出數據為NMEA0183協議的串列數據,波特率為9 600 b/s,適用於各種相關開發。在本設計中,G591主要用來獲取時間信息和PPS信號,不涉及定位導航;電源模塊採用的是AMS(Advanced Monolithie Systems)設計的AMS1117-3.3晶元,該晶元輸出電壓為3.3 V,最大輸出電流為1 A,用來給G591和MAX232供電;電平轉換模塊主要採用MAXIM公司設計的MAX232晶元,該晶元負責把G591輸出的CMOS電平轉換成RS 232電平,供串口讀取。

 


(3)電腦設備用於處理GPS數據,要求支持串口和網口等設備,以實現GPS數據接收和校時輸出。
硬體平臺搭建好了之後,本文對PPS信號和NMEA0183串列數據進行了相應的調試。對PPS信號的調試採用的是硬體方式,使用示波器來觀察GPS接收器是否有秒脈衝信號輸出,若天線和接收器工作正常,會檢測到PPS端有脈寬為100 ms的秒脈衝輸出;對NMEA數據的調試採用的是軟體方式,使用Windows操作系統自帶的超級終端或Linux操作系統的minicom等工具來讀取串口,檢測數據是否正常,正確的輸出結果是NME A0183串列數據。
若由於天線或氣象原因,G591模塊沒有接收到信號,則不會產生PPS信號,同時NMEA0183語句中的GPRMC語句的標誌位也會變成無效。
2.2 軟體平臺
2.2.1 安裝過程
本文使用的是Ubuntu 11.04操作系統,內核版本是2.6.38;需要的軟體包有setserial,gpsd,gpsd-cli-ents,python-gps,ntp。在終端中使用Ubuntu自帶的apt-get命令安裝這些軟體包,然後分別作出相應的設置:
(1)setserial的版本是2.17,該軟體是用來對串口進行相應的設置。為了能夠讓串口識別PPS信號,要對setserial的配置文件修改。在autoserial.conf中對接收GPS數據的串口添加low_latency關鍵字。
(2)gpsd的版本是2.95。安裝完成後,使用dpkgreconfigure命令要對gpsd重新進行配置,使其能夠開機自動運行,讀取串口數據。此外gpsd的調試方法也十分簡便。如果放在後臺執行,可以通過系統日誌文件查看其工作狀況;gpsd也可以在前臺運行,通過進入調試模式來檢查時間信息和PPS信號的捕獲情況,詳見gpsd的使用說明。
(3)ntp的版本是4.2.6。安裝完成後,要對NTP的配置文件ntp.conf進行修改。NTP伺服器的正確配置決定了最終的時間同步結果。本設計選用的時間伺服器只有GPS時鐘源,具體配置如下:

Linux操作系統從2.6.34版本開始支持PPS中斷源,而本文采用的方案是通過共用記憶體的方式傳遞時間信息,會與PPS中斷源發生衝突,所以要禁止掉內核響應PPS。127.127.28.1對應於NTP定義的一個記憶體段地址,gpsd進程就是通過這個地址向NTP傳遞時間信息。
2.2.2 結果
NTP伺服器安裝後的調試工作可以通過參照系統和NTP的日誌文件,以及查看串口狀態等操作來進行。本文總結了NTP伺服器正常工作的必要條件:正確的配置、可用的網路、有效的GPS信號、沒有其他進程占據GPS時鐘源使用的串口。當NTP伺服器正常工作時,使用其自帶的ntpq程式可以查看NTP的工作狀態,即校時的效果。如果GPS設備正常工作,NTP伺服器幾秒鐘後就能鎖定GPS時鐘源,輸出結果如下所示:



3
測試與分析
3.1 對照實驗
要衡量校時系統的好壞,偏移量(offset)和抖動(jitter)是重要的參考指標。本文為驗證GPS校時的有效性和可行性設計了對照實驗。實驗內容是測試一臺電腦分別採用網路校時、串列校時以及基於GPSD的綜合校時三種方式的校時效果。網路校時採用的伺服器為國家授時中心的NTP伺服器,地址是:210.72.154.44;串列校時只需要向NTP配置文件中添加server 127.127.28.0;
通過編寫shell腳本程式實時記錄偏移量和抖動的情況。shell腳本程式主要功能是每16 s執行一次“ntpq-p”命令,將偏移量和抖動的結果輸出到一個文件。

 


電腦設備通過互聯網與網路時間伺服器進行同步的結果,如圖3所示,實驗時間為24 h。從圖中可以看出經過約7 h的鎖定過程,NTP軟體通過網路時間伺服器將系統時鐘的偏移量從約80 ms穩定到10 ms以下,抖動通常能穩定在20 ms以下,但部分時段也能夠達到50 ms以上。
NTP支持的NMEA串列方式的校時結果如圖4所示,實驗時間為24 h。可以看出,該方案的時鐘偏移量和抖動在幾十毫秒的範圍內變化很快,NTP難以將時鐘穩定到一個更小的範圍。

 


採用基於GPSD綜合方式的校時鎖定過程如圖5所示,實驗時間為8 h。該過程持續了近8 h,時鐘偏移從-18 ms穩定到10μs左右,而抖動從4 ms穩定到10μs以下。

 

採用基於GPSD綜合方式的校時穩定過程如圖6所示,實驗時間為24 h。可以看出,該方案的時鐘偏移和抖動明顯優於前兩種方案,偏移量通常低於30μs,抖動也不超過50μs。這期間,從大約14 h開始偏移量恆為49μs,抖動恆為0μs,並持續了約3 h;之後偏移和抖動又分別從-230μs和60μs逐漸穩定到10μs以下。這種現象的原因是GPS信號不好,GPSD不再更新時間信息,使得NTP處於等待狀態造成的。當3 h之後GPS信號再次有效時,校時系統自動開始重新鎖定,無需人工干預。參考相關實驗結果,證明瞭本實驗結果的正確性。

 


3.2 數據分析
表2對三種校時結果數據進行了統計分析。結合圖表分析可以看出,使用網路時間伺服器,雖然校時工作較為穩定,但精度較低,維持在幾個到幾十個毫秒,主要的原因是網路傳輸延時的不確定性;採用單一的NMEA0183串列數據進行校時,效果並不理想,抖動太大,穩定性差,主要的原因是硬體資源分配過程中存在的隨機性,使得NMEA串列數據的處理速度有隨機偏差;本文采用的NMEA和PPS綜合校時方案取得了較為理想的效果。授時精度可達微秒級,比上述兩種方式提高了至少兩個數量級。這種方式充分發揮了脈衝校時精確度高的特點,又保留了串列校時的時間信息,實現了優勢互補。

 

 

4 結語
經過多次實驗反覆驗證,本文采用的基於GPSD綜合校時方案是一種行之有效的高精度校時方案,不僅實現了單機的精確校時,也可以通過網路提供NTP服務;相比於Linux PPS高精度校時方法,該方案操作簡單,可擴展性好,校時精度同樣可以達到微秒量級,能夠滿足大部分天文觀測設備的校時需要。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 關於日誌切割 日誌文件包含了關於系統中發生的事件的有用信息,在排障過程中或者系統性能分析時經常被用到。對於忙碌的伺服器,日誌文件大小會增長極快,伺服器會很快消耗磁碟空間,這成了個問題。除此之外,處理一個單個的龐大日誌文件也常常是件十分棘手的事。logrotate是個十分有用的工具,它可以自動對日誌進 ...
  • test簡介 測試命令test用於形成一個表達式,結合條件判斷語句if-else來判斷。 例如可以判斷某個文件是否存在,是否具備什麼樣的特性(可讀嗎?可寫嗎?可執行嗎?塊文件嗎?)等等。 測試命令test有三種語法格式: test EXPRESSION [ EXPRESSION ] [[ EXPRE ...
  • Delete ms-resource:AppName/Text ...
  • 背景 By 魯迅 By 高爾基 說明: 1. Kernel版本:4.14 2. ARM64處理器,Contex A53,雙核 3. 使用工具:Source Insight 3.5, Visio 1. 概述 是一種物理地址反向映射虛擬地址的方法。 映射 頁表用於虛擬地址到物理地址映射,其中的 頁表項記 ...
  • Mysql存儲引擎 1.MyISAM MySQL 5.0 之前的預設資料庫引擎,最為常用。擁有較高的插入,查詢速度,但不支持事務. 2.InnoDB事務型資料庫的首選引擎,支持ACID事務,支持行級鎖定, MySQL 5.5 起成為預設資料庫引擎. 3.BDB源 自 Berkeley DB,事務型數 ...
  • Index Merge特性 在MySQL 5.5之前版本中,查詢或子查詢被限制在一個表只能使用一個索引(回表查詢除外)。 假設表TB1001上C1和C2列分別有單列索引,如對下麵查詢: SELECT * FROM TB1001 WHERE C1='XXX' OR C2='XXX'; 單獨使用任一索引 ...
  • 概述: 浮點數據類型包括real型、float型、decimal型和numeric型。浮點數據類型用於存儲十進位小數。 在SQL Server 中浮點數值的數據採用上舍入(Round up)的方式進行存儲,所謂上舍入也就是,要舍入的小數部分不論其大小, 只要是一個非零的數,就要在該數字的最低有效位上 ...
  • 報錯誤The tablename is not defined (empty) 去掉表輸出中的“表分區數據” ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...