Abstract-
synchronization and plesiochronous mode are also applicable. The master oscillator, called the primary reference clock (PRC), is a very accurate frequency source with a long-term stability better than 10 -11 . Normally atomic clocks provide the PRC. These may be autonomous or traceable to Universal Time Coordinated (UTC), using the Global Positioning System (GPS), the Global Navigation Satellite System (GLONASS) or the Galileo system. Most slave clocks contain a crystal oscillator as part of a phase locked loop (PLL) and can fall to a holdover mode when input synchronization signals are absent. Phase noises of master and slave oscillators, different conversions of information signals, SONET/SDH pointer adjustments, diurnal temperature variations and other random components cause a whole range of phase instabilities known as jitter and wander. The quality and number of master clocks, slave clocks, synchronization links and the amount of jitter and wander, are the main factors defining the quality of clock synchronization and the quality of services the information network offers.
To estimate phase instabilities existing within a network several special criteria were proposed by standards organizations. These include Maximum Time Interval Error (MTIE), Time Deviation (TDEV) etc with requirements specified in the form of standard limitation masks [1, 2] .
Computer and data communication network applications also require maintaining accurate time-of-day information. For networks built using TCP/IP protocol suite Network Time Protocol (NTP) or Simple Network Time Protocol (SNTP) can be used to perform synchronization and timing functions. Distributed NTP servers with different timing accuracy are organized in a hierarchical structure for the Internet and intranets. Timing information is distributed from servers to clients via specialized message exchange and stored by clients in a well-known format [3] .
Global trends towards real-time services, improvements in voice over IP technologies, integration of traditional voice and data networks and the increasing popularity of high speed Ethernet networks in Local and Metropolitan areas bring new challenges to network design and in particular to the organization of clock synchronization. In compliance with ongoing work led by the Metropolitan Ethernet Forum (MEF) communication network infrastructure, traditionally built on legacy SONET/SDH equipment can now be replaced by Ethernet switches at much lower cost and still ensure delivery of carrier-class services required by the end user [15] .
In response to emerging market requirements for clock synchronization with sub-microsecond timing accuracy, initially primarily driven by new test and measurement applications, a new protocol for synchronization called the Precision Time Protocol (PTP) was developed in 2002 [4] . In addition to specialized message exchange between master and slave clocks PTP specifies a hardware time stamping mechanism to bypass delays in protocol stacks and correct for non-deterministic Ethernet delays. PTP Version 2, with expanded functionality, is currently being developed with strong support from communication, industrial automation, power, military, and test and measurement industries. Development of the NTP Version 4, with additional features of security, etc., is also on its way.
Changes in the market place and standardization activities require that timing and synchronization continue to be a current and active area of research and development, which raises a need for tools and instruments to assist in the analysis of such systems. Modeling and simulation have been traditionally used to analyze processes in complex systems. Although time transfer networks were described mathematically [5] and selective analysis was performed using simulations, e.g. noise accumulation in chains on slave clocks [6, 7] , a comprehensive tool with a wide spectrum of capabilities specifically aimed to analyze synchronization in communication networks would be very useful. Such tool is introduced in this paper, accompanied by a description of the underlying modeling technique, graphical user interface and selected simulation results. The tool supports analysis of stability, quality of control, time to converge, calculations of standard Maximum Time Interval Error (MTIE) and Time Deviation (TDEV) parameters, etc. Currently the tool offers an analysis of synchronization in telecommunication networks built using PDH and SONET/SDH technologies. Tool enhancements are required to support TCP/IP and Ethernet-based networks.
II. MODELING TECHNIQUE
A general modeling technique described in this paper allows derivation of a discrete model of a simulated system from its transfer function. The technique is applicable to both linear and non-linear systems with any input stimulus. System complexity is limited only by the processing power of the computer.
The transformation from the continuous-time p-domain to the discrete-time z-domain is performed using the Boxer-Thaler method, which was shown to be more accurate than the commonly used bilinear method. For this transformation the SMatrix method was used. General expressions for a system of any order and pre-calculated matrices for up to 32nd order were obtained to facilitate the simulation of complex systems.
A. General Algorithm and Model
A general algorithm used for modeling is as follows. For any kth-order system with a given continuous transfer function Coefficients are determined as 
B. Transformation from the p-domain to the z-domain
To compute processes in discrete-time systems different transformation methods from the p-domain to the z-domain can be used. Among these methods, the bilinear or Tustin transformation [8] , Madwed and Boxer-Thaler transformation [9, 10, 11] , all offer different degrees of accuracy and computational complexity.
General expressions for the Boxer-Thaler transformation are shown in Table 1 . Expressions for the bilinear transformation for higher powers of k are found simply by multiplying the expression for by itself k times.
The difference between these two transformations is obvious from the general expressions. It has been previously shown [9, 10] that better results can be obtained using the Boxer-Thaler transformation due to its more accurate nature.
Δϕ 1

C. The S-Matrix Method
Even for simple systems many complex calculations are required to obtain a discrete equivalent of continuous transfer functions using any transformation method. To facilitate this task the so-called Q-Matrix for the bilinear and Boxer-Thaler transformations were formulated and are widely used [10, 11] .
Independently and unaware of that work on the other side of the "iron curtain" in place at that time, a similar S-Matrix method was proposed for the Boxer-Thaler transformation with a general expression formulated for a system of any order and S matrices pre-calculated up to order 32 [12] . After its formulation the S-Matrix method was extensively used to calculate processes in discrete-time systems and in simulations.
Q-Matrix expressions correspond to S-Matrix expressions, which increases the creditability of the correctness of their formulation. The modeling technique described in this paper uses the S-Matrix method.
III. MODEL OF CLOCK SYNCHRONIZATION
Clock synchronization can be described as an automatic control system, composed of master and slave clocks, connected via synchronization links. Master clocks are generally good quality reference oscillators, while slave clocks normally contain phase locked loops, traceable to a higher accuracy clock. Many sources of jitter and wander are present both in the clocks themselves and in links between them.
A general block diagram of a clock synchronization model consisting of n elements is shown in Fig. 1 To obtain a complete model of a clock synchronization system, models of a slave clock, a master clock and a synchronization link were developed. For clocks with multiple synchronization inputs C matrix elements can be used as weighting coefficients that reflect the quality of input synchronization signal and quality of synchronization link from a particular source.
Master clocks with the highest accuracy may have no synchronization inputs; so all coefficients in its row will be equal to 0. The same is true for a slave clock when it falls into holdover mode in response to losing all synchronization inputs.
ij c A. Slave Clock Model
A slave clock normally contains a phase locked loop, traceable to a higher accuracy clock. The general block diagram, Fig. 2 , shows the main PLL components: phase detector (PD), phase detector filter (PDF), low-pass filter (LPF) and voltage-controlled oscillator (VCO).
Applying the general modeling technique described in Section II the model of a slave clock was derived as follows.
The first equation in the slave clock model is the equation of a closed loop system, characterizing phase error as follows: As shown in Fig. 2 , the control signal then passes through a phase detector filter. For a first-order PDF the recursive equation (2) can be written as: 
S
After leaving the PD the control signal goes through the low-pass filter. For a second-order LPF the recursive equation (2) 
Coefficients 0 1 2 0 1 2 are calculated from the coefficients of a LPF transfer function using the second order matrix .
A A A B B B
'' '' '' '' '' '' , , , , 2
S
After passing through the low-pass filter, the control signal is fed to the voltage-controlled oscillator to tune its frequency. The relationship between the control voltage and the oscillator frequency is defined by the oscillator characteristic. For a linear oscillator characteristic with a correlation coefficient :
, and in terms of phase
where Δω is the oscillator frequency variation,
( )
Δϕ t is the oscillator phase variation, and Δu 2 is the control voltage variation.
In the p-domain (8) can be written as:
. (9) ( ) ( )
. (10) Coefficients are determined using the matrix .
, , , 1 
S
Various sources of PLL noises, such as PD noise, VCO noise, quantization noise can optionally be added to the slave clock model. A good description of noise sources in PLLs is given in [13] .
B. Master Clock Model
A master clock model includes its frequency stability, longterm and short-term accuracy. Stability is modeled as a systematic frequency variation with given maximum offset max and accuracy is modeled as additive white Gaussian noise with a given maximum variation a .
Δf ac
The master clock model for the period of simulation in days is follows: 
nT o nT o nT o nT T T T r nT r nT c s t c a c c s t c c sim
C. Synchronization Link Model
A synchronization link model that takes into account the propagation delay τ is obtained from the transfer function of a delay block:
Using (2) the model can be written as follows:
Coefficients are determined using the matrix .
A A B B
S
Simulations assume a constant propagation delay for a given synchronization link. Model enhancements are required to include variable and asymmetrical delays, which are present in real-life networks.
Phase jumps, frequency offsets, jitter and diurnal wander, which are typical network impairments, are optional additions to the synchronization link model.
IV. SIMULATION TOOL
Using the described modeling technique a simulation tool was developed by students at the St. Petersburg State University of Telecommunications, Russia. The tool is targeted for use in a MS Windows environment with the computational part written in the standard ANSI C++ programming language and graphical user interface (GUI) written in XML language.
Input parameters for the tool include, but are not limited to, the number and type of clocks, their connectivity, parameters of slave clocks and sources of jitter and wander. A choice of various input stimulus is offered, with phase jump and frequency jump being among the possible choices. Observation intervals for the MTIE and the TDEV calculations are also user configurable.
From the main program window, Fig. 3 , a user can create a clock synchronization system by selecting clocks from a list of predefined models or by creating his own system from a list of clock components as shown in Fig. 4 . Clock parameters, including a type of phase detector, noise sources and input stimulus, are configured in the node's property menu, Fig. 5 . Once all nodes are created and configured, they can be connected using links menu, as shown in Fig. 6 . This tool has been widely used since it was created for analysis of clock synchronization elements and complete network synchronization systems. Due to its modular structure and scalability any network topologies can be analyzed with various clocks and links included in simulations. For example, chains of slave clocks represented by SDH equipment clocks (SECs), with or without stand-alone synchronization equipment (SASE), can be modeled. Various fault tolerance scenarios can be considered, including switching to a standby synchronization source, restoration of an original synchronization source, fall back into holdover mode upon losing all synchronization sources, etc. 
V. SELECTED SIMULATION RESULTS
To illustrate the tool capabilities let us demonstrate selected simulation results obtained for the analysis of different synchronization systems.
System stability is generally a very important requirement enforced on automatic control systems. Depending on system and slave clock parameters the whole system may or may not return to a normal mode of operation after an unexpected disturbing stimulus is applied. Stability analysis for synchronization systems with given parameters can be performed using the so-called D-splitting method. The method allows defining margins for system and clock parameters to ensure its stable operation. The quality of control characteristics, e.g. a response to a phase or frequency jump, can be analyzed for stand-alone slave clocks and for a complete system. Different types of slave clocks were evaluated using a phase jump as an input stimulus.
Results were compared to standard masks for devices of appropriate types. On network level chains with a various number of SEC slave clocks were modeled. The time to acquire a synchronous mode of operation when slave clocks are controlled by higher accuracy master clocks is an important parameter for many systems. Transient processes happen at the time of initial system startup, switching to an alternative synchronization source, restoring a preferable synchronization connection and falling in and out of a holdover mode. The time to converge was evaluated for systems with a different number of synchronization nodes. As shown in Fig. 9 the number of nodes affects the time to converge much more in systems with a smaller number of nodes.
Noise accumulation in a long chain of slave clocks has been an area of concern for many synchronization systems. To address this issue simulation were performed for chains of SEC slave clocks with and without SASE clock. The MTIE results were obtained for chains of SEC slave clocks with the noise of their oscillators included in the model. The plots in Fig. 11 show that adding a SASE clock into a chain can dramatically improve the noise characteristics of the whole synchronization system. The developed tool was compared with the commercially available simulator MATLAB 6.5, which has a specialized library for analysis of synchronization systems. Experiments show that simulation results obtained using these programs are in agreement, with variance of less than 1%, but the time required to run the simulations is significantly less when the developed package is used. Analyzing identical systems with observation time τ = 100s, simulations using MATLAB take 2 times longer and with observation time τ = 1000s 3.5 times longer than simulations using the developed package. Fig. 12 illustrates simulation time as a function of observation interval for simulations of three linear systems, performed using the developed tool and MATLAB 6.5. 
VI. CONCLUSION
Clock synchronization and timing continue to be a current and active area of research and development. The modeling technique and a simulation tool described in this paper were specifically developed to assist in the analysis and design of clock synchronization systems. The tool has a friendly easy-touse graphical user interface and supports detailed analyses of synchronization system stability, characteristics of quality of control, time to converge, calculations of standard MTIE and TDEV parameters, etc. The modular structure of the underlying model allows for easy modifications, e.g. to include new clock types or to add calculations of a new quality criteria.
The tool can be enhanced by including an optional variable delay to the synchronization link model, adding support for analysis of clock synchronization in TCP/IP and Ethernetbased networks, etc. Comparison with the commercially available simulator MATLAB 6.5 has shown an agreement of simulation results, with variance of less than 1%, and that a significantly smaller simulation time is required using the tool, introduced in this paper.
