WO1995002294A1 - Distributed time synchronization system and method - Google Patents

Distributed time synchronization system and method Download PDF

Info

Publication number
WO1995002294A1
WO1995002294A1 PCT/US1994/007545 US9407545W WO9502294A1 WO 1995002294 A1 WO1995002294 A1 WO 1995002294A1 US 9407545 W US9407545 W US 9407545W WO 9502294 A1 WO9502294 A1 WO 9502294A1
Authority
WO
WIPO (PCT)
Prior art keywords
message
node
time
computer system
node computer
Prior art date
Application number
PCT/US1994/007545
Other languages
French (fr)
Inventor
Richard W. Mincher
Kerry E. Lynn
Original Assignee
Apple Computer, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Apple Computer, Inc. filed Critical Apple Computer, Inc.
Priority to AU72554/94A priority Critical patent/AU7255494A/en
Publication of WO1995002294A1 publication Critical patent/WO1995002294A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W56/00Synchronisation arrangements
    • H04W56/001Synchronization between nodes
    • H04W56/0015Synchronization between nodes one node acting as a reference for the others
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04BTRANSMISSION
    • H04B1/00Details of transmission systems, not covered by a single one of groups H04B3/00 - H04B13/00; Details of transmission systems not characterised by the medium used for transmission
    • H04B1/69Spread spectrum techniques
    • H04B1/713Spread spectrum techniques using frequency hopping
    • H04B1/7156Arrangements for sequence synchronisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • H04J3/0635Clock or time synchronisation in a network
    • H04J3/0638Clock or time synchronisation among nodes; Internode synchronisation
    • H04J3/0658Clock or time synchronisation among packet nodes
    • H04J3/0661Clock or time synchronisation among packet nodes using timestamps
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W56/00Synchronisation arrangements
    • H04W56/001Synchronization between nodes
    • H04W56/002Mutual synchronization
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04JMULTIPLEX COMMUNICATION
    • H04J3/00Time-division multiplex systems
    • H04J3/02Details
    • H04J3/06Synchronising arrangements
    • H04J3/0635Clock or time synchronisation in a network
    • H04J3/0638Clock or time synchronisation among nodes; Internode synchronisation
    • H04J3/0658Clock or time synchronisation among packet nodes
    • H04J3/0661Clock or time synchronisation among packet nodes using timestamps
    • H04J3/0664Clock or time synchronisation among packet nodes using timestamps unidirectional timestamps
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/02Hierarchically pre-organised networks, e.g. paging networks, cellular networks, WLAN [Wireless Local Area Network] or WLL [Wireless Local Loop]
    • H04W84/10Small scale networks; Flat hierarchical networks
    • H04W84/12WLAN [Wireless Local Area Networks]

Definitions

  • the present invention relates generally to local area networks (LAN), and more particularly, to a system and method for ensuring time synchronization between two or more computer systems communicating via a wireless LAN. Still more particularly, the present invention relates to a distributed time synchronization system and method for a frequency hopping spread spectrum LAN, which utilizes a plurality of logical frequency channels within a frequency band for communication.
  • LAN local area networks
  • the present invention relates to a distributed time synchronization system and method for a frequency hopping spread spectrum LAN, which utilizes a plurality of logical frequency channels within a frequency band for communication.
  • a wireless LAN system does not have any hardwired couplings between nodes. This allows nodes to easily join and exit a given LAN, and eliminates the need for routing LAN cabling to each node site.
  • Communication between nodes in a wireless LAN is accomplished by transferring information using electromagnetic signals having a specified frequency range. Such a frequency range has a finite bandwidth, which limits the amount of information that can be transferred. In situations having many nodes or groups of nodes utilizing the same frequency range, bandwidth limitations severely restrict the efficient transfer of information.
  • Spread spectrum (SS) communication techniques have been used to improve bandwidth availability in situations involving many communicating systems.
  • One such spread spectrum technique is known ,as frequency hopping spread spectrum (FHSS).
  • a FHSS LAN communication between nodes is accomplished by transferring information using electromagnetic signals within a plurality of logical frequency channels spanning a frequency band.
  • Each logical frequency channel comprises one or more physical frequency channels, with each physical frequency channel having a designated bandwidth.
  • information is preferably transmitted sequentially and redundantly on each physical frequency channel within a logical frequency channel, thereby making the logical frequency channel bandwidth the same as that of any single physical frequency channel.
  • a group of nodes communicating in a FHSS LAN utilize one logical frequency channel within the frequency band for a designated amount of time. After the designated amount of time, all the nodes in the group must move to a new logical frequency channel within the frequency band, hence the term frequency hopping spread spectrum.
  • nodes within a given group transfer information on a specific logical frequency channel only for a limited time, that channel's bandwidth becomes available after the group's frequency hop. Another group of nodes may then communicate on this logical frequency channel for the designated amount of time. Since each node within a group is required to move to a new logical frequency channel at a prescribed time, the importance of synchronization between each node's clock becomes apparent. Any logical frequency channel within a band can be subject to interference or noise; thus, moving to a new logical frequency channel also aids in improving signal reception if such effects are present within a portion of the frequency band. FCC regulations are structured in a manner which reflects these considerations, and have mandated specific FHSS rules for frequency bands at 900 and 2400 MHz.
  • the lack of perfect synchronization between nodes requires the use of a "dead-time" interval that includes time periods before and after a frequency hop. During this dead time, no information is transmitted by any of the nodes. Providing such dead time ensures that all nodes have completed all sending and receiving of information prior to a frequency hop, and that all nodes have moved to the new channel and are ready to communicate again after the frequency hop, before transmission of information begins.
  • time synchronization between the clocks of each node included within a FHSS LAN group is essential in order to minimize the dead-time, and thereby maximize the time available for sending and receiving information.
  • the master's clock fails, or if the node serving as the master leaves the network, provisions must exist for the removal of the current master, and for the selection of another node as a new master.
  • Other nodes within the LAN require a certain amount of time in order to determine if communication with the master node cannot take place. Time is also required to select a new master node. Thus, in this situation the nodes have no synchronization source until a new master is selected. This is undesirable in any type of LAN since this increases the likelihood that synchronization cannot be maintained between nodes.
  • close synchronization In order to maximize the amount of time available for information transfer between nodes prior to moving to a new logical frequency channel. Moreover, close synchronization helps to minimize any drift away from a synchronized state in the event that one or more nodes cannot communicate within the FHSS LAN for a limited time.
  • Another problem associated with single-master LAN systems pertains to the master node recovering from a temporary communication problem. If a new master node has been selected during a time interval in which the original master node could not communicate, the LAN will have two master nodes after the original master node's recovery. Synchronization differences between the two master nodes results in conflicting synchronization messages being sent over the LAN. This situation is obviously undesirable on a FHSS LAN, since conflicting synchronization messages would cause nodes to move to a new logical frequency channel at different times.
  • a node within a FHSS LAN is able to transmit information to other nodes only when the current frequency channel is not being used for information transmission by another node.
  • the information transfer capacity of any given logical frequency channel is limited by the logical frequency channel bandwidth, and by the limited amount of time the nodes in a LAN group remain on the channel. The limited information transfer capacity on any given channel dramatically increases the importance of minimizing unnecessary information transfers.
  • a FHSS LAN must therefore minimize the number of information transfers pertaining to LAN maintenance, thereby maximizing the amount of time available for other information transfer.
  • the presence of special time synchronization messages and master-related LAN maintenance messages on a single-master LAN would adversely affect the performance of a FHSS LAN, and are therefore not suitable for use in such a system.
  • Node synchronization on a FHSS LAN must be achieved without such messages in order to maximize communication efficiency.
  • a multiple-master LAN two or more nodes serve as masters for time synchronization purposes.
  • Nodes within this type of LAN collect synchronization messages from each master at regular intervals, and typically calculate a corresponding average correct time. This requires each node to have the capability to communicate with at least one master node.
  • reliable communication between two specific nodes is not always possible.
  • a multiple- master system cannot be used as the basis for a FHSS LAN.
  • a multiple-master LAN must have provisions for the selection and removal of masters. Such provisions would greatly increase the message traffic on a wireless LAN, adversely affecting communication efficiency as discussed for the single-master LAN.
  • the node can update its clock by setting its clock to be the same as the average. If the tolerance limit is exceeded, the node sends an argument message comprising its clock value to all other nodes within the LAN.
  • each of the other nodes After receiving the argument message, each of the other nodes treats the argument message as a synchronization request message, and in turn send their clock values to the node which originally sent the argument message. This node then calculates a new average clock value for use in updating its clock.
  • the number of messages transferred during the argument procedure can become quite large, flooding a FHSS LAN with messages and consuming a channel's information capacity. Synchronization discrepancies between each node's clock and the degradation of network performance because of flooding makes such prior art methods undesirable in a wireless LAN context. Thus, both single-master and multiple-master systems are incapable of providing an adequate solution to time synchronization issues on FHSS LANs.
  • the present invention is a distributed time synchronization system and method for a FHSS LAN.
  • the synchronization system automatically achieves synchronization of each node's clock using a unique message format that includes clock synchronization information.
  • nodes maintain clock synchronization in an incompletely connected environment.
  • the system of the present invention functions in a wireless LAN comprising two or more nodes. Each node is able to transmit information to and receive information from at least one other node through frequency hopping spread spectrum communication.
  • Each node system of the present invention comprises a CPU; an input device; a display device; a printer or other device for producing hard copy of information; random-access memory (RAM); read-only memory (ROM); a data storage device; a local clock; a transmitter /receiver that facilitates wireless frequency hopping spread spectrum communication with other nodes; an antenna; and a virtual master clock processor.
  • the antenna which is coupled to the transmitter /receiver, all elements within a node are coupled to a common data pathway in a Von Neumann architecture.
  • the random access memory further comprises an operating system, an application program, and routines related to transmitting and receiving messages over the wireless network.
  • the virtual master clock processor comprises a means for extracting and processing time information contained within messages received from other nodes, a means for periodically maintaining node synchronization to a virtual master clock value derived from the processed time information.
  • the method of the present invention preferably incorporates time information into all messages transferred between nodes.
  • a node incorporates the value of its local clock into a message just prior to sending the message.
  • a node is capable of receiving any message transmitted from other nodes within a predetermined receiving distance, regardless of whether or not the data in the message is addressed to the node. Therefore, a given node can obtain time information for synchronization purposes even if it was not the intended recipient of the message data.
  • the receiving node Upon message receipt, stores the message header and the value of its local clock.
  • the receiving node's virtual master clock processor uses the time information contained within the message to calculate the time difference between the sending node's local clock and its local clock value at message receipt.
  • a node's virtual master clock processor Prior to frequency hopping to another channel, a node's virtual master clock processor averages the time differences calculated from all messages the node has received since the previous frequency hop, thereby creating a virtual master clock value corresponding to the average of the local clock values for all nodes from which messages were received. The virtual master clock processor then uses this average to adjust the node's local clock value, thereby maintaining synchronization with the other nodes prior to the change in the operating frequency of the network. If the magnitude of any time difference calculated by the virtual master clock processor is larger than a maximum allowed value, the time difference is clamped to the maximum allowed value. This ensures system stability by preventing an erroneous clock value from greatly affecting synchronization, and allows synchronization to the virtual master clock value to be maintained within a predetermined tolerance.
  • the virtual processor initiates a general broadcast of a synchronization request message. Nodes which receive the synchronization request message respond by transmitting a message over the network. This message can then be used by all nodes for synchronization.
  • FIG. 1 shows a prior art system of nodes communicating in a wireless LAN, in which one node lies outside the communication range of all but one other node;
  • FIG. 2 shows a preferred embodiment of the distributed time synchronization system within a node computer system;
  • FIG. 3 shows a preferred embodiment for the structure of a message
  • FIG. 4 is a flowchart showing an overview of the distributed time synchronization method of the present invention
  • FIG. 5 is a flowchart of a preferred method for a node joining an existing wireless LAN group
  • FIG. 6 is a flowchart showing the preferred method for sending messages
  • FIG. 7 is a flowchart depicting the preferred method for receiving messages
  • FIG. 8 is a timing diagram indicating the preferred timing between local clock adjustment and frequency hopping; and FIG. 9 is a flowchart representing the preferred method for virtual master clock processor operation.
  • FIG. 1 shows an exemplary prior art wireless LAN 20 configuration in which the present invention may operate.
  • the wireless LAN 20 comprises two or more nodes 22 transmitting and receiving information without the use of hardwired couplings between the nodes 22.
  • Information transmitted in a wireless LAN 20 is subject to signal attenuation effects due to node separation distances, signal path obstacles, and multipath fading caused by signal reflections. Therefore, one or more nodes 22 within the wireless LAN 20 may not be capable of receiving information sent from another node 22.
  • Such a LAN configuration is defined as having incomplete connectivity.
  • one or more communication boundaries 24 can be defined to indicate which nodes 22 within the wireless LAN 20 can reliably communicate with each other.
  • FIG. 1 shows an exemplary prior art wireless LAN 20 configuration in which the present invention may operate.
  • the wireless LAN 20 comprises two or more nodes 22 transmitting and receiving information without the use of hardwired couplings between the nodes 22.
  • Information transmitted in a wireless LAN 20 is subject to signal attenuation effects due
  • one communication boundary 24 encloses nodes A through G, while another communication boundary 25 encloses nodes B and H.
  • nodes A through G can all communicate reliably with each other, while node H can communicate reliably only with node B.
  • Information directed to node H must therefore either originate from node B or pass through node B.
  • wireless LAN 20 signals are subject to noise and interference.
  • Two or more nodes 22 intentionally communicating on the wireless LAN 20 comprise a wireless LAN group.
  • Each node 22 within the wireless LAN 20 maintains the distributed time synchronization system of the present invention, which in a preferred embodiment comprises a computer system 30 having an architecture illustrated in the block diagram of FIG. 2.
  • the computer system 30 preferably comprises a display device 32, a CPU 34, a given amount of random access memory (RAM) 36, a given amount of read-only memory (ROM) 38, a printer or hard copy device 40, an input device 42, a data storage device 44, a transmitter /receiver 46, a common data pathway or bus 48, an antenna 50, a local clock 52, and a virtual master clock processor 54.
  • the antenna 50 all elements of the computer system 30 in the preferred embodiment are coupled to the common data bus 48 in a Von Neumann architecture.
  • the antenna 50 is coupled to the transmitter /receiver 46.
  • the routines of the present invention for logical frequency channel selection, processing related to information transmission and reception as well as an operating system and application programs are preferably stored in RAM 36 and ROM 38 memory.
  • the routines include a routine for sending information over the network, and a routine for extracting time synchronization information from messages received. Messages received are routed directly into RAM 36 by the transmitter /receiver 46 beginning at a predetermined RAM 36 address, in a direct memory access (DMA) information transfer.
  • DMA direct memory access
  • the present invention preferably uses a conventional operating system 28 such as Macintosh System Software version 7.1, DOS or Windows.
  • the RAM 36 may also include a variety of different application programs including but not limited to computer drawing programs, word processing programs, and spreadsheet programs.
  • Each node's local clock 52 comprises a programmable counting or time keeping means, and is preferably implemented as a programmable counter coupled to a crystal oscillator.
  • the local clock 52 may be integrated with the CPU 34 such as with many present-day microprocessors.
  • the local clock 52 serves as the node's time reference for frequency hopping.
  • the virtual master clock processor 54 comprises an adjustment timer which maintains a time count for indicating when the local clock is to be adjusted and when frequency hopping is to occur, a plurality of buffers, and control circuitry.
  • the virtual master clock processor 54 extracts time information contained within messages received, and utilizes this information to maintain a virtual master clock value.
  • the virtual master clock processor 54 adjusts the local clock value relative to the virtual master clock value in order to maintain synchronization to other nodes 22 within the wireless LAN 20.
  • the CPU 34 organizes information to be sent to one or more other nodes 22 within the wireless LAN 20 into a specific message structure, and informs the transmitter /receiver 46 as to the location of the message in RAM 36.
  • the transmitter /receiver 46 senses the wireless LAN 20 for network activity, and informs the CPU 34 if the network 20 is busy or available.
  • the CPU 34 incorporates the value of the local clock 52 into the header of the message, and directs the transmitter /receiver 46 to send the message.
  • the transmitter /receiver 46 then transmits the message over the network 20 via its antenna 50.
  • the transmitter /receiver 46 operates in a receive mode unless it is directed to transmit a message by the CPU 34. While in receive mode, the transmitter /receiver 46 receives messages sent by other nodes within receiving distance. A node can receive any message on the current channel, even if the data contained in a message is addressed to another node. A message is received by the transmitter /receiver 46 via its antenna 50. The transmitter/ receiver 46 maintains the starting address of a portion of available RAM 36, and routes the incoming message into RAM 36 through DMA beginning at this address. In the preferred embodiment of the distributed time synchronization system, the CPU 34 stores the receiving node's current local clock value in RAM 36 immediately after the entire message has been stored in RAM 36.
  • the virtual master clock processor 54 can access the time information contained within the message and the stored local clock value of the receiving node 22 in order to maintain the virtual master clock value.
  • the receiving node's CPU 34 determines which node the message was directed to, and whether any further actions, such as transmission of a response message, are required.
  • the CPU 34 could store the current local clock value after the message header were stored rather than after the entire message had been stored. This would allow the CPU 34 to analyze the message header and determine if actions are required without waiting for storage of the entire message.
  • the transmitter /receiver 46 follows a logical frequency channel selection sequence under the direction of the CPU 34, thereby providing for wireless frequency hopping spread spectrum communication between nodes 22.
  • Each logical frequency channel in the preferred embodiment comprises five physical frequency channels, each physical frequency channel a designated bandwidth.
  • information is preferably transmitted sequentially and redundantly on each physical frequency channel within a logical frequency channel, thereby making the logical frequency channel bandwidth the same as that of any single physical frequency channel.
  • a node 22 operates on a physical frequency channel for 400 ms. Since each logical frequency channel in the preferred embodiment comprises five physical frequency channels, the total amount of time a node remains on a logical frequency channel is 2 seconds. Thus, a frequency hop occurs every two seconds in this case.
  • the distributed time synchronization system is implemented using an Apple computer system in an exemplary embodiment.
  • the frequency band has a bandwidth of 2.4 GHz, and each physical frequency channel within the frequency band has a bandwidth of 1 MHz.
  • FCC regulations require a minimum of seventy-five and a maximum of eighty-three separate physical frequency channels within the frequency band.
  • All messages transferred between nodes 22 preferably comprise a header portion 60 and a data portion 62, as shown in FIG. 3.
  • the header portion 60 comprises a control information portion 64, a time stamp portion 66, and a LAN ID portion 68.
  • the control information portion 64 indicates the message type and any control functions to which the message may correspond.
  • the time stamp portion 66 comprises the sending node's 22 local clock value just prior to transmission of the message.
  • the LAN ID portion 68 indicates to which wireless LAN group or groups the message is directed.
  • the data portion 62 comprises an address indicating the specific node or node portion to which the message is addressed, and the information which the sending node 22 intends to convey to the receiving node 22.
  • the flowchart of FIG. 4 provides an overview of the operation of the preferred method of the present invention.
  • the preferred method begins in step 100 with the CPU 34 of a node 22 that intends to send a message storing time information in the message just prior to transmission on the wireless LAN 20. After the time information has been incorporated into the message, the transmitter /receiver 46 of the sending node 22 transmits the message through use of the antenna 50 in step 102. In step 104, the message is received by other nodes' transmitters /receivers 46 via their antennas 50, after which the CPUs 34 of the receiving nodes 22 store the value of their respective local clocks 52 in RAM 36 in step 106. Additional messages may also be received and processed, although only one message receipt is necessary for synchronization.
  • the virtual master clock processor 54 of each receiving node 22 extracts the time information contained within each message in step 108, and compares the extracted time to the time the message was received. In step 110, the virtual master clock processor 54 of each receiving node 22 adjusts its respective local clock value relative to the time information extracted from each received message, thereby synchronizing the node 22 with the virtual master clock.
  • FIG. 5 shows the preferred method for a new node 22 to join an existing wireless LAN group.
  • the process begins in step 120 with a node 22 that wishes to join a specific wireless LAN group selecting the lowest logical frequency channel within the frequency band.
  • the joining node's CPU 34 instructs the transmitter /receiver 46 to transmit a join request message over the network.
  • This message contains a special code within its time stamp portion 66, which prevents other nodes 22 from using the message for synchronization purposes. This ensures that the local clock 52 value on the node 22 attempting to join the wireless LAN group does not affect the group's synchronization.
  • Nodes 22 which receive the join request message will transmit a response message that the joining node 22 can utilize for synchronization purposes.
  • the joining node 22 After the joining node 22 has sent the join request message in step 122, it begins a scan of the logical frequency channel in step 124. During the scan, the transmitter /receiver 46 will receive messages sent from other nodes 22 within receiving distance in an attempt to find the desired FHSS LAN group. Since any given FHSS LAN group hops from one operating frequency to another after a designated amount of time, channels must be scanned rapidly in order to increase the probability that a node 22 can join the desired LAN group while the group is on a known logical frequency channel. In step 126, the CPU 34 determines if the transmitter /receiver 46 has received a message.
  • the CPU 34 checks whether the scan time has been exceeded in step 128.
  • the join operation preferably uses a scan time that is approximately forty times faster than the frequency hopping rate. In the preferred embodiment, the scan time is therefore set to 50 ms. If the scan time has not been exceeded, operation loops back to step 126 with the CPU 34 checking for a received message. If step 126 indicates that a message has been received, the CPU 34 determines if the LAN ID 68 portion of the received message corresponds to the desired FHSS LAN group in step 130. If not, the process returns to step 128 with the CPU 34 checking if the scan time has been exceeded.
  • the virtual master clock processor sets the virtual master clock value of the joining node to the value contained with the time stamp 66 portion of the received message in step 132. This value indicates the amount of time remaining before the node 22 which sent the message moves to a new logical frequency channel. The join process has been successfully completed at this point.
  • the virtual master clock processor 54 will subsequently use the virtual master clock value for adjusting the joining node's local clock 52 value.
  • the CPU 34 determines if the scan time has been exceeded in step 128, it next determines if the join request message should be sent again in step 134.
  • Multiple join request messages are preferably transmitted on each logical frequency channel in order to reduce the possibility that one or more join request messages were not received due to noise, interference, or signal attenuation effects.
  • up to four join request messages are transmitted on each logical frequency channel.
  • the 50 ms scan time available for receiving a reply to a join request message therefore gives a maximum time of 200 ms available on each logical frequency channel.
  • the joining node 22 moves from one logical frequency channel to another at a rate ten times faster than the rate of a FHSS LAN group in the preferred embodiment. This ensures that a node wishing to join a given FHSS LAN group will find the group quickly if the group is communicating within the frequency band. If another join request message is to be transmitted, the process loops back to step 122 in order to do so.
  • the CPU 34 determines in step 136 if all logical frequency channels have been scanned. If one or more logical frequency channels have not been scanned, the CPU 34 selects the next logical frequency channel in step 138, after which operation loops to step 122 for transmittal of a join request message on this channel. If all logical frequency channels have been scanned in step 136, the CPU determines if the entire join process should be repeated in step 140. Repeated scans through all channels within the frequency band without finding the desired LAN group may indicate that the desired LAN group is not present. In the preferred embodiment, two scans are performed through all channels. If no more channels will be scanned, the join attempt is aborted. FIG.
  • step 150 the CPU 34 prepares a message having the structure shown in FIG. 3, placing the appropriate information into the header portion 60 and the data portion 62.
  • step 152 the CPU 34 informs the transmitter /receiver 46 of the message location in RAM 36.
  • step 152 the CPU 34 instructs the transmitter /receiver 46 to check the wireless LAN 20 for message traffic in step 154.
  • the CPU 34 next determines if the transmitter /receiver 46 found the network 20 to be busy in step 156.
  • the CPU 34 instructs the transmitter /receiver 46 to send the message in step 160, which is broadcast over the network 20 via the antenna 50.
  • the preferred method for receiving a message is shown in the flowchart of FIG. 7.
  • the transmitter /receiver 46 preferably operates in a mode which allows message reception unless the CPU 34 requests message transmission.
  • the transmitter /receiver 46 monitors the network 20 for activity via its antenna 50.
  • the transmitter /receiver 46 determines if a CPU 34 interrupt requesting message transmission has occurred. If so, the receive process ends.
  • the transmitter /receiver 46 next determines if message transfer activity is present on the network 20 in step 184.
  • the transmitter /receiver 46 continues to monitor the network 20 in step 180.
  • Message transfer activity detected in step 184 causes the transmitter /receiver 46 to receive a message in step 186.
  • the transmitter /receiver 46 transfers the incoming message into RAM 36 via direct memory access (DMA).
  • DMA direct memory access
  • the transmitter /receiver 46 sends a signal to the CPU 34 after the entire message has been stored in RAM 36. After receiving this signal, the CPU 34 stores the value of the local clock 52 in RAM 36 in step 188. Then the method returns to step 180 to operate in receive mode to accept additional messages transmitted over the network 20.
  • FIG. 8 shows the preferred timing relations between frequency hop timing and local clock 52 adjustment by the virtual master clock processor 54.
  • the time interval during which a node utilizes a given channel is known as dwell time.
  • a node's virtual master clock processor 54 must adjust the local clock to ensure the node maintains synchronization with other nodes in the wireless LAN group.
  • Local clock adjustment time occurs at or approximately at the midpoint of the dwell time in the preferred embodiment of the present invention. Waiting until the midpoint of the dwell time increases the likelihood that the node has received messages since the previous local clock 52 adjustment, and provides the virtual master clock processor 54 with ample time to perform the local clock 52 adjustment prior to the upcoming frequency hop.
  • the dashed lines in the figure correspond to a "dead time" that occurs before and after a frequency hop.
  • the dead time Prior to a frequency hop, the dead time ensures that messages will not be transmitted while one or more nodes moves to a new frequency channel.
  • the dead time after the frequency hop ensures that all nodes 22 within a wireless LAN group have moved to the new frequency, and are ready to communicate again. This prevents information transmitted from a sending node 22 and directed to one or more receiving nodes 22 from being lost due to a small lack of synchronization. Messages can be received and their time information collected and processed at any time other than during a dead time.
  • the virtual master clock processor 54 calculates the time difference between the receiving node's local clock value and the transmitting node's local clock value.
  • FIG. 9 shows the preferred method of virtual master clock processor 54 operation. Beginning in step 200, the virtual master clock processor 54 determines if it is time to adjust the local clock 52 by checking the adjustment timer. The adjustment timer maintains a time count which begins counting immediately after a frequency hop and indicates when the midpoint of the dwell time has been reached. If local clock 52 adjustment is not yet required, the virtual master clock processor ascertains whether a new message has been received in step 202 via a CPU 34 inquiry. No new message receipt causes operation to return to step 200, with the virtual master clock processor 54 determining if the local clock adjustment time has arrived.
  • the virtual master clock processor 54 obtains the message's address in RAM 36 from the CPU 34 in step 204. In step 206, the virtual master clock processor 54 calculates the time difference between the value contained within the time stamp portion 66 of the message and the local clock value which the CPU 34 stored immediately after the message was received. In order to account for varying message lengths, the transmission time and message storage time is also included in this calculation.
  • the virtual master clock processor 54 determines if the value of delta exceeds a predetermined limit. This limit is preferably equal to one-half the desired synchronization accuracy, that being 5 ms in the preferred embodiment.
  • the value of delta is maintained within a predetermined range in the event that a sending node's local clock 52 is malfunctioning or is significantly out of synchronization. This ensures that the receiving node's local clock value maintains synchronization to the virtual master clock within a known maximum limit, and is not over adjusted due to an unacceptable value for Tout- If the magnitude of delta is too large, it is clamped to the maximum allowable value in step 210. An example of the clamp value is 5 ms.
  • the current value of delta is added to a running total SUM of all previously calculated delta values in step 212, after which the virtual master clock processor 54 increments a message counter, COUNT, which corresponds to the number of messages received in step 214. Operation then returns to step 200 with the virtual master clock processor 54 determining if the local clock 52 adjustment time has arrived.
  • the virtual master clock processor 54 next checks the value of the message counter in step 216. If the message count equals zero, no messages have been received since the last local clock 52 adjustment, and therefore no time synchronization information has been received. In this case, the virtual master clock processor initiates a synchronization request message via the CPU 34 in step 218. The CPU 34 prepares the synchronization request message, and sends it as detailed in FIG. 6. Upon receiving the synchronization request message, other nodes 22 transmit a response message over the network 20, providing the node 22 which initiated the synchronization request with messages containing time synchronization information. After initiating the synchronization request message, the virtual master clock processor 54 resets the adjustment timer in step 226. Operation then returns to step 202, with the virtual master clock processor 54 checking if any new messages have arrived.
  • a non zero message count in step 216 indicates messages have been received and timing information has been processed since the last local clock 52 adjustment, and causes the virtual master clock processor to adjust the local clock 52 in step 220.
  • the virtual master clock processor 54 makes this adjustment by dividing the sum of delta values by the message counter value, and adding the resulting quantity to the to the local clock value.
  • the virtual master clock processor resets the SUM to zero, and in step 224 resets the message COUNT to zero.
  • the virtual master clock processor 54 resets the adjustment timer, after which operation loops to step 202 with the check for new message arrival.
  • the calculation and summation of all delta values obtained from each message received, when included with the message counter, provide a virtual master clock value which the virtual master clock processor 54 uses to adjust the local clock 52.
  • the synchronization of each node 22 to the virtual master clock ensures synchronization to between the nodes 22 within a wireless LAN group. Therefore, the need to communicate with a specific node 22 for synchronization purposes is eliminated.
  • the present invention automatically and continuously synchronizes the local clocks 52 of the nodes 22 within a LAN group by adjusting them relative to a virtual master clock.

Abstract

A distributed time synchronization system and method synchronizes nodes within a frequency hopping spread spectrum (FHSS) local area network (LAN) group to a virtual master clock value. Each node system of the present invention comprises a CPU, an input device, a display device, a printer or hard copy device, a given amount of RAM and ROM memory, a data storage device, a local clock, a transmitter/receiver, an antenna, a virtual master clock processor, and a common data bus. The method of the present invention comprises the inclusion of a node's local clock value in a message just prior to transmission over the network, storage of a node's local clock value in RAM after an incoming message has been received, and the calculation of the time delay between the sending node and the receiving node by the virtual master clock processor. The virtual master clock processor utilizes this time delay in maintaining a virtual master clock value, which it uses in adjusting the value of the node's local clock at periodic intervals. This synchronizes the receiving node to the virtual master clock value. If the magnitude of the time delay exceeds a maximum allowed value, the magnitude is clamped to the maximum allowed value, thereby maintaining synchronization withing a predetermined tolerance. A node can receive a message transmitted over the FHSS LAN regardless of the message address. Synchronization is therefore maintained without requiring a node to be able to communicate with any specific node within the FHSS LAN group.

Description

DISTRIBUTED TIME SYNCHRONIZATION
SYSTEM AND METHOD
BACKGROUND OF THE INVENTION
1. Field of the Invention The present invention relates generally to local area networks (LAN), and more particularly, to a system and method for ensuring time synchronization between two or more computer systems communicating via a wireless LAN. Still more particularly, the present invention relates to a distributed time synchronization system and method for a frequency hopping spread spectrum LAN, which utilizes a plurality of logical frequency channels within a frequency band for communication.
2. Description of the Background Art
A wireless LAN system does not have any hardwired couplings between nodes. This allows nodes to easily join and exit a given LAN, and eliminates the need for routing LAN cabling to each node site. Communication between nodes in a wireless LAN is accomplished by transferring information using electromagnetic signals having a specified frequency range. Such a frequency range has a finite bandwidth, which limits the amount of information that can be transferred. In situations having many nodes or groups of nodes utilizing the same frequency range, bandwidth limitations severely restrict the efficient transfer of information. Spread spectrum (SS) communication techniques have been used to improve bandwidth availability in situations involving many communicating systems. One such spread spectrum technique is known ,as frequency hopping spread spectrum (FHSS). In a FHSS LAN, communication between nodes is accomplished by transferring information using electromagnetic signals within a plurality of logical frequency channels spanning a frequency band. Each logical frequency channel comprises one or more physical frequency channels, with each physical frequency channel having a designated bandwidth. In a FHSS LAN, information is preferably transmitted sequentially and redundantly on each physical frequency channel within a logical frequency channel, thereby making the logical frequency channel bandwidth the same as that of any single physical frequency channel. A group of nodes communicating in a FHSS LAN utilize one logical frequency channel within the frequency band for a designated amount of time. After the designated amount of time, all the nodes in the group must move to a new logical frequency channel within the frequency band, hence the term frequency hopping spread spectrum. Since nodes within a given group transfer information on a specific logical frequency channel only for a limited time, that channel's bandwidth becomes available after the group's frequency hop. Another group of nodes may then communicate on this logical frequency channel for the designated amount of time. Since each node within a group is required to move to a new logical frequency channel at a prescribed time, the importance of synchronization between each node's clock becomes apparent. Any logical frequency channel within a band can be subject to interference or noise; thus, moving to a new logical frequency channel also aids in improving signal reception if such effects are present within a portion of the frequency band. FCC regulations are structured in a manner which reflects these considerations, and have mandated specific FHSS rules for frequency bands at 900 and 2400 MHz.
Within a single FHSS LAN group, the lack of perfect synchronization between nodes requires the use of a "dead-time" interval that includes time periods before and after a frequency hop. During this dead time, no information is transmitted by any of the nodes. Providing such dead time ensures that all nodes have completed all sending and receiving of information prior to a frequency hop, and that all nodes have moved to the new channel and are ready to communicate again after the frequency hop, before transmission of information begins. Thus, time synchronization between the clocks of each node included within a FHSS LAN group is essential in order to minimize the dead-time, and thereby maximize the time available for sending and receiving information.
In the prior art, many have attempted to solve LAN time synchronization problems by designating one or more nodes as masters. In a single-master LAN, one node is designated as the master node and the clock of the designated node is utilized as the timing standard for every other node connected to the network. This requires the master node periodically send a special time synchronization message to all other nodes within the network. Thus, all nodes in a single-master system must be capable of receiving messages from the master.
On a FHSS LAN, and in general on any wireless LAN, electrical noise and interference, coupled with signal attenuation effects corresponding to node separation distances, signal path obstacles, or multipath fading arising from signal reflections preclude continuous reliable communication between a node and another specified node. It is therefore desirable to maintain a wireless LAN environment in which a node is considered to be a member of a designated wireless LAN group if it can communicate with at least one other node within the group. Since each node within a single-master LAN system must be able to communicate with the master node, a single-master LAN system does not allow the flexibility desired in a wireless LAN environment.
If, within a single-master LAN system, the master's clock fails, or if the node serving as the master leaves the network, provisions must exist for the removal of the current master, and for the selection of another node as a new master. Other nodes within the LAN require a certain amount of time in order to determine if communication with the master node cannot take place. Time is also required to select a new master node. Thus, in this situation the nodes have no synchronization source until a new master is selected. This is undesirable in any type of LAN since this increases the likelihood that synchronization cannot be maintained between nodes. Particularly in the case of a FHSS LAN, close synchronization must be maintained in order to maximize the amount of time available for information transfer between nodes prior to moving to a new logical frequency channel. Moreover, close synchronization helps to minimize any drift away from a synchronized state in the event that one or more nodes cannot communicate within the FHSS LAN for a limited time.
Another problem associated with single-master LAN systems pertains to the master node recovering from a temporary communication problem. If a new master node has been selected during a time interval in which the original master node could not communicate, the LAN will have two master nodes after the original master node's recovery. Synchronization differences between the two master nodes results in conflicting synchronization messages being sent over the LAN. This situation is obviously undesirable on a FHSS LAN, since conflicting synchronization messages would cause nodes to move to a new logical frequency channel at different times.
In general, if information is being transferred on a LAN, a node wishing to send a message to another node must wait until the current information transfer has been completed before the message can be sent. In like manner, a node within a FHSS LAN is able to transmit information to other nodes only when the current frequency channel is not being used for information transmission by another node. On a FHSS LAN, the information transfer capacity of any given logical frequency channel is limited by the logical frequency channel bandwidth, and by the limited amount of time the nodes in a LAN group remain on the channel. The limited information transfer capacity on any given channel dramatically increases the importance of minimizing unnecessary information transfers. A FHSS LAN must therefore minimize the number of information transfers pertaining to LAN maintenance, thereby maximizing the amount of time available for other information transfer. The presence of special time synchronization messages and master-related LAN maintenance messages on a single-master LAN would adversely affect the performance of a FHSS LAN, and are therefore not suitable for use in such a system. Node synchronization on a FHSS LAN must be achieved without such messages in order to maximize communication efficiency.
In a multiple-master LAN, two or more nodes serve as masters for time synchronization purposes. Nodes within this type of LAN collect synchronization messages from each master at regular intervals, and typically calculate a corresponding average correct time. This requires each node to have the capability to communicate with at least one master node. As discussed above, in a wireless LAN environment reliable communication between two specific nodes is not always possible. As a result, a multiple- master system cannot be used as the basis for a FHSS LAN.
As in the case of a single-master LAN, a multiple-master LAN must have provisions for the selection and removal of masters. Such provisions would greatly increase the message traffic on a wireless LAN, adversely affecting communication efficiency as discussed for the single-master LAN. On the multiple-master LAN, if the difference between a node's current clock value and the calculated average obtained from master node clock values is within a predetermined tolerance, the node can update its clock by setting its clock to be the same as the average. If the tolerance limit is exceeded, the node sends an argument message comprising its clock value to all other nodes within the LAN. After receiving the argument message, each of the other nodes treats the argument message as a synchronization request message, and in turn send their clock values to the node which originally sent the argument message. This node then calculates a new average clock value for use in updating its clock. The number of messages transferred during the argument procedure can become quite large, flooding a FHSS LAN with messages and consuming a channel's information capacity. Synchronization discrepancies between each node's clock and the degradation of network performance because of flooding makes such prior art methods undesirable in a wireless LAN context. Thus, both single-master and multiple-master systems are incapable of providing an adequate solution to time synchronization issues on FHSS LANs. Therefore, there is a need for a system and method for ensuring time synchronization between nodes on a FHSS LAN that maintains synchronization without the use of one or more master nodes; requires no special messages dedicated to time synchronization, arguments, or master- related LAN maintenance; and functions in an incompletely connected environment. SUMMARY OF THE INVENTION
The present invention is a distributed time synchronization system and method for a FHSS LAN. The synchronization system automatically achieves synchronization of each node's clock using a unique message format that includes clock synchronization information. In addition, nodes maintain clock synchronization in an incompletely connected environment.
The system of the present invention functions in a wireless LAN comprising two or more nodes. Each node is able to transmit information to and receive information from at least one other node through frequency hopping spread spectrum communication. Each node system of the present invention comprises a CPU; an input device; a display device; a printer or other device for producing hard copy of information; random-access memory (RAM); read-only memory (ROM); a data storage device; a local clock; a transmitter /receiver that facilitates wireless frequency hopping spread spectrum communication with other nodes; an antenna; and a virtual master clock processor. With the exception of the antenna, which is coupled to the transmitter /receiver, all elements within a node are coupled to a common data pathway in a Von Neumann architecture. The random access memory further comprises an operating system, an application program, and routines related to transmitting and receiving messages over the wireless network. The virtual master clock processor comprises a means for extracting and processing time information contained within messages received from other nodes, a means for periodically maintaining node synchronization to a virtual master clock value derived from the processed time information.
The method of the present invention preferably incorporates time information into all messages transferred between nodes. A node incorporates the value of its local clock into a message just prior to sending the message. A node is capable of receiving any message transmitted from other nodes within a predetermined receiving distance, regardless of whether or not the data in the message is addressed to the node. Therefore, a given node can obtain time information for synchronization purposes even if it was not the intended recipient of the message data. Upon message receipt, the receiving node stores the message header and the value of its local clock. The receiving node's virtual master clock processor then uses the time information contained within the message to calculate the time difference between the sending node's local clock and its local clock value at message receipt. Prior to frequency hopping to another channel, a node's virtual master clock processor averages the time differences calculated from all messages the node has received since the previous frequency hop, thereby creating a virtual master clock value corresponding to the average of the local clock values for all nodes from which messages were received. The virtual master clock processor then uses this average to adjust the node's local clock value, thereby maintaining synchronization with the other nodes prior to the change in the operating frequency of the network. If the magnitude of any time difference calculated by the virtual master clock processor is larger than a maximum allowed value, the time difference is clamped to the maximum allowed value. This ensures system stability by preventing an erroneous clock value from greatly affecting synchronization, and allows synchronization to the virtual master clock value to be maintained within a predetermined tolerance.
If a node has not received any messages during an interval between frequency hops, the virtual processor initiates a general broadcast of a synchronization request message. Nodes which receive the synchronization request message respond by transmitting a message over the network. This message can then be used by all nodes for synchronization.
BRIEF DESCRIPTION OF THE DRAWINGS FIG. 1 shows a prior art system of nodes communicating in a wireless LAN, in which one node lies outside the communication range of all but one other node; FIG. 2 shows a preferred embodiment of the distributed time synchronization system within a node computer system;
FIG. 3 shows a preferred embodiment for the structure of a message; FIG. 4 is a flowchart showing an overview of the distributed time synchronization method of the present invention; FIG. 5 is a flowchart of a preferred method for a node joining an existing wireless LAN group;
FIG. 6 is a flowchart showing the preferred method for sending messages;
FIG. 7 is a flowchart depicting the preferred method for receiving messages;
FIG. 8 is a timing diagram indicating the preferred timing between local clock adjustment and frequency hopping; and FIG. 9 is a flowchart representing the preferred method for virtual master clock processor operation.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
FIG. 1 shows an exemplary prior art wireless LAN 20 configuration in which the present invention may operate. The wireless LAN 20 comprises two or more nodes 22 transmitting and receiving information without the use of hardwired couplings between the nodes 22. Information transmitted in a wireless LAN 20 is subject to signal attenuation effects due to node separation distances, signal path obstacles, and multipath fading caused by signal reflections. Therefore, one or more nodes 22 within the wireless LAN 20 may not be capable of receiving information sent from another node 22. Such a LAN configuration is defined as having incomplete connectivity. In a wireless LAN 20 having incomplete connectivity, one or more communication boundaries 24 can be defined to indicate which nodes 22 within the wireless LAN 20 can reliably communicate with each other. In FIG. 1, one communication boundary 24 encloses nodes A through G, while another communication boundary 25 encloses nodes B and H. Thus, nodes A through G can all communicate reliably with each other, while node H can communicate reliably only with node B. Information directed to node H must therefore either originate from node B or pass through node B. In addition to attenuation effects, wireless LAN 20 signals are subject to noise and interference. Two or more nodes 22 intentionally communicating on the wireless LAN 20 comprise a wireless LAN group.
Each node 22 within the wireless LAN 20 maintains the distributed time synchronization system of the present invention, which in a preferred embodiment comprises a computer system 30 having an architecture illustrated in the block diagram of FIG. 2. The computer system 30 preferably comprises a display device 32, a CPU 34, a given amount of random access memory (RAM) 36, a given amount of read-only memory (ROM) 38, a printer or hard copy device 40, an input device 42, a data storage device 44, a transmitter /receiver 46, a common data pathway or bus 48, an antenna 50, a local clock 52, and a virtual master clock processor 54. With the exception of the antenna 50, all elements of the computer system 30 in the preferred embodiment are coupled to the common data bus 48 in a Von Neumann architecture. The antenna 50 is coupled to the transmitter /receiver 46.
The routines of the present invention for logical frequency channel selection, processing related to information transmission and reception as well as an operating system and application programs are preferably stored in RAM 36 and ROM 38 memory. The routines include a routine for sending information over the network, and a routine for extracting time synchronization information from messages received. Messages received are routed directly into RAM 36 by the transmitter /receiver 46 beginning at a predetermined RAM 36 address, in a direct memory access (DMA) information transfer. The present invention preferably uses a conventional operating system 28 such as Macintosh System Software version 7.1, DOS or Windows. The RAM 36 may also include a variety of different application programs including but not limited to computer drawing programs, word processing programs, and spreadsheet programs.
Each node's local clock 52 comprises a programmable counting or time keeping means, and is preferably implemented as a programmable counter coupled to a crystal oscillator. In an exemplary embodiment, the local clock 52 may be integrated with the CPU 34 such as with many present-day microprocessors. The local clock 52 serves as the node's time reference for frequency hopping. The virtual master clock processor 54 comprises an adjustment timer which maintains a time count for indicating when the local clock is to be adjusted and when frequency hopping is to occur, a plurality of buffers, and control circuitry. The virtual master clock processor 54 extracts time information contained within messages received, and utilizes this information to maintain a virtual master clock value. At periodic intervals indicated by the adjustment timer, the virtual master clock processor 54 adjusts the local clock value relative to the virtual master clock value in order to maintain synchronization to other nodes 22 within the wireless LAN 20. For message transmission, the CPU 34 organizes information to be sent to one or more other nodes 22 within the wireless LAN 20 into a specific message structure, and informs the transmitter /receiver 46 as to the location of the message in RAM 36. The transmitter /receiver 46 senses the wireless LAN 20 for network activity, and informs the CPU 34 if the network 20 is busy or available. When the network 20 is available, the CPU 34 incorporates the value of the local clock 52 into the header of the message, and directs the transmitter /receiver 46 to send the message. The transmitter /receiver 46 then transmits the message over the network 20 via its antenna 50.
The transmitter /receiver 46 operates in a receive mode unless it is directed to transmit a message by the CPU 34. While in receive mode, the transmitter /receiver 46 receives messages sent by other nodes within receiving distance. A node can receive any message on the current channel, even if the data contained in a message is addressed to another node. A message is received by the transmitter /receiver 46 via its antenna 50. The transmitter/ receiver 46 maintains the starting address of a portion of available RAM 36, and routes the incoming message into RAM 36 through DMA beginning at this address. In the preferred embodiment of the distributed time synchronization system, the CPU 34 stores the receiving node's current local clock value in RAM 36 immediately after the entire message has been stored in RAM 36. At this point, the virtual master clock processor 54 can access the time information contained within the message and the stored local clock value of the receiving node 22 in order to maintain the virtual master clock value. After message reception, the receiving node's CPU 34 determines which node the message was directed to, and whether any further actions, such as transmission of a response message, are required. In an alternate embodiment, the CPU 34 could store the current local clock value after the message header were stored rather than after the entire message had been stored. This would allow the CPU 34 to analyze the message header and determine if actions are required without waiting for storage of the entire message.
In the preferred embodiment of the distributed time synchronization system 30, the transmitter /receiver 46 follows a logical frequency channel selection sequence under the direction of the CPU 34, thereby providing for wireless frequency hopping spread spectrum communication between nodes 22. Each logical frequency channel in the preferred embodiment comprises five physical frequency channels, each physical frequency channel a designated bandwidth. In a FHSS LAN, information is preferably transmitted sequentially and redundantly on each physical frequency channel within a logical frequency channel, thereby making the logical frequency channel bandwidth the same as that of any single physical frequency channel. As a result of the logical frequency channel selection by the CPU 34, all nodes 22 within a given wireless LAN group communicate on a single logical frequency channel within a specified frequency band for a designated amount of time, and subsequently move to a new logical frequency channel within the band. Communication then continues on this logical frequency channel for a specified amount of time, after which another new logical frequency channel is selected, and so on. In the preferred embodiment, a node 22 operates on a physical frequency channel for 400 ms. Since each logical frequency channel in the preferred embodiment comprises five physical frequency channels, the total amount of time a node remains on a logical frequency channel is 2 seconds. Thus, a frequency hop occurs every two seconds in this case. The distributed time synchronization system is implemented using an Apple computer system in an exemplary embodiment. In the exemplary embodiment, the frequency band has a bandwidth of 2.4 GHz, and each physical frequency channel within the frequency band has a bandwidth of 1 MHz. FCC regulations require a minimum of seventy-five and a maximum of eighty-three separate physical frequency channels within the frequency band.
All messages transferred between nodes 22 preferably comprise a header portion 60 and a data portion 62, as shown in FIG. 3. The header portion 60 comprises a control information portion 64, a time stamp portion 66, and a LAN ID portion 68. The control information portion 64 indicates the message type and any control functions to which the message may correspond. The time stamp portion 66 comprises the sending node's 22 local clock value just prior to transmission of the message. The LAN ID portion 68 indicates to which wireless LAN group or groups the message is directed. The data portion 62 comprises an address indicating the specific node or node portion to which the message is addressed, and the information which the sending node 22 intends to convey to the receiving node 22.
The flowchart of FIG. 4 provides an overview of the operation of the preferred method of the present invention. The preferred method begins in step 100 with the CPU 34 of a node 22 that intends to send a message storing time information in the message just prior to transmission on the wireless LAN 20. After the time information has been incorporated into the message, the transmitter /receiver 46 of the sending node 22 transmits the message through use of the antenna 50 in step 102. In step 104, the message is received by other nodes' transmitters /receivers 46 via their antennas 50, after which the CPUs 34 of the receiving nodes 22 store the value of their respective local clocks 52 in RAM 36 in step 106. Additional messages may also be received and processed, although only one message receipt is necessary for synchronization. The virtual master clock processor 54 of each receiving node 22 extracts the time information contained within each message in step 108, and compares the extracted time to the time the message was received. In step 110, the virtual master clock processor 54 of each receiving node 22 adjusts its respective local clock value relative to the time information extracted from each received message, thereby synchronizing the node 22 with the virtual master clock.
FIG. 5 shows the preferred method for a new node 22 to join an existing wireless LAN group. The process begins in step 120 with a node 22 that wishes to join a specific wireless LAN group selecting the lowest logical frequency channel within the frequency band. Next, in step 122, the joining node's CPU 34 instructs the transmitter /receiver 46 to transmit a join request message over the network. This message contains a special code within its time stamp portion 66, which prevents other nodes 22 from using the message for synchronization purposes. This ensures that the local clock 52 value on the node 22 attempting to join the wireless LAN group does not affect the group's synchronization.
Nodes 22 which receive the join request message will transmit a response message that the joining node 22 can utilize for synchronization purposes. After the joining node 22 has sent the join request message in step 122, it begins a scan of the logical frequency channel in step 124. During the scan, the transmitter /receiver 46 will receive messages sent from other nodes 22 within receiving distance in an attempt to find the desired FHSS LAN group. Since any given FHSS LAN group hops from one operating frequency to another after a designated amount of time, channels must be scanned rapidly in order to increase the probability that a node 22 can join the desired LAN group while the group is on a known logical frequency channel. In step 126, the CPU 34 determines if the transmitter /receiver 46 has received a message. If not, the CPU 34 checks whether the scan time has been exceeded in step 128. The join operation preferably uses a scan time that is approximately forty times faster than the frequency hopping rate. In the preferred embodiment, the scan time is therefore set to 50 ms. If the scan time has not been exceeded, operation loops back to step 126 with the CPU 34 checking for a received message. If step 126 indicates that a message has been received, the CPU 34 determines if the LAN ID 68 portion of the received message corresponds to the desired FHSS LAN group in step 130. If not, the process returns to step 128 with the CPU 34 checking if the scan time has been exceeded. If the desired LAN group has been found in step 130, the virtual master clock processor sets the virtual master clock value of the joining node to the value contained with the time stamp 66 portion of the received message in step 132. This value indicates the amount of time remaining before the node 22 which sent the message moves to a new logical frequency channel. The join process has been successfully completed at this point. The virtual master clock processor 54 will subsequently use the virtual master clock value for adjusting the joining node's local clock 52 value.
If the CPU 34 determines that the scan time has been exceeded in step 128, it next determines if the join request message should be sent again in step 134. Multiple join request messages are preferably transmitted on each logical frequency channel in order to reduce the possibility that one or more join request messages were not received due to noise, interference, or signal attenuation effects. In the preferred embodiment, up to four join request messages are transmitted on each logical frequency channel. The 50 ms scan time available for receiving a reply to a join request message therefore gives a maximum time of 200 ms available on each logical frequency channel. Thus, the joining node 22 moves from one logical frequency channel to another at a rate ten times faster than the rate of a FHSS LAN group in the preferred embodiment. This ensures that a node wishing to join a given FHSS LAN group will find the group quickly if the group is communicating within the frequency band. If another join request message is to be transmitted, the process loops back to step 122 in order to do so.
If no further join request messages will be transmitted, the CPU 34 determines in step 136 if all logical frequency channels have been scanned. If one or more logical frequency channels have not been scanned, the CPU 34 selects the next logical frequency channel in step 138, after which operation loops to step 122 for transmittal of a join request message on this channel. If all logical frequency channels have been scanned in step 136, the CPU determines if the entire join process should be repeated in step 140. Repeated scans through all channels within the frequency band without finding the desired LAN group may indicate that the desired LAN group is not present. In the preferred embodiment, two scans are performed through all channels. If no more channels will be scanned, the join attempt is aborted. FIG. 6 is a flowchart showing the preferred method for sending a message to one or more nodes 22 within a given wireless LAN group. As noted above, the present invention advantageously includes time synchronization information in every message transmitted over the network 20. In step 150, the CPU 34 prepares a message having the structure shown in FIG. 3, placing the appropriate information into the header portion 60 and the data portion 62. Next, in step 152, the CPU 34 informs the transmitter /receiver 46 of the message location in RAM 36. After step 152, the CPU 34 instructs the transmitter /receiver 46 to check the wireless LAN 20 for message traffic in step 154. The CPU 34 next determines if the transmitter /receiver 46 found the network 20 to be busy in step 156. A message cannot be sent while the network 20 is busy; therefore, a busy condition causes the CPU 34 to wait a predetermined amount of time in step 157. After waiting the predetermined amount of time, operation loops to step 154 with the transmitter /receiver 46 checking the network 20 for message traffic. If the transmitter /receiver 46 did not detect any network traffic in step 156, the CPU 34 stores the value of the local clock 52 into the message's time stamp 66 in step 158. In the case of a join message, the CPU 34 would set the message's time stamp 66 to a special value indicating that the time stamp is not to be used. The local clock 52 value stored in the message time stamp 66 indicates the time at which message transmission begins. Therefore, immediately after step 158, the CPU 34 instructs the transmitter /receiver 46 to send the message in step 160, which is broadcast over the network 20 via the antenna 50. The preferred method for receiving a message is shown in the flowchart of FIG. 7. The transmitter /receiver 46 preferably operates in a mode which allows message reception unless the CPU 34 requests message transmission. Beginning with step 180, the transmitter /receiver 46 monitors the network 20 for activity via its antenna 50. In step 182, the transmitter /receiver 46 determines if a CPU 34 interrupt requesting message transmission has occurred. If so, the receive process ends. The transmitter /receiver 46 next determines if message transfer activity is present on the network 20 in step 184. If no message transfer activity is occurring, the transmitter /receiver 46 continues to monitor the network 20 in step 180. Message transfer activity detected in step 184 causes the transmitter /receiver 46 to receive a message in step 186. The transmitter /receiver 46 transfers the incoming message into RAM 36 via direct memory access (DMA). The transmitter /receiver 46 sends a signal to the CPU 34 after the entire message has been stored in RAM 36. After receiving this signal, the CPU 34 stores the value of the local clock 52 in RAM 36 in step 188. Then the method returns to step 180 to operate in receive mode to accept additional messages transmitted over the network 20.
FIG. 8 shows the preferred timing relations between frequency hop timing and local clock 52 adjustment by the virtual master clock processor 54. The time interval during which a node utilizes a given channel is known as dwell time. At some point during the dwell time, a node's virtual master clock processor 54 must adjust the local clock to ensure the node maintains synchronization with other nodes in the wireless LAN group. Local clock adjustment time occurs at or approximately at the midpoint of the dwell time in the preferred embodiment of the present invention. Waiting until the midpoint of the dwell time increases the likelihood that the node has received messages since the previous local clock 52 adjustment, and provides the virtual master clock processor 54 with ample time to perform the local clock 52 adjustment prior to the upcoming frequency hop. The dashed lines in the figure correspond to a "dead time" that occurs before and after a frequency hop. During the dead time, no communication between nodes 22 can occur. Prior to a frequency hop, the dead time ensures that messages will not be transmitted while one or more nodes moves to a new frequency channel. The dead time after the frequency hop ensures that all nodes 22 within a wireless LAN group have moved to the new frequency, and are ready to communicate again. This prevents information transmitted from a sending node 22 and directed to one or more receiving nodes 22 from being lost due to a small lack of synchronization. Messages can be received and their time information collected and processed at any time other than during a dead time.
After a message has been received, the virtual master clock processor 54 calculates the time difference between the receiving node's local clock value and the transmitting node's local clock value. FIG. 9 shows the preferred method of virtual master clock processor 54 operation. Beginning in step 200, the virtual master clock processor 54 determines if it is time to adjust the local clock 52 by checking the adjustment timer. The adjustment timer maintains a time count which begins counting immediately after a frequency hop and indicates when the midpoint of the dwell time has been reached. If local clock 52 adjustment is not yet required, the virtual master clock processor ascertains whether a new message has been received in step 202 via a CPU 34 inquiry. No new message receipt causes operation to return to step 200, with the virtual master clock processor 54 determining if the local clock adjustment time has arrived.
If the CPU 34 indicates that a new message has been received in step 202, the virtual master clock processor 54 obtains the message's address in RAM 36 from the CPU 34 in step 204. In step 206, the virtual master clock processor 54 calculates the time difference between the value contained within the time stamp portion 66 of the message and the local clock value which the CPU 34 stored immediately after the message was received. In order to account for varying message lengths, the transmission time and message storage time is also included in this calculation. This time difference, herein referred to as delta, is calculated as delta = Tout + Txmit - Tin, where To t is the value contained within the time stamp portion 66 of the message, corresponding to the sending node's local clock value immediately prior to message transmission; TXmit is the time interval required for message transmission and storage in RAM 36; and Tin is the local clock value of the receiving node that the CPU 34 stored immediately after message reception. In step 208, the virtual master clock processor 54 determines if the value of delta exceeds a predetermined limit. This limit is preferably equal to one-half the desired synchronization accuracy, that being 5 ms in the preferred embodiment. The value of delta is maintained within a predetermined range in the event that a sending node's local clock 52 is malfunctioning or is significantly out of synchronization. This ensures that the receiving node's local clock value maintains synchronization to the virtual master clock within a known maximum limit, and is not over adjusted due to an unacceptable value for Tout- If the magnitude of delta is too large, it is clamped to the maximum allowable value in step 210. An example of the clamp value is 5 ms. Next, the current value of delta is added to a running total SUM of all previously calculated delta values in step 212, after which the virtual master clock processor 54 increments a message counter, COUNT, which corresponds to the number of messages received in step 214. Operation then returns to step 200 with the virtual master clock processor 54 determining if the local clock 52 adjustment time has arrived.
If it was determined in step 200 that the local clock 52 adjustment time has arrived in step 200, the virtual master clock processor 54 next checks the value of the message counter in step 216. If the message count equals zero, no messages have been received since the last local clock 52 adjustment, and therefore no time synchronization information has been received. In this case, the virtual master clock processor initiates a synchronization request message via the CPU 34 in step 218. The CPU 34 prepares the synchronization request message, and sends it as detailed in FIG. 6. Upon receiving the synchronization request message, other nodes 22 transmit a response message over the network 20, providing the node 22 which initiated the synchronization request with messages containing time synchronization information. After initiating the synchronization request message, the virtual master clock processor 54 resets the adjustment timer in step 226. Operation then returns to step 202, with the virtual master clock processor 54 checking if any new messages have arrived.
A non zero message count in step 216 indicates messages have been received and timing information has been processed since the last local clock 52 adjustment, and causes the virtual master clock processor to adjust the local clock 52 in step 220. The virtual master clock processor 54 makes this adjustment by dividing the sum of delta values by the message counter value, and adding the resulting quantity to the to the local clock value. In step 222, the virtual master clock processor resets the SUM to zero, and in step 224 resets the message COUNT to zero. Next, in step 226, the virtual master clock processor 54 resets the adjustment timer, after which operation loops to step 202 with the check for new message arrival.
The calculation and summation of all delta values obtained from each message received, when included with the message counter, provide a virtual master clock value which the virtual master clock processor 54 uses to adjust the local clock 52. The synchronization of each node 22 to the virtual master clock ensures synchronization to between the nodes 22 within a wireless LAN group. Therefore, the need to communicate with a specific node 22 for synchronization purposes is eliminated. The present invention automatically and continuously synchronizes the local clocks 52 of the nodes 22 within a LAN group by adjusting them relative to a virtual master clock.
While the present invention has been described with reference to certain preferred embodiments, those skilled in the art will recognize that various modifications may be provided. For example, modifications might include, but would not be limited to, weighting time synchronization information based upon the transmission delay between nodes, or including a node's local clock value into the virtual master clock value prior to local clock adjustment. These and other variations upon and modifications to the preferred embodiment are provided for by the present invention which is limited only by the following claims.

Claims

WHAT IS CLAIMED IS:
1. A distributed time synchronization system for a wireless communications network having a plurality of node systems, each node system comprising: a display device for displaying information to the user, the display device having an input; an input device for inputting information to the system, the input device having an output; a local clock having an input and an output for providing a timing signal, the input for receiving a signal to adjust the local clock; a memory for storing data and routines, the memory having inputs and outputs, the memory including a routine for sending messages with time synchronization information, a routine for receiving messages and extracting synchronization information, an routine for adjusting the local clock using extracted synchronization information; a transmitter /receiver for receiving and translating radio signals into digital signals and for translating and transmitting digital signals into radio signals in response to digital control signals, the transmitter /receiver coupled to an antenna to receive and transmit radio signals, the transmitter /receiver having an input and an output for processing digital signals; a virtual master clock processing means for calculating the value of a virtual master clock for the network, the virtual master clock processing means coupled to the transmitter /receiver and memory for extracting synchronization information from messages received over the network, the virtual master clock processing means using the extracted synchronization information to calculate the value of the virtual master clock; and a processing unit for adding synchronization information to messages sent by the transmitter /receiver, and using the value of the virtual master clock to adjust the local clock, the processing unit having inputs and outputs coupled to the input device, the display device, the local clock, memory, the transmitter /receiver and the virtual master clock processing means.
2. The system of claim 1, wherein the transmitter /receiver further comprises: a receiver for receiving radio signals and converting them to digital signals, the receiver having an input and an output, the input coupled to the antenna; a transmitter for receiving digital signals and converting them to radio signals, the transmitter having an input and an output, the output coupled to the antenna; and a buffer for storing data, the buffer coupled to the receiver and the transmitter for storing digital signals from each, the buffer having inputs and outputs, an output of the buffer coupled to the input of the transmitter, and an input of the buffer coupled to the output of the receiver, the inputs and outputs of the buffer also coupled to the processing unit.
3. The system of claim 1, wherein the virtual master clock processing means further comprises: an adjustment timer for maintaining a time count indicating when the local clock is to be adjusted and when frequency hopping occurs; a plurality of buffers; and control circuitry.
4. The system of claim 1, wherein each message includes a value of the local clock of the sending node when the message is transmitted, and the virtual master clock processing means determines the value of the virtual master clock by calculating the average difference between the value of the local clock when the message is received and the value stored in the received message.
5. A computer implemented method for synchronizing a plurality of node computer systems in a communications network, the node computer systems being coupled by a media, the method comprising the steps of: storing time synchronization information as part of a message at a first node computer system; sending the message over the network using the first node computer system; receiving the message at a second node computer system in the communications network; extracting the time synchronization information from the message at the second node computer system; and adjusting the local clock of the second node computer system using the time synchronization information.
6. The method of claim 5, further comprising the step of monitoring the availability of the media used by the network for communication using the first node computer system before the step of sending the message.
7. The method of claim 5, wherein the time synchronization information is stored in the message just prior to the step of sending the message and the time synchronization information comprises the value of the local clock of the first node computer system just prior to the sending step.
8. The method of claim 5, further comprising the steps of: storing a local clock value for the second node computer system at the time the message is received; and wherein the step of adjusting includes a comparison of the local clock value of the storing step to the time synchronization information from the extracting step.
9. The method of claim 5, further comprising the steps of: receiving the message at a third node computer system in the communications network; extracting the time synchronization information from the message at the third node computer system; and adjusting the local clock of the third node computer system using the time synchronization information.
10. The method of claim 5, further comprising the steps of: storing time synchronization information as part of a second message at a third node computer system; sending the second message over the network using the third node computer system; receiving the second message at a second node computer system in the communications network; extracting the time synchronization information from the second message at the second node computer system; and adjusting the local clock of the second node computer system using both the time synchronization information from both the message and the second message.
11. The method of claim 5, further comprising the steps of: receiving the message at a plurality of other nodes in the communications network; extracting the time synchronization information from the message at each of the plurality of other nodes; and adjusting the local clock of each of the plurality of other nodes using the time synchronization information respectively extracted.
12. A computer implemented method for sending a synchronizing message to a plurality of node computer systems in a communications network, the node computer systems being coupled by a media, the method comprising the steps of: preparing a message' structure including a time stamp portion, a network identification portion, and a data & address portion at a first node computer system; passing the message to the transmitter /receiver of the first node computer systems; storing the value of the local clock in the time stamp portion of the message just before transmission of the message over the network; and sending the message over the network using the first node computer system;
13. The method of claim 12, wherein the step of passing the message to the transmitter /receiver is accomplished by using a processing unit to notifying the transmitter /receiver of the location of the message in memory.
14. The method of claim 12, further comprises the steps of: checking the media for availability; determining whether the network is busy; and waiting a specified amount of time and the returning to the checking step if the media is busy.
15. The method of claim 12, wherein the value stored in the time stamp portion of the message can be set to a predetermined value if the message is special type that has no effect on synchronization.
16. A computer implemented method for receiving messages and synchronizing a first node computer system in a communications network having a plurality of node computer systems being coupled by a media, the method comprising the steps of: receiving a message at the first node computer system in the communications network if any messages are sent over the network; extracting the time synchronization information from any messages sent over the network at the first node computer system; and adjusting the local clock of the first node computer system using the time synchronization information or requesting time synchronization information.
17. The method of claim 16, wherein the step of receiving a message at the first node computer system in the communications network, further comprises the steps of: monitoring the media for a message; determining whether a message was detected on the media; returning to the monitoring step if a message was not detected on the media; transferring the incoming message from a transmitter /receiver of the first node computer system to memory of the first node computer system; and storing the value of a local clock of the first node computer system at the time the message is received in memory of the first node computer system.
18. The method of claim 16, further comprising before the adjusting step the steps of: determining whether it is time to adjust the local clock of the first node computer system; and processing and waiting for messages if it is not time to adjust the local clock of the first node computer system.
19. The method of claim 18, wherein the network is a wireless frequency hopping spread spectrum network, and the step of determining whether it is time to adjust the local clock of the first node computer system is performed by measuring whether half of the dwell time has elapsed since the last frequency hop.
20. The method of claim 18, wherein the step of processing and waiting for messages further comprises the steps of: determining whether a new message has been received; returning to the step of determining whether it is time to adjust the local clock, if no new message has been received; obtaining the new message from memory if it has been received; obtaining the time of receipt information for memory corresponding to the message; calculating the difference between the time synchronization information and the time of receipt information obtained; and maintaining an average time difference.
21. The method of claim 20, the step of processing and waiting for messages further comprises the steps of: comparing the difference between the time synchronization information and the time of receipt information obtained to a clamping value; and using the clamping value instead of the difference between the time synchronization information and the time of receipt information obtained for maintaining an average time difference if the difference between the time synchronization information and the time of receipt information obtained is greater than the clamping value.
22. The method of claim 20, the step of adjusting the local clock of the first node computer system using the time synchronization information or requesting time synchronization information, further comprises the steps of: determining whether any message has been received by the first node computer system; sending an synchronization request message over the network if no message has been received by the first node computer system; and adjusting the clock using the average time difference if a message has been received.
23. A computer implemented method for joining a wireless frequency hopping spread spectrum communications network having a plurality of node computer systems being coupled by a media with a plurality of logical channels, the method comprising the steps of: selecting a channel of the media with a first node; sending a join request message on the channel of the media; scanning the channel for a message transmitted on the channel; extracting the network identification and the time synchronization information from the message transmitted on the channel; determine whether the network identification is the same as the network the first node is joining; and adjusting the local clock of the first node using the time synchronization information from the message transmitted on the channel if the network identification corresponds to the network the first node is joining.
24. The method of claim 23, wherein the steps of the method are repeated on each of the channels utilized by wireless frequency hopping spread spectrum communications network.
25. The method of claim 24, wherein the steps of sending a join request message is repeated at least once on each channel before the steps are repeated on another channel.
26. The method of claim 24, wherein each channel is scanned for a predetermined amount of time, and the method changes channels a rate ten times greater than the hopping rate of the wireless frequency hopping spread spectrum communications network.
PCT/US1994/007545 1993-07-09 1994-07-06 Distributed time synchronization system and method WO1995002294A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU72554/94A AU7255494A (en) 1993-07-09 1994-07-06 Distributed time synchronization system and method

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/089,431 US5408506A (en) 1993-07-09 1993-07-09 Distributed time synchronization system and method
US08/089,431 1993-07-09

Publications (1)

Publication Number Publication Date
WO1995002294A1 true WO1995002294A1 (en) 1995-01-19

Family

ID=22217606

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1994/007545 WO1995002294A1 (en) 1993-07-09 1994-07-06 Distributed time synchronization system and method

Country Status (3)

Country Link
US (1) US5408506A (en)
AU (1) AU7255494A (en)
WO (1) WO1995002294A1 (en)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5509027A (en) * 1994-12-05 1996-04-16 Motorola, Inc. Synchronization method in a frequency hopping local area network having dedicated control channels
WO1998056136A2 (en) * 1997-06-03 1998-12-10 Abb Research Ltd. Method for providing time synchronization in a network
WO1999038287A1 (en) * 1998-01-23 1999-07-29 Koninklijke Philips Electronics N.V. Method for synchronizing network nodes
WO2004055682A1 (en) * 2002-12-17 2004-07-01 Kvaser Consultant Ab Schematizing of messages in distributed control and supervision system
FR2938356A1 (en) * 2008-11-10 2010-05-14 Active Circle METHOD AND SYSTEM FOR SYNCHRONIZING A SET OF SOFTWARE MODULES OF A COMPUTER SYSTEM DISTRIBUTED TO A CLUSTER OF SERVERS
EP2637459A3 (en) * 2012-03-06 2014-03-26 Techem Energy Services GmbH Method for organising and/or commissioning a network for communication and network nodes
US8902933B2 (en) 2007-05-02 2014-12-02 Tyco Fire & Security Gmbh Wireless communication system
CN111343039A (en) * 2018-12-18 2020-06-26 西蒙兹精密产品公司 Distributed time synchronization protocol for asynchronous communication systems
CN114362869A (en) * 2021-12-21 2022-04-15 国网江苏省电力有限公司电力科学研究院 Time collaborative synchronization method and device for power Internet of things nodes

Families Citing this family (95)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5602992A (en) * 1993-11-29 1997-02-11 Intel Corporation System for synchronizing data stream transferred from server to client by initializing clock when first packet is received and comparing packet time information with clock
US5579318A (en) * 1994-06-30 1996-11-26 Bellsouth Corporation Processes and apparatus for maintaining data concurrence between databases in telecommunications networks
WO1996031033A2 (en) * 1995-03-29 1996-10-03 Philips Electronics N.V. System for providing a predetermined timing relation between inputting and outputting of data; transmitter and receiver for such a system
JP3016415B2 (en) * 1995-06-14 2000-03-06 ブラザー工業株式会社 Data transfer method and data transfer system
US5666358A (en) * 1995-10-16 1997-09-09 General Instrument Corporation Of Delaware Method and apparatus for supporting TDMA operating over hybrid fiber coaxial (HFC) or other channels
USRE38619E1 (en) * 1995-10-16 2004-10-12 General Instrument Corporation Method and apparatus for supporting TDMA operating over hybrid fiber coaxial (HFC) or other channels
FR2741975B1 (en) * 1995-11-30 1998-01-09 Aeg Schneider Automation PROGRAMMABLE CONTROLLER INPUT-OUTPUT SYSTEM
JP3094900B2 (en) * 1996-02-20 2000-10-03 ヤマハ株式会社 Network device and data transmission / reception method
US5970400A (en) * 1996-04-30 1999-10-19 Magellan Corporation Adjusting the timing and synchronization of a radio's oscillator with a signal from an SATPS satellite
US6018775A (en) * 1996-07-02 2000-01-25 Gateway 2000, Inc. System with a remote wireless mass storage which provides identification of a particular mass storage stored in a cradle to the system
US5854994A (en) * 1996-08-23 1998-12-29 Csi Technology, Inc. Vibration monitor and transmission system
US6301514B1 (en) 1996-08-23 2001-10-09 Csi Technology, Inc. Method and apparatus for configuring and synchronizing a wireless machine monitoring and communication system
US5907491A (en) * 1996-08-23 1999-05-25 Csi Technology, Inc. Wireless machine monitoring and communication system
US5892981A (en) * 1996-10-10 1999-04-06 Hewlett-Packard Company Memory system and device
US5956261A (en) * 1997-03-13 1999-09-21 International Business Machines Corporation In-transit message detection for global virtual time calculation in parrallel time warp simulation
US5875320A (en) * 1997-03-24 1999-02-23 International Business Machines Corporation System and method for synchronizing plural processor clocks in a multiprocessor system
US6069887A (en) * 1997-05-28 2000-05-30 Apple Computer, Inc. Method and system for synchronization in a wireless local area network
US6034988A (en) * 1997-08-04 2000-03-07 Intellon Corporation Spread spectrum apparatus and method for network RF data communications having extended communication channels
US6466138B1 (en) 1997-09-15 2002-10-15 Andrzej Partyka Meshed telemetry system using frequency hopping for intermittent transmission
US6058137A (en) 1997-09-15 2000-05-02 Partyka; Andrzej Frequency hopping system for intermittent transmission
US6327254B1 (en) 1997-10-14 2001-12-04 Lucent Technologies Inc. Method for bandwidth sharing in a multiple access system for communications networks
US6157957A (en) * 1998-01-22 2000-12-05 Cisco Technology, Inc. Clock synchronization system and method using a continuous conversion function for a communication network
AU2004200167B2 (en) * 1998-03-12 2006-05-04 Sony Corporation Synchronizing method and bridge
JP3397124B2 (en) 1998-03-12 2003-04-14 ソニー株式会社 Synchronization method and bridge
US6169761B1 (en) * 1998-04-01 2001-01-02 Wavespan Corporation Method and transceiver using an improved protocol for a frequency hop communication system
US7224713B2 (en) 1998-04-09 2007-05-29 Andrzej Partyka Telemetry system with authentication
US6188715B1 (en) 1998-04-09 2001-02-13 Andrzej Partyka Frequency hopping system for intermittent transmission with receiver using individual tracking, FFT, and authentication
US6909728B1 (en) * 1998-06-15 2005-06-21 Yamaha Corporation Synchronous communication
JP3427971B2 (en) 1998-08-24 2003-07-22 ソニー株式会社 Communication control method
EP1112641A2 (en) 1998-09-11 2001-07-04 Sharewave, Inc. Method and apparatus for accessing a computer network communication channel
US7324544B1 (en) 1998-09-11 2008-01-29 Cirrus Logic, Inc. Network slot synchronization scheme for a computer network communication channel
US6236623B1 (en) * 1998-10-16 2001-05-22 Moore Industries System and method for synchronizing clocks in a plurality of devices across a communication channel
DE19849458A1 (en) * 1998-10-28 2000-05-04 Philips Corp Intellectual Pty Wireless network with clock synchronization
JP2000165364A (en) * 1998-11-30 2000-06-16 Sony Corp Radio network and method for time synchronization establishment among a plurality of buses
US6724729B1 (en) 1998-12-30 2004-04-20 Finisar Corporation System analyzer and method for synchronizing a distributed system
CN1166249C (en) * 1999-01-19 2004-09-08 西门子公司 Method for the time synchronisation of a computer network and computer network with time synchronisation
US7184413B2 (en) * 1999-02-10 2007-02-27 Nokia Inc. Adaptive communication protocol for wireless networks
AU758059B2 (en) * 1999-05-04 2003-03-13 Two Way Media Limited Interactive applications
DE60041470D1 (en) * 1999-05-11 2009-03-19 Canon Kk Method and apparatus for synchronization between two networks
US7042923B1 (en) * 1999-07-27 2006-05-09 Legerity, Inc. Method and apparatus for frequency hopping in a spread spectrum digital cordless telephone system
AU6440200A (en) * 1999-08-06 2001-03-05 Alexander Keck Wireless local network and method for transmitting data in the network
US7023833B1 (en) * 1999-09-10 2006-04-04 Pulse-Link, Inc. Baseband wireless network for isochronous communication
US20040090983A1 (en) * 1999-09-10 2004-05-13 Gehring Stephan W. Apparatus and method for managing variable-sized data slots within a time division multiple access frame
US6728293B1 (en) 1999-09-14 2004-04-27 Andrzej Partyka Hopping pattern generation method in frequency hopping system for intermittent transmission
DE69936302T2 (en) * 1999-09-21 2008-02-14 Sony Corp. Method and system for cordless data communication
US6870875B1 (en) 1999-09-30 2005-03-22 Andrzej Partyka Transmission of urgent messages in frequency hopping system for intermittent transmission
US6967974B1 (en) 1999-09-30 2005-11-22 Andrzej Partyka Transmission of urgent messages in telemetry system
US7088795B1 (en) * 1999-11-03 2006-08-08 Pulse-Link, Inc. Ultra wide band base band receiver
US6438702B1 (en) * 1999-12-21 2002-08-20 Telcordia Technologies, Inc. Method for providing a precise network time service
US7103124B1 (en) 1999-12-30 2006-09-05 Telefonaktiebolaget Lm Ericsson (Publ) Synchronization of nodes
US6894975B1 (en) 2000-01-15 2005-05-17 Andrzej Partyka Synchronization and access of the nodes in a communications network
US6731223B1 (en) 2000-01-15 2004-05-04 Andrzej Partyka Meshed telemetry system
US6925105B1 (en) 2000-05-01 2005-08-02 Andrzej Partyka Overhead reduction in system for intermittent transmission
AU2001264504A1 (en) * 2000-06-12 2001-12-24 Telefonaktiebolaget Lm Ericsson (Publ) Random identity management in scatternets
US6928061B1 (en) 2000-09-06 2005-08-09 Nokia, Inc. Transmission-scheduling coordination among collocated internet radios
US7209495B2 (en) 2000-09-28 2007-04-24 Andrzej Partyka Urgent messages and power-up in frequency hopping system for intemittent transmission
US20020041622A1 (en) * 2000-09-29 2002-04-11 David Steed Spread spectrum frequency hopping communications system
US6757318B1 (en) * 2000-10-10 2004-06-29 Computer Access Technology Corporation Apparatus and method for synchronizing with a communication network by shadowing a page response connection to the network
JP2002186037A (en) * 2000-12-12 2002-06-28 Ntt Docomo Inc Authentication method, communication system, and repeater
DE10065117A1 (en) * 2000-12-28 2002-07-04 Bosch Gmbh Robert Method and communication system for exchanging data between at least two participants via a bus system
US7016325B2 (en) * 2001-01-18 2006-03-21 Strix Systems, Inc. Link context mobility method and system for providing such mobility, such as a system employing short range frequency hopping spread spectrum wireless protocols
GB2371449A (en) * 2001-01-22 2002-07-24 Nokia Mobile Phones Ltd Synchronizing a new device to a synchronized network of devices
US7035246B2 (en) * 2001-03-13 2006-04-25 Pulse-Link, Inc. Maintaining a global time reference among a group of networked devices
WO2002103988A1 (en) * 2001-05-02 2002-12-27 Strix Systems, Inc. Wireless base station neighbor discovery in a communication system employing a short-range frequency hopping scheme
US7151757B2 (en) * 2001-05-02 2006-12-19 Strix Systems, Inc. Wireless base station to base station synchronization in a communication system, such as a system employing a short-range frequency hopping or time division duplex scheme
US7194010B2 (en) * 2001-05-02 2007-03-20 Strix Systems, Inc. Wireless base station to base station synchronization in a communication system, such as a system employing a short range frequency hopping or time division duplex scheme
US7283568B2 (en) * 2001-09-11 2007-10-16 Netiq Corporation Methods, systems and computer program products for synchronizing clocks of nodes on a computer network
EP1430627B1 (en) * 2001-09-26 2005-02-09 Siemens Aktiengesellschaft Method for synchronising nodes of a communications system
US7221686B1 (en) * 2001-11-30 2007-05-22 Meshnetworks, Inc. System and method for computing the signal propagation time and the clock correction for mobile stations in a wireless network
US20030126447A1 (en) * 2001-12-27 2003-07-03 Jacques Debiez Trusted high stability time source
US7151945B2 (en) * 2002-03-29 2006-12-19 Cisco Systems Wireless Networking (Australia) Pty Limited Method and apparatus for clock synchronization in a wireless network
US7072432B2 (en) * 2002-07-05 2006-07-04 Meshnetworks, Inc. System and method for correcting the clock drift and maintaining the synchronization of low quality clocks in wireless networks
US7274713B2 (en) * 2002-08-30 2007-09-25 Altera Corporation Cell sequence number synchronization system and method
CH704101B1 (en) * 2002-11-06 2012-05-31 Barix Ag Method and apparatus for synchronized playback of data streams.
DE10260807B4 (en) * 2002-12-23 2007-07-05 Siemens Ag Transmission method for a time reference via a transmission medium and timer block corresponding thereto
US6987709B2 (en) * 2003-02-03 2006-01-17 Hewlett-Packard Development Company, L.P. Device time setting method, program and system
ATE360298T1 (en) * 2003-06-26 2007-05-15 Koninkl Philips Electronics Nv METHOD FOR CLOCK SYNCHRONIZATION OF WIRELESS 1394 BUSES FOR NODES CONNECTED VIA IEEE 802.11 LAN NETWORK
JP4211529B2 (en) * 2003-08-06 2009-01-21 日本電気株式会社 Channel selection method and radio station and program used therefor
US7340630B2 (en) * 2003-08-08 2008-03-04 Hewlett-Packard Development Company, L.P. Multiprocessor system with interactive synchronization of local clocks
US7349362B2 (en) * 2005-06-29 2008-03-25 Meshnetworks, Inc. Method and system for implementing the time division multiple access method to AD-HOC multihopping wireless networks
US7948833B2 (en) * 2007-07-25 2011-05-24 Computime, Ltd. Clock setup over a network
US8826060B2 (en) * 2007-08-03 2014-09-02 Sap Ag Correlation of log information in a distributed computing environment using relative timestamps
US8532003B2 (en) * 2008-10-03 2013-09-10 Synapsense Corporation Apparatus and method for managing packet routing through internally-powered network devices in wireless sensor networks
US8600560B2 (en) 2008-12-30 2013-12-03 Synapsense Corporation Apparatus and method for controlling computer room air conditioning units (CRACs) in data centers
US8538584B2 (en) 2008-12-30 2013-09-17 Synapsense Corporation Apparatus and method for controlling environmental conditions in a data center using wireless mesh networks
US8761084B2 (en) * 2009-01-14 2014-06-24 Synapsense Corporation Apparatus and method for establishing data communication in a time-synchronized mesh wireless network during time synchronization failures
US8811377B1 (en) 2010-08-30 2014-08-19 Synapsense Corporation Apparatus and method for instrumenting devices to measure power usage using a multi-tier wireless network
US8583042B2 (en) * 2010-09-30 2013-11-12 St-Ericsson Sa Channel randomization for backoff efficiency improvement
US9185003B1 (en) * 2013-05-02 2015-11-10 Amazon Technologies, Inc. Distributed clock network with time synchronization and activity tracing between nodes
DE102014226400B4 (en) * 2014-12-18 2017-07-13 Telemotive Aktiengesellschaft Data acquisition device, network and procedures
US10531451B2 (en) * 2015-05-18 2020-01-07 Telefonaktiebolaget Lm Ericsson (Publ) Time advance for dual connectivity
CN107864235B (en) * 2017-12-19 2021-03-30 宁波公牛电器有限公司 Address allocation method and device for shunt circuit breaker of intelligent distribution box
US10764770B2 (en) * 2018-08-29 2020-09-01 Landis+Gyr Innovations, Inc. Detecting network devices without joining a network
CN111106891A (en) * 2019-06-29 2020-05-05 长沙北斗产业安全技术研究院有限公司 Relative time synchronization method, device and system
CN111324046B (en) * 2020-02-28 2022-10-25 中国电力科学研究院有限公司 Method and system for performing cooperative operation on distributed simulation system

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4866606A (en) * 1984-06-22 1989-09-12 Austria Miktosystem International Gmbh Loosely coupled distributed computer system with node synchronization for precision in real time applications
WO1991007030A1 (en) * 1989-10-24 1991-05-16 Motorola, Inc. Distributed synchronization method for a wireless fast packet communication system
EP0523362A2 (en) * 1991-06-21 1993-01-20 International Business Machines Corporation Broadcast-initiated bipartite frame multi-access protocoll

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE3333714A1 (en) * 1983-09-17 1985-04-04 Standard Elektrik Lorenz Ag, 7000 Stuttgart CIRCUIT ARRANGEMENT FOR FRAME AND PHASE SYNCHRONIZATION OF A RECEIVING SAMPLE CLOCK
SE452231B (en) * 1986-03-07 1987-11-16 Philips Norden Ab PROCEDURE FOR SYNCHRONIZING CLOCKS INTO A LOCAL BUS TYPE NETWORK
US4736393A (en) * 1986-04-16 1988-04-05 American Telephone And Telegraph Co., At&T Information Systems, Inc. Distributed timing control for a distributed digital communication system
DE3833940A1 (en) * 1988-09-22 1990-04-05 Siemens Ag METHOD FOR RE-SYNCHRONIZING A SWITCH CENTER IN A TELECOMMUNICATION NETWORK
US4926446A (en) * 1988-11-25 1990-05-15 Alberta Telecommunications Research Centre Method and apparatus for precision time distribution in telecommunication networks
US5001730A (en) * 1989-03-31 1991-03-19 International Business Machines Corporation Clock synchronization algorithm for address independent networks
US5200957A (en) * 1989-06-26 1993-04-06 Telefonaktiebolaget L M Ericsson Mobile assisted handoff

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4866606A (en) * 1984-06-22 1989-09-12 Austria Miktosystem International Gmbh Loosely coupled distributed computer system with node synchronization for precision in real time applications
WO1991007030A1 (en) * 1989-10-24 1991-05-16 Motorola, Inc. Distributed synchronization method for a wireless fast packet communication system
EP0523362A2 (en) * 1991-06-21 1993-01-20 International Business Machines Corporation Broadcast-initiated bipartite frame multi-access protocoll

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5509027A (en) * 1994-12-05 1996-04-16 Motorola, Inc. Synchronization method in a frequency hopping local area network having dedicated control channels
WO1998056136A2 (en) * 1997-06-03 1998-12-10 Abb Research Ltd. Method for providing time synchronization in a network
WO1998056135A2 (en) * 1997-06-03 1998-12-10 Abb Research Ltd. Method for providing time synchronization in a network
WO1998056136A3 (en) * 1997-06-03 1999-03-04 Abb Research Ltd Method for providing time synchronization in a network
WO1998056135A3 (en) * 1997-06-03 1999-03-04 Abb Research Ltd Method for providing time synchronization in a network
WO1999038287A1 (en) * 1998-01-23 1999-07-29 Koninklijke Philips Electronics N.V. Method for synchronizing network nodes
US8037226B2 (en) 2002-12-17 2011-10-11 Xinshu Management, L.L.C. Time and event based message transmission
US10579562B2 (en) 2002-12-17 2020-03-03 Callahan Cellular L.L.C. Time and event based message transmission
US11157429B2 (en) 2002-12-17 2021-10-26 Callahan Cellular L.L.C. Time and event based message transmission
US7711880B2 (en) 2002-12-17 2010-05-04 Lars-Berno Fredriksson Schematizing of messages in distributed control and supervision system
WO2004055682A1 (en) * 2002-12-17 2004-07-01 Kvaser Consultant Ab Schematizing of messages in distributed control and supervision system
US8364875B2 (en) 2002-12-17 2013-01-29 Xinshu Management, L.L.C. Time and event based message transmission
US10025738B2 (en) 2002-12-17 2018-07-17 Callahan Cellular L.L.C. Time and event based message transmission
US8700836B2 (en) 2002-12-17 2014-04-15 Xinshu Management, L.L.C. Time and event based message transmission
US9594709B2 (en) 2002-12-17 2017-03-14 Callahan Cellular L.L.C. Time and event based message transmission
US9455764B2 (en) 2007-05-02 2016-09-27 Tyco Fire & Security Gmbh Wireless communication system
US8902933B2 (en) 2007-05-02 2014-12-02 Tyco Fire & Security Gmbh Wireless communication system
US9893760B2 (en) 2007-05-02 2018-02-13 Tyco Fire & Security Gmbh Wireless communication system
WO2010052441A1 (en) * 2008-11-10 2010-05-14 Active Circle Method and system for synchronizing a set of software modules of a computing system distributed as a cluster of servers
FR2938356A1 (en) * 2008-11-10 2010-05-14 Active Circle METHOD AND SYSTEM FOR SYNCHRONIZING A SET OF SOFTWARE MODULES OF A COMPUTER SYSTEM DISTRIBUTED TO A CLUSTER OF SERVERS
EP2637459A3 (en) * 2012-03-06 2014-03-26 Techem Energy Services GmbH Method for organising and/or commissioning a network for communication and network nodes
CN111343039A (en) * 2018-12-18 2020-06-26 西蒙兹精密产品公司 Distributed time synchronization protocol for asynchronous communication systems
CN114362869A (en) * 2021-12-21 2022-04-15 国网江苏省电力有限公司电力科学研究院 Time collaborative synchronization method and device for power Internet of things nodes

Also Published As

Publication number Publication date
US5408506A (en) 1995-04-18
AU7255494A (en) 1995-02-06

Similar Documents

Publication Publication Date Title
US5408506A (en) Distributed time synchronization system and method
US6466608B1 (en) Frequency hopping medium access control protocol for a communication system having distributed synchronization
US4757460A (en) Communications network with individualized access delays
US5124698A (en) Method and apparatus for synchronizing radio transmitters in a paging network
US5875179A (en) Method and apparatus for synchronized communication over wireless backbone architecture
US5844900A (en) Method and apparatus for optimizing a medium access control protocol
US7573913B2 (en) Synchronization of timing advance and deviation
US6292508B1 (en) Method and apparatus for managing power in a frequency hopping medium access control protocol
US5287384A (en) Frequency hopping spread spectrum data communications system
US5293645A (en) Apparatus and method for locating mobile and portable radio terminals in a radio network
US5661727A (en) Schemes to determine presence of hidden terminals in wireless networks environment and to switch between them
US4769807A (en) Loop back control system
EP0483548A1 (en) Transceiver for extending a CSMA/CD network for wireless communication
EP0577780A1 (en) Method for controlling the scheduling of multiple access to communication resources
EP0528639B1 (en) Data communications network
WO1995002295A1 (en) System and method for sending and responding to information requests in a communications network
US5706274A (en) CSMA with dynamic persistence
US6088344A (en) Packet radio systems
US6937609B1 (en) Method for improving efficiency in a time sharing network
US7002947B1 (en) Method and system for data collision avoidance in a wireless communications system
US7180970B1 (en) Automatic link establishment using external synchronization
US5678193A (en) Determination of an initial launch time in a simulcast communication system
JPH0348704B2 (en)
JP2000101482A (en) Radio communication system
JP2758762B2 (en) Auto fallback apparatus and method

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AT AU BB BG BR BY CA CH CN CZ DE DK ES FI GB GE HU JP KG KP KR KZ LK LU LV MD MG MN MW NL NO NZ PL PT RO RU SD SE SI SK TJ TT UA UZ VN

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: CA