An apparatus for synchronizing devices includes a central access point node configured to utilize a low latency protocol to transmit a series of synchronization messages to the devices, transmit and receive data acquisition commands and responses from the devices using a high reliability protocol different from the low latency protocol, and calculate and apply relative clock offsets for each device based on the series of synchronization messages. The apparatus may also account for failure in delivery of a portion of the series of synchronization messages by recording timestamp data at the devices to send to the central access point prior to the central access point calculating the relative clock offsets.
|
12. An apparatus for synchronizing devices in which synchronization messages may be lost comprising:
a central access point node having a processor in communication with memory, the central access point node configured to:
utilize a low latency protocol to transmit a first series of synchronization messages to the devices, each synchronization message in the first series including a central access point node timestamp;
transmit data acquisition commands to the devices using a high reliability protocol different from the low latency protocol;
receive a second series of synchronization messages responsive to the first series from the devices using a high reliability protocol different from the low latency protocol, wherein the second series is smaller than the first series due to lost messages and each synchronization message of the second series includes a corresponding device timestamp respective to each device, wherein the device timestamp derives from a clock of each device;
calculate an intermediate average clock offset for each device, the intermediate average clock offset being equal to a difference between the central point node timestamp and the device timestamp for each synchronization message of the second series;
calculate an overall relative clock offset equal to an average of the intermediate average clock offsets for each device; and
synchronize the clock of each device by applying the overall relative clock offset for each device.
1. A method for synchronizing devices from a central access point node in which synchronization messages may be lost, the method comprising steps of:
utilizing a low latency protocol from the central access point node to the devices to transmit a first series of synchronization messages, each synchronization message in the first series including a central access point node timestamp;
transmitting a second series of synchronization messages from the devices to the central access point node in response to the first series of synchronization messages, wherein the second series is smaller than the first series due to lost messages and each synchronization message of the second series includes a corresponding device timestamp respective to each device, wherein the device timestamp derives from a clock of each device
calculating an intermediate average clock offset for each device, the intermediate average clock offset being equal to a difference between the central point node timestamp and the device timestamp for each synchronization message of the second series;
calculating an overall relative clock offset equal to an average of the intermediate average clock offsets for each device;
synchronizing the clock of each device by applying the overall relative clock offset for each device;
transmitting data acquisition commands from the central access point node to the devices using a high reliability protocol different from the low latency protocol; and
receiving responses to the data acquisition commands at the central access point node from the devices.
2. A method as recited in
3. A method as recited in
4. A method as recited in
5. A method as recited in
6. A method as recited in
7. A method as recited in
8. A method as recited in
9. A method as recited in
10. A method as recited in
11. A method as recited in
13. An apparatus as recited in
14. An apparatus as recited in
15. An apparatus as recited in
|
1. Field of the Disclosure
The subject disclosure relates to communication in sensing, monitoring and control systems, and more particularly to synchronizing wireless devices used on board aircraft.
2. Background of the Related Art
In recent years, the aerospace industry has been actively working on using wireless communication as a replacement for wired data connections in aircraft systems. Some benefits of wireless as opposed to traditionally wired sensor include weight and complexity reductions, simplified installation and maintenance, easier system reconfiguration as well as better diagnostic analysis. Additionally, new sensing technologies and aircraft subsystems are enabled by utilizing wireless technology, which eliminates additional design and installation costs and limits the additional wiring weight.
Mechanical and structural health monitoring and diagnostic systems particularly benefit from wireless technology. At present, wider use of such systems is hampered by the increased cost and complexity of the required wiring, which can often outweigh the potential gains. If no additional wiring were necessary, such systems might be more readily used, which would lead to significant improvements in maintenance costs and in aircraft reliability.
Most sensing and actuation systems require some degree of synchronicity between different elements. For example, a mechanical diagnostic system may collect vibration data from multiple sensors. For correct interpretation of multi-dimensional vibration data, it is necessary to make sure that the acquired signals correspond to the same intervals in time. The synchronization is typically achieved in one of two ways. The first approach is to devise a method to make sure that all sensors start their data acquisition at the same time. The second approach is to have all sensor nodes measure their local time according to well synchronized clocks.
The two approaches to synchronization are in fact equivalent. If it is possible to command several sensor nodes to perform a certain task starting at the same time, then the task may involve starting or resetting their clocks. If clock resets are done simultaneously, then the clocks will be closely synchronized for some time provided their rates do not differ too much. On the other hand, if the clocks are tightly synchronized, then the sensors may be commanded to perform the task of interest, such as to start data acquisition, at particular time values according to their clocks. In other words, the respective sensor's reading can be correlated in such way that the readings correspond to the same physical time instance.
Several techniques for synchronization of wireless devices are known and typically involve exchanges of time-stamped messages. Based on known send and receive times of sent messages, offsets and rate differences may be estimated between the clocks of those devices. For example, see “Protocols and architectures for wireless sensor networks” by Holger Karl and Andreas Willig, (published by John Wiley & Sons, Ltd. in the year 2005, hereinafter the Karl/Willig approach), which is incorporated herein by reference.
The Karl/Willig approach rests on the assumption that propagation and processing delays of the messages are symmetric and statistically constant in time. That is, it is assumed that any random delays in delivering a message from wireless node N1 to the wireless node N2 are distributed in the same way as message delivery delays from wireless node N2 to wireless node N1, and this statistical distribution is stationary in time. Furthermore, the accuracy of the resulting clock synchronization depends on the variability of message delivery delays. Generally, as the variance of message delivery delays gets larger, so does the synchronization error. Therefore, for synchronization to be accurate in the Karl/Willig approach, it is desirable to have as little variance in message delivery delays as possible.
In an effort to reduce development costs and to leverage the huge level of investment in consumer wireless technology, it is desirable to build wireless aircraft systems using commercial off-the-shelf (COTS) wireless components. COTS products typically do not allow access to lower level protocol functions but instead interface with the sensing device above a high-level network protocol. For example, wireless devices using the standard 802.11 protocol may be commercially available in form of modules allowing communication via TCP or UDP protocols.
Use of high level protocols is desirable because the software development costs are reduced and communication reliability is increased. The TCP protocol particularly represents years of development of reliable network communication and includes many built-in mechanisms to ensure dependable delivery of large quantities of data. In contrast, the much simpler UDP protocol does not include such reliability mechanisms, so the communication link may experience high and unpredictable message losses. For this reason, from the software development point of view, the use of TCP may be more attractive than UDP, because TCP reduces or eliminates the need to add customized reliability mechanisms.
There are problems associated with high level communication protocols when synchronizing is required because, there is uncertainty about the exact time of delivery. The latency of a particular message cannot be fully predicted due to high level protocols such as TCP using multiple software layers as well as complicated acknowledgement, retransmission, and packet scheduling algorithms. The unpredictable latency creates a difficulty with performing synchronization of end devices using these high level protocols.
The subject disclosure has recognized and addressed the need to effectively synchronize sensors and other system elements that communicate wirelessly using high level commercial protocols. In one method, commercially available high level protocols, such as TCP, are used for reliable wireless transmission of sensor data. However for synchronization purposes, the method switches operation to a less complicated, potentially less reliable, but simpler protocol with limited and/or more consistent latency, such as UDP. In order to accommodate the higher message losses associated with the simpler protocol, a number of approaches are developed to still efficiently complete accurate synchronization calculations. Hence, the method allows utilizing the high reliability of complex packet-based commercial-off-the-shelf protocols for data transfer while still allowing for tight synchronization. As a result, the cost and development effort of the wireless sensing systems is desirably lower.
In one embodiment, the subject technology is directed to a method for synchronizing a plurality of wireless devices including the steps of sending a set of multiple reference messages from an access point to each of the plurality of devices, recording, at each device, a timestamp corresponding to each of the reference messages that is received, sending from each of the wireless devices a response to a request for the timestamps corresponding to the reference messages, and determining relative clock offsets between each of the wireless devices using the timestamps. The devices may be sensors, control systems, monitoring systems and the like.
In another embodiment, the subject technology is a method for synchronizing devices from a central access point node, the method including the steps of utilizing a low latency protocol between the central access point node and the devices to transmit a series of reference broadcasts, calculating and applying relative clock offsets for each device based on the series of reference broadcasts, and transmitting and receiving data acquisition commands and responses between the central access point node and the devices using a high reliability protocol different from the low latency protocol.
The devices may be wireless sensors. The low latency protocol may be UDP and the high reliability protocol may be TCP. The series of reference broadcasts can include timestamp pairs sent to first and second devices. The method may also include accounting for failure in delivery of a portion of the series of reference broadcasts by utilizing each broadcast received at the first and second device nodes, and calculating at the central access point node an intermediate quantity for each device based on timestamps sent from each device.
The method may calculate the clock offset using a subset of the series of reference broadcasts. For example, the subset can be broadcasts with minimal propagation and processing delays. The subset could be a simple percentage such as 50% of the series of reference broadcasts, only messages with delays below a predetermined threshold, a certain amount such as a statistically significant sample size, and the like. The method also can calculate a clock drift for at least one of the devices based on the series of reference broadcasts.
Another embodiment is a method for synchronizing devices from a central access point node including the steps of transmitting a series of reference broadcasts between the central access point node and the devices, accounting for failure in delivery of a portion of the series of reference broadcasts, collecting timestamp data based on the series of reference broadcasts, and calculating and applying relative clock offsets for each device based on the timestamp data of the series of reference broadcasts. The devices can be a first and second device in which the timestamp data from the first device is decoupled from the timestamp data of the second device.
The subject technology is also directed to an apparatus for synchronizing devices including a central access point node configured to utilize a low latency protocol to transmit a series of reference broadcasts to the devices, transmit and receive data acquisition commands and responses from the devices using a high reliability protocol different from the low latency protocol, and calculate and apply relative clock offsets for each device based on the series of reference broadcasts. The apparatus may also account for failure in delivery of a portion of the series of reference broadcasts by recording timestamp data at the devices to send to the central access point prior to the central access point calculating the relative clock offsets.
It should be appreciated that the present technology can be implemented and utilized in numerous ways, including without limitation as a process, an apparatus, a system, a device, a method for applications now known and later developed or a computer readable medium. These and other unique features of the system disclosed herein will become more readily apparent from the following description and the accompanying drawings.
So that those having ordinary skill in the art to which the disclosed system appertains will more readily understand how to make and use the same, reference may be had to the following drawings.
The present disclosure overcomes many of the prior art problems associated with synchronizing wireless systems. The advantages, and other features of the system disclosed herein, will become more readily apparent to those having ordinary skill in the art from the following detailed description of certain preferred embodiments taken in conjunction with the drawings which set forth representative embodiments of the present invention and wherein like reference letters and numerals identify similar structural elements.
Now referring to
For exchanges of synchronization messages that require lower latency, the method 100 switches to a simpler albeit less reliable protocol such as UDP. Even though not all UDP messages may reach their destination, the messages that are completed have lower and less random delivery delays than the more reliable TCP. The synchronization method of
Still referring to
By using UDP for this initial series of broadcasts, it is possible to reduce the random spread of message delays and thus to improve synchronization accuracy. Because UDP does not include any built-in reliability mechanisms, some of the reference broadcast messages may be lost. Some complications may arise when different messages are lost between the central access point node AP and sensor node N1 and between the central access point node AP and sensor node N2. As a consequence, the timestamp information from nodes N1, N2 may correspond to different sets of reference broadcasts messages. The method 100 resolves the difficulty associated with lost messages as discussed hereinbelow.
Note that for clarity,
As mentioned above, step S1 utilizes a low-latency, relatively low-reliability protocol for the initial reference series of timestamp messages. Since a larger number of the initial messages may not be delivered, the decrease in accuracy of calculating the relative clock offset between the sensor nodes N1, N2 must be overcome. For example, if the central access point node AP sends a number M of reference broadcast messages, let t1(i) and t2(i) be the receive timestamps at sensor nodes N1, N2, according to the corresponding local clocks. If all M reference broadcasts were received by the sensor nodes N1, N2, then a set of clock offset estimates between the sensor nodes N1, N2 could be defined as
O(i)12=t1(i)−t2(i)
where O(i)12 is the set and i=1 . . . M. Then, as described in the '087 application, the set of offset estimates O(i)12 may be used to calculate the overall clock offset estimate. This may be done through arithmetic mean, median, their trimmed versions (with outliers rejected), or other estimation methods now known or later developed.
Alternatively, if some number of reference messages are lost at the sensor nodes N1, N2, then the number of individual offset estimates O(i)12 may become small. For example, if 10% of messages fail to arrive at the sensor nodes N1, N2, then the number of available estimates in the set O(i)12 is reduced by up to 20%. In a more severe case, a loss of 40% of messages at each sensor node N1, N2 may result in up to 80% of clock offset estimates in set O(i)12 being lost, or equivalently only 20% of those estimates are available. In such a case, in order to achieve the desired accuracy of clock offset estimation, it might be necessary to increase the number of reference broadcasts by five times. Further, from the point of view of energy consumption, it is desirable to minimize the number of reference broadcasts sent by the central access point node AP.
The problem of lost messages is alleviated in the method 100 of calculating the overall clock offset estimate. At step S2, the sensor nodes N1, N2 send timestamps to the central access point node AP. As noted above, if t0(i), where i=1, . . . M denotes the instances when reference broadcasts were sent from the central access point node AP, measured locally according to the central access point node clock, the timestamp difference between the central access point node AP and both sensor nodes N1, N2 is represented as follows
O(i)20=t2(i)−t0(i)
O(i)10=t1(i)−t0(i)
In the perfect case when all messages were delivered instantaneously (i.e., with zero propagation and processing delays), then the quantities O(i)20 and O(i)10 could be treated as instantaneous clock offsets between the central access point node AP and the sensor nodes N1, N2. Because of the nonzero propagation and processing delays, the numbers O(i)20 and O(i)10 do not allow any accurate synchronization between the central point access node AP and sensor node N1, or between the central point access node AP and sensor node N2. The mean values of the timestamp differences are defined by
Omean20=mean(O(i)20)
Omean10=mean(O(i)10)
In the case when all reference broadcasts are received by both sensors, the following applies
Omean12=Omean10−Omean20=mean(O(i)12)
In short, the intermediate calculation of the means O(i)20 and O(i)10 in the method 100 may not be necessary when every message is delivered. However, use of the intermediate quantities O(i)20 and O(i)10 is advantageous when some of the reference broadcast messages of step S1 are not received by the sensor nodes N1, N2.
At step S3, the central access point node AP calculates the relative clock offsets between the sensor nodes N1, N2 using the intermediate quantities O(i)20 and O(i)10. For example, if 25% of the broadcast messages are lost by sensor nodes N1, N2, up to 50% of timestamp pairs t1(i), t2(i) may be not not available for synchronization purposes. Hence, to accomplish the same desired synchronization accuracy, the number of reference broadcast needs to be doubled.
On the other hand, for calculation of the intermediate estimate Omean10, the number of timestamp pairs t1(i), t0(i) is 75% of the non-loss case (e.g., only a 25% shortfall). Similarly, the intermediate estimate Omean20 may be calculated using 75% of all timestamp pairs t2(i), t0(i). As a result, the overall clock offset estimate Omean12=Omean10−Omean20 calculated from the intermediate quantities O(i)20 and O(i)10 is more accurate. If desired, to achieve the same synchronization accuracy, the number of reference broadcast needs to only be increased by one third.
Once the desired overall clock offsets are determined from the overall clock offset estimates Omean12, the method 100 proceeds. At step S4, the method 100 is ready for data acquisition, so the central access point node AP commands the sensor nodes to acquire data using TCP. At step S5, the sensor nodes N1, N2 collect the relevant data. Upon completion of the data acquisition period, the sensor nodes N1, N2 send the acquired data to the central access point node AP using TCP as shown in step S6.
Referring now to
In another embodiment, the method 100 performs a clock offset calculation based on the broadcast messages for which the propagation and processing delay is the shortest. Typically, the shorter the delay, the more accurate the resulting calculation. The messages for which the timestamp differences O(i)10 and O(i)20 are minimal are denoted as follows
Omin20=min(O(i)20)
Omin10=min(O(i)10)
where the minima are taken over the reference broadcasts received by the sensor nodes N2, N1, respectively. The following clock offset estimate may be calculated as
Omin12=Omin10−Omin20
Note that depending on the actual statistical distribution of timestamp differences O(i)10 and O(i)20, a plurality of methods may be used for estimating the overall clock offset between the sensor nodes N1, N2. For example, a median approach may be used to estimate O10 and O20 to minimize the influence of outliers. Another possibility may be to use a trimmed mean approach, or a trimmed median approach, when a fixed number of largest values of O(i)10 and O(i)20 would be excluded from calculations. As a result, the estimation of the clock offset O10 between the central access point node AP and the sensor node N1 is decoupled from the estimation of the clock offset O20 between the central access point node AP and the sensor node N2, and then the resulting estimates are combined into the final clock offset O12 between the sensor nodes N1, N2. By doing so, timestamp information associated with a particular reference broadcast is utilized as long as at least one sensor received that message.
Now referring to
At initial step S10 of the method 300, the central access point node AP and the sensor nodes N1, N2 exchange timestamps using the simple UDP protocol to reduce latency. It is noted that the timestamp exchanges may occur at different times as shown in
At step S11, the central access point node AP calculates the relative clock offset for the sensor node N1 based on the timestamp exchange. At step S12, the central access point node AP calculates the relative clock offset for the sensor node N2. Once the desired overall clock offsets are determined, the method 300 proceeds.
At step S13, the method 300 is ready for data acquisition, so the central access point node AP commands the sensor nodes N1, N2 to acquire data using TCP. At step S14, the sensor nodes N1, N2 collect data. Upon completion of the data acquisition period, the sensor nodes N1, N2 send the acquired data to the central access point node AP using TCP as shown in steps S15, S16, respectively.
Note that the depiction of method 300 in
In addition, the timing and sequence of events may differ from that shown in the
Referring now to
As can be seen, at step S10 of
The method 300 of
O10(i)=(t8(i)−t5(i)−t4(i)+t1(i))/2
The collection of estimates O10(i) is then used to calculate the overall clock offset between the central access point node AP and the sensor node N1. Several methods are known for subsequently determining the clock offset based on this data and, thus, any estimation techniques now known or later developed may be utilized.
In the circumstances where the timestamp message delivery experiences message losses, then the set of available individual estimates O10(i) may become dramatically small. For example, in
A drawback of simply increasing the number of timestamp messages sent is the increased time of the overall synchronization operation. For example, after a message from the central access point node AP to the sensor node N1 is lost, the central access point node AP waits for a response from the sensor node N1. Thus, the next message to the sensor node N1 is sent only after the central access point node AP times out when it becomes apparent that no response will be coming. This unnecessary waiting time translates into unnecessary energy expenditure while both nodes AP, N1 are in an active state.
The method 300 overcomes the lost messages problem by observing that in the formula to calculate O10(i), the two timestamp differences t8(i)−t5(i) and t4(i)−t1(i) are independent, because two timestamp differences t8(i)−t5(i) and t4(i)−t1(i) correspond to two distinct messages: the difference t4(i)−t1(i) corresponds to the message from the central access point AP to the sensor node N1, and the difference t8(i)−t5(i) corresponds to the message from the sensor node N1 to the central access point AP. Because the associated propagation and processing delays do not depend on each other, consecutive messages exchanged between the two wireless devices are not required.
Referring now to
In this example, two messages carrying timestamps t1(2), t5(3) have been lost out of eight messages sent, which is the same message loss rate as in the example of
Of(i)=t4(i)−t1(i)
Or(i)=t8(i)−t5(i)
where the subscript “f” is chosen to denote the forward message route from the central access point node AP to the sensor node N1 and the subscript “r” corresponds to the response route from sensor node N1 to the central access point node AP.
The mean values of the differences Of(i), Or(i) are defined as follows:
Omeanf=mean(O(i)r)
Omeanr=mean(O(i)r)
where the averages are taken over the respective collections of the available timestamp differences. The overall clock offset estimate may be calculated as
Omean10=(Omeanr−Omeanf)/2
Note that when there are no messages losses, this overall clock offset estimate is equivalent to
Omean10=mean(t8(i)−t5(i)−t4(i)+t1(i))/2
The modified overall clock offset estimate formula becomes clearly advantageous when there may be message losses in both directions. By decoupling the timestamp data for messages from the central point access node AP to the sensor node N1 from the timestamp data from the sensor node N1 to the central access point node AP, the data is used more efficiently, and fewer messages need to be sent. Also, note that the waiting period following message losses is greatly reduced. Because either of the wireless nodes sends a sequence of messages without waiting for responses, the central access point node AP avoids unnecessary waiting, which may allow a significant reduction in energy use.
Another improvement in the clock offset calculation results from the observation that the best accuracy of calculation is given by those messages for which the propagation and processing delay is the shortest, i.e., the messages for which the timestamp differences O(i)f and O(i)r are smallest. That is, let
Ominf=min(O(i)f)
Ominr=min(O(i)r)
where the minima are taken over the timestamp messages received by the sensor node N1 and the central point access node AP, respectively. Then, the following clock offset estimate may be calculated as
Omin10=(Ominr−Ominf)/2
Again, note that depending on the actual statistical distribution of the quantities O(i)f and O(i)r, various estimation methods may be used for clock offset calculation. This may involve median, trimmed median, or other estimators now known or later developed.
Referring again to
Alternatively, the set of timestamp pairs t1(i), t4(i) may be sent from the sensor node N1 to the central access point node AP between two sequences of messages. Yet another possibility is to include the timestamp data as additional payload in the timestamp messages from sensor node N1 to the central access point node AP, possibly repeated in consecutive messages to account for the possible message losses. In most applications, once the timestamps t1(i), t4(i) are recorded by the sensor node N1, the information only needs to be sent to the central access point node AP in time for the central access point node AP to calculate the clock offset.
Typically, even when the clock rates differ slightly, if the time is short, the clock drift may be disregarded. If this is not the case, the subject technology may be extended to include both clock offset and clock drift rate estimation. For example, the Karl/Willig approach proposes a drift estimation using multiple data points and assuming that sensor node drift is constant through an interval of interest. It is also envisioned that the subject technology may apply to a subset of nodes. In such an application, the central access point AP can multicast or send out synchronizing messages to selected sensors and/or nodes instead of using broadcast messages directed to all nodes within the network.
While the invention has been described with respect to preferred embodiments, those skilled in the art will readily appreciate that various changes and/or modifications can be made to the invention without departing from the spirit or scope of the invention as defined by the appended claims. For example, each claim may depend from any or all claims in a multiple dependent manner even though such has not been originally claimed.
Lynch, Michael A., Zakrzewski, Radoslaw R.
Patent | Priority | Assignee | Title |
11469843, | Jun 26 2018 | HUAWEI TECHNOLOGIES CO , LTD | Synchronization method and apparatus |
Patent | Priority | Assignee | Title |
6577872, | Aug 08 2000 | TELEFONAKTIEBOLAGET LM ERICSON PUBL | Base station oscillator regulation independent of transport network clocks in cellular telecommunications network |
20050157658, | |||
20090228732, | |||
20100142421, | |||
20110255528, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 01 2010 | LYNCH, MICHAEL A | SIMMONDS PRECISION PRODUCTS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025322 | /0977 | |
Nov 01 2010 | ZAKRZEWSKI, RADOSLAW R | SIMMONDS PRECISION PRODUCTS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025322 | /0977 | |
Nov 08 2010 | Simmonds Precision Products, Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Dec 28 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Dec 18 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Dec 21 2024 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jul 16 2016 | 4 years fee payment window open |
Jan 16 2017 | 6 months grace period start (w surcharge) |
Jul 16 2017 | patent expiry (for year 4) |
Jul 16 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 16 2020 | 8 years fee payment window open |
Jan 16 2021 | 6 months grace period start (w surcharge) |
Jul 16 2021 | patent expiry (for year 8) |
Jul 16 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 16 2024 | 12 years fee payment window open |
Jan 16 2025 | 6 months grace period start (w surcharge) |
Jul 16 2025 | patent expiry (for year 12) |
Jul 16 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |