Philip P. Ide

Author, programmer, science enthusiast, half-wit.
Life is sweet. Have you tasted it lately?

User Tools

Site Tools


blog:articles:software:lunaclockpub

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
blog:articles:software:lunaclockpub [2024/04/15 12:24] – [Lunar Clock Published] Phil Ideblog:articles:software:lunaclockpub [2024/07/28 14:53] (current) – [Lunar Clock Published] Phil Ide
Line 1: Line 1:
 +~~NOCACHE~~
 ====== Lunar Clock Published ====== ====== Lunar Clock Published ======
  
-The lunar clock has a new name: ''rtaps'' which stands for **R**PC **T**imestamp **A**djustment  **P**rogram **S**erver. Yeah, I know, a bit contrived, but aren't all acronyms?+The lunar clock has a new name: ''rtaps'' which stands for [**R**]PC [**T**]imestamp [**A**]djustment  [**P**]rogram [**S**]erver. Yeah, I know, a bit contrived, but aren't all acronyms?
  
 The code has now been published on GitHub at https://github.com/stroggprog/rtap and can be cloned using git or downloaded as a compressed zip archive. The code has now been published on GitHub at https://github.com/stroggprog/rtap and can be cloned using git or downloaded as a compressed zip archive.
  
 I have decided not to turn the program into an NTP server, since that is non-trivial task. If someone thinks that would be a great idea (I no longer think so), they can take existing NTP code and amend it. I have decided not to turn the program into an NTP server, since that is non-trivial task. If someone thinks that would be a great idea (I no longer think so), they can take existing NTP code and amend it.
 +
 +===== Recent Updates =====
 +{{rss>https://github.com/stroggprog/rtap/commits/main.atom date 3}}
 +
  
 ===== New Philosophy ===== ===== New Philosophy =====
Line 19: Line 24:
  
 As mentioned above, there is a configuration file. When the program is first run it will look for it, and if not found it will create it with sensible default values. If the configuration file is manually edited, the program will need to be restarted to load the new values. The only exception is the //private epoch//, which if changed via the ''SetPrvEpoch'' call will come into effect immediately. As mentioned above, there is a configuration file. When the program is first run it will look for it, and if not found it will create it with sensible default values. If the configuration file is manually edited, the program will need to be restarted to load the new values. The only exception is the //private epoch//, which if changed via the ''SetPrvEpoch'' call will come into effect immediately.
 +
 +===== Uses =====
 +
 +For this part of the discussion, image we are on Earth's moon.
 +
 +If there is an experiment that is going to timestamp the results (or the data it has just collected), it grabs a timestamp from its own system clock. This clock has drifted from Earth-UTC due to relativistic effects as a result of the lower gravity. It sends that timestamp to the RPC server which adjusts it so it now represents the same moment in Earth-UTC.
 +
 +Since there is a processing delay while the RPC server adjusts the timestamp, the RPC server cannot be used as a clock with a granularity less than a microsecond. A program that represents a clock (e.g. displaying the time and updating in real-time) must take this into consideration. However, it can make its own adjustments if it notes the turnaround time between requesting the adjusted time and receiving it - but the process of applying the secondary adjustment of the turnaround time is also time expensive. Nonetheless, noting the average turnaround time will reveal how accurate the displayed clock is. If it takes an average of 150 microseconds to receive the timestamp from the RPC server, the clock cannot be relied on to be more accurate than this (and since this is an average, arguably it is less accurate than this). Therefore, in this case, the clock should not display greater granularity than thousandths of a second - which is fine for most clocks which only wish to display seconds with an update of approximately ten times per second.
 +
 +~~socialite~~
 +~~DISCUSSION~~
 +
blog/articles/software/lunaclockpub.1713183895.txt.gz · Last modified: 2024/04/15 12:24 by Phil Ide

Except where otherwise noted, content on this wiki is licensed under the following license: Copyright © Phil Ide
Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki