This application is based upon and claims the benefit of priority from prior Japanese Patent Applications No. 2009-220124, filed Sep. 25, 2009; No. 2009-244095, filed Oct. 23, 2009; and No. 2009-248786, filed Oct. 29, 2009, the entire contents of all of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to a time information-acquiring apparatus that receives a standard time radio wave and acquires the time information thereof, and a radio wave timepiece comprising the time information-acquiring apparatus.
2. Description of the Related Art
In recent years, for example, in Japan, Germany, England, and Switzerland, transmitting stations transmit a standard time radio wave of a low frequency. For example, transmitting stations in Fukushima and Saga prefectures in Japan transmit amplitude-modulated standard time radio waves of 40 kHz and 60 kHz. The standard time radio wave includes a code string forming a time code indicating the date and time and is transmitted every 60 seconds. That is, the period of the time code is 60 seconds.
A clock (radio wave timepiece) that receives the standard time radio wave, extracts the time code from the received standard time radio wave, and corrects the time has been put to practical use. A receiver of the radio wave timepiece includes a band-pass filter (BPF) that receives the standard time radio wave through an antenna and extracts only the standard time radio wave signal, a demodulator that demodulates an amplitude-modulated standard time radio wave signal using, for example, envelope detection, and a processor that reads a time code included in the signal demodulated by the demodulator.
The processor in the prior art performs synchronization with the rising edge of the demodulated signal and then performs binarization with a predetermined sampling period to acquire time code output (TCO) data having a unit time length (one second), which is a binary bit string. The processor measures the pulse width (that is, the time of a bit 1 or the time of a bit 0) of the TCO data, determines whether each code is a binary 1 code, a binary 0 code, or a position marker code P based on the measured pulse width, and acquires time information based on the determined code string.
The processing circuit according to the prior art performs processes, such as a second synchronization process, a minute synchronization process, a process of acquiring a code, and a process of determining matching, during the period from the start of the reception of the standard time radio wave to the acquisition of the time information. When each of the processes is not appropriately terminated, the processing circuit needs to start the processes from the beginning. Therefore, in some cases, the processing circuit needs to start the processes from the beginning several times due to the influence of noise included in the signal. Under such instances, it takes a very long time to acquire time information.
The second synchronization detects the rising edge of a code at an interval of one second among the codes indicated by the TCO data. It is possible to detect a portion in which a position marker P0 arranged at the end of a frame and a marker M arranged at the head of the frame are continuously arranged by repeatedly performing the second synchronization. The portion in which the markers are continuously arranged appears at an interval of one minute (60 seconds). Within the TCO data, the marker M shows the position of the head frame data. The detection of the position of the marker is referred to as minute synchronization. The head of the frame is recognized by the minute synchronization. Therefore, after code acquisition starts to acquire one frame of data, a parity bit is checked to determine whether the data has an improper value (the date and time have improper values) (matching determination). For example, since the minute synchronization is for detecting the head of the frame, 60 seconds are required in some cases. Of course, multiples of 60 seconds are required to detect the heads of several frames.
In Jpn. Pat. Appln. KOKAI Publication No. 2005-249632 (corresponding to US 2005/0195690 A1), the demodulated signal is binarized at a predetermined sampling interval (50 ms) to obtain TCO data and a list of data groups (20 samples) in the form of binary bit strings is obtained every one second.
The apparatus disclosed in Jpn. Pat. Appln. KOKAI Publication No. 2005-249632 compares the bit string with each of the templates of a binary bit string indicating a position marker code P, a binary bit string indicating a code 1, and a binary bit string indicating a code 0, calculates a correlation therebetween, and determines to which of the codes P, 1, and 0 the bit string corresponds, based on the correlation.
In the technique disclosed in Jpn. Pat. Appln. KOKAI Publication No. 2005-249632, the TCO data, which is a binary bit string, is acquired and matched with the template. When the field intensity is weak or a large amount of noise is mixed with the demodulated signal, many errors are included in the acquired TCO data. Therefore, it is necessary to provide a filter which removes noise from the demodulated signal or to finely adjust the threshold of an AD converter, in order to improve the quality of the TCO data.
The process of determining to which of the code 0, the code 1, and the position marker code P data with a unit time length (one second) corresponds is insufficient to detect the head of the second or the head of the minute, and it is necessary to perform the determining process again based on the determination result. When the head of the second or the head of the minute is not appropriately detected, it is necessary to perform the process again.
An object of the invention is to provide a time information-acquiring apparatus capable of accurately acquiring a code included in a standard time radio wave to obtain the current time while reducing the amount of calculation and the calculation time, without being affected by the field intensity or the noise of signals and further provide a radio wave timepiece including the time information-acquiring apparatus.
According to one embodiment of the present invention, a time information-acquiring apparatus comprises:
a receiver configured to receive a standard time radio wave including a time code;
an input waveform generator configured to sample a signal output from the receiver and including the time code with a predetermined sampling period and to generate input waveform data with one or more unit time lengths, the input waveform data at each sampling point having one of a first value indicating a low level and a second value indicating a high level;
a predicted waveform generator configured to generate plural predicted waveform data, each of the plural predicted waveform data having the one or more unit time lengths, each of the plural predicted waveform data at each sampling point having one of the first value and the second value, and a phase of each of the plural predicted waveform data being shifted by a predetermined number of samples;
a correlation calculator configured to arithmetically operate the input waveform data at a sampling point and the plural predicted waveform data at a corresponding sampling point and to calculate correlation values between the input waveform data and the plural predicted waveform data, wherein the correlation calculator is configured to calculate a first correlation value indicating a positive correlation by arithmetically operating the first value of the input waveform data and the first value of the predicted waveform data or arithmetically operate the second value of the input waveform data and the second value of the predicted waveform data, and to calculate a second correlation value indicating a negative correlation by arithmetically operating the first value of the input waveform data and the second value of the predicted waveform data or arithmetically operate the second value of the input waveform data and the first value of the predicted waveform data;
a comparator configured to compare the correlation values calculated by the correlation calculator and to detect an optimal value of the correlation values; and
a controller configured to detect a head position of a second in the time code based on predicted waveform data related to the optimal value.
Additional objects and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention.
The objects and advantages of the invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out hereinafter.
The accompanying drawings, which are incorporated in and constitute a part of the detection, illustrate embodiments of the invention, and together with the general description given above and the detailed description of the embodiments given below, serve to explain the principles of the invention.
Hereinafter, a first embodiment of the invention will be described with reference to the accompanying drawings. According to the first embodiment, a time information-acquiring apparatus is provided in a radio wave timepiece that receives a standard time radio wave in a long wavelength band, detects the signal thereof, extracts a code string indicating a time code in the signal, and corrects time based on the code string.
In recent years, for example, in Japan, Germany, England, and Switzerland, a standard time radio wave is transmitted from a predetermined transmitting station. For example, transmitting stations in Fukushima and Saga prefectures in Japan transmit amplitude-modulated standard time radio waves of 40 kHz and 60 kHz, respectively. The standard time radio wave includes a code string forming a time code indicating the date and time and is transmitted with a period of 60 seconds. Since one code has a unit time length (one second), one period may include 60 codes.
The CPU 11 reads a program stored in the ROM 14 at predetermined timing or in response to an operation signal input from the input device 12, expands the read program in the RAM 15, and transmits instructions or data to each unit or device of the radio wave timepiece 10 based on the program. Specifically, for example, the CPU 11 performs a process of controlling the receiver 16 to receive a standard time radio wave at predetermined time intervals, specifying a code string included in the standard time radio wave signal from digital data which is based on the signal obtained from the receiver 16, and a process of correcting the current time measured by the internal timer 17 based on the code string, or a process of transmitting the current time measured by the internal timer 17 to the display device 13. In the first embodiment, predicted waveform data of a standard time radio wave signal with one or more unit time lengths and a predetermined format is generated, and the predicted waveform data is compared with input waveform data which is obtained from the standard time radio wave received by the receiver to detect the head of the second.
In the first embodiment, the head of the minute and the values of various kinds of codes including hour, minute, and date codes, are specified by the same method as that in the prior art. When the date and time are specified, it is possible to calculate an error in the internal timer 17 and correct the current time measured by the internal timer 17.
The input device 12 includes switches configured to instruct the radio wave timepiece 10 to perform various kinds of functions. When a switch is operated, a corresponding operation signal is output to the CPU 11. The display device 13 includes a liquid crystal panel, an analog pointer mechanism controlled by the CPU 11, and a dial and displays the current time measured by the internal timer 17. The ROM 14 stores, for example, a system program or an application program configured to operate the radio wave timepiece 10 and to implement a predetermined function. The programs configured to implement the predetermined function also include a program configured to control the signal comparator 18 in order to perform a process of detecting a second pulse position, which will be described below. The RAM 15 is used as a work area of the CPU 11 and temporarily stores, for example, the program or data read from the ROM 14 and data processed by the CPU 11.
The receiver 16 includes, for example, an antenna circuit or a detector. The receiver 16 obtains a demodulated signal from the standard time radio wave received by the antenna circuit and outputs the signal to the signal comparator 18. The internal timer 17 includes an oscillator. The internal timer 17 counts clock signals output from the oscillator to measure the current time and outputs data of the current time to the CPU 11.
The input waveform data generator 21 converts the signal output from the receiver 16 into digital data having any one of plural values at predetermined sampling intervals and outputs the converted digital data. For example, the sampling interval is 50 ms and data of 20 samples per second may be acquired. The value of the digital data according to the first embodiment will be described below. The received waveform data buffer 22 sequentially stores data generated by the input waveform data generator 21. The received waveform data buffer 22 may store data of plural unit time lengths (for example, 10 unit time lengths (10 seconds)) when the unit time length is one second. When new data is stored, the old data is erased in chronological order.
The predicted waveform data generator 23 generates predicted waveform data, with a predetermined time length, which is a comparison target and used in the following processes. For example, the predicted waveform data is used in each process, which will be described below. The predicted waveform data generated by the predicted waveform data generator 23 will be described in detail in a process of detecting the second pulse position. The waveform extractor 24 extracts input waveform data from the received waveform data buffer 22 with the same time length as that of the predicted waveform data.
The correlation value calculator 25 calculates a correlation value between each of a plurality of predicted waveform data and the input waveform data. In this embodiment, covariance is used for correlation, which will be described below in detail. The correlation value comparator 26 compares the correlation values (covariance values) calculated by the correlation value calculator 25 to detect the optimal value thereof.
In this embodiment, though described later, in order to accurately detect the signal of JJY which changes from a low level to a high level at the head of the second, plural items of predicted waveform data are generated in which a predetermined number of waveform data items (for example, four items of data in this embodiment) each having a unit time length and a predetermined data value are continuously arranged and a phase of the plural items of predicted waveform data is shifted by a time interval of 50 ms. The covariance values between the plural items of predicted waveform data and the input waveform data are calculated and a changing point of the predicted waveform data indicating the optimal covariance value from a low level to a high level is determined to be the second pulse position (the head position of the second).
Then, the CPU 11 and the like detect the head position of the minute, that is, the head position of one frame of the standard time radio wave signal (Step S104).
Then, the CPU 11 and the like decode various kinds of codes (a code M1 indicating one's place of the minute, a code M10 indicating ten's place of the minute, and other codes indicating the date or day) of the standard time radio wave signal based on the comparison between the predicted waveform data and the input waveform data (Step S106).
In this embodiment, the standard time radio wave signal of JJY is received and second synchronization is performed on the received signal. However, this embodiment may be modified such that standard time radio wave signals based on other standards, for example, WWVB or MSF are received. Here, the codes based on WWVB and MSF will be described briefly.
Next, the process of detecting the second pulse position (or the process of second synchronization) according to this embodiment (Step S102) will be described in more detail.
As shown in
In the actual calculation, in a portion having the first value and a portion having the second value, that is, in the first predicted waveform data item P(1, j) (see reference numeral 701), only portions represented by reference numerals 711 and 712 are substantially valid in calculation. In the second predicted waveform data item P(2, j) to the twentieth predicted waveform data item P(20, j), only portions represented by reference numerals 721, 731, 741, . . . , and 751 are substantially valid in calculation.
As can be seen from
Then, the CPU 11 controls the waveform extractor 24 to extract data (see reference numeral 910 in
In this embodiment, the input waveform data generator 21 binarizes the analog signal (see reference numeral 910 in
Then, the CPU 11 controls the correlation value calculator 25 to initialize a parameter p which detects the predicted waveform data with 1 (Step S116) and to calculate a correlation value (covariance value) C(p) between the input waveform data Sn(j) and the predicted waveform data P(p, j) (Step S118).
In this embodiment, the correlation value calculator 25 calculates the covariance value C(p) using the data value Sn(j) of the input waveform data, the average value Sm thereof, the data value P(p, j) of the predicted waveform data, and the average value Pm thereof according to the following expression:
C(p)=(1/N)×Σ((Sn(j)−Sm)×(P(p, j)−Pm))
where Sm=(1/N)×Σ(Sn(j)) and
Pm=(1/N)×Σ(P(p, j))
In
In addition, Σ is for j=1 to N. As described above, when the waveform extractor 24 extracts sample data in the order of Sn(1), Sn(2), . . . , and so on, not all of Sn(j) (j=1 to N) are acquired in Step S118. Therefore, in at the beginning of Step S118, the average value Sm=(1/N)×Σ(Sn(j)) is not obtained.
However, C(p) is modified as follows:
C(p)=(1/N)×Σ(Sn(j)×(p,j))−Sm×Pm.
Therefore, whenever the waveform extractor 24 acquires the sample data Sn(j), the correlation value calculator 25 calculates Sn(j)×P(p, j) and repeats a process of accumulating the calculated value, which is the multiplication result, to the addition result. When the last sample data Sn(N) is acquired, the correlation value calculator 25 may calculate the average value Sm and subtract Sm×Pm from the accumulation result.
In this embodiment, when Sn(j) is the first value −1 and P(p, j) is the first value −1, Sn(j)×P(p, j) is 1. Similarly, when Sn(j) is the second value 1 and P(p, j) is the second value 1, Sn(j)×P(p, j) is 1. That is, when P(p, j) has the first value or the second value and Sn(j) and P(p, j) have the same value, a predetermined value (in this embodiment, 1) indicating a positive correlation is obtained.
When Sn(j) is the first value −1 and P(p, j) is the second value 1, Sn(j)×P(p, j) is −1. Similarly, when Sn(j) is the second value 1 and P(p, j) is the first value −1, Sn(j)×P(p, j) is −1. That is, when P(p, j) has the first value or the second value and Sn(j) and P(p, j) do not have the same value, a predetermined negative value (in this embodiment, −1) indicating a negative correlation is obtained.
When P(p, j) is the third value 0, Sn(j)×P(p, j) is 0 which has no effect on the calculation of the covariance value, regardless of the value of Sn(j).
In the predicted waveform data P(1, j) to P(3, j), C(1) to C(3) are 0. However, in the predicted waveform data P(4, j) in which the rising edge position of the waveform is aligned with the rising edge position of the waveform of the input waveform data Sn(j), C(4) is 2. In the predicted waveform data P(6, j) in which the rising edge position of the waveform is aligned with the falling edge position of the waveform of the input waveform data Sn(j), C(6) is −2.
As such, in this embodiment, when the rising edge position of the input waveform data is aligned with the rising edge position of the predicted waveform, a large covariance value indicating a strong correlation appears. When the falling edge position of the input waveform data is aligned with the rising edge position of the predicted waveform, that is, when the phases of the waveforms are opposite to each other, a negative covariance value indicating a negative correlation appears. A value of 0 that has no effect on the calculation result appears when the rising edge position of the predicted waveform is aligned with other positions of the input waveform data.
When the parameter p is smaller than 20 (No in Step S120), the parameter p is incremented (Step S122), and the process returns to Step S118. When covariance values C(1) to C(20) are acquired for all of the parameters p, the determination result in Step S120 is “Yes”. In this case, the correlation value comparator 26 compares the covariance values C(1) to C(20) to find an optimal value (in this case, the maximum value) C(x) (Step S124). The CPU 11 receives the optimal value C(x) and determines whether the optimal value is valid (Step S126).
The maximum value C(x) of the obtained covariance values C(p) is a predicted waveform with the highest correlation. However, in the covariance value obtained from a sample with insufficient moduli, the maximum value is likely to appear due to an unexpected factor caused by noise. In order to exclude this case, for example, in Step S126, the following criteria are set to prevent an error in detection:
(1) The number of input waveform data used to calculate the covariance is equal to or more than a predetermined value;
(2) The value x indicating C(x) appears plural times, the values x appearing plural times are equal to each other, and the frequency of the value of x is higher than that of other values (x is a mode value);
(3) The values x that continuously appear a predetermined number of times or more are equal to each other (the continuity of a mode value);
(4) The variance of C(p) is equal to or less than a predetermined value; and
(5) Kurtosis or the degree of distortion, which is the amount of statistics of C(p), or an evaluation function equivalent thereto is calculated and it is determined whether the calculation result reaches a predetermined value.
When the criteria (1) to (3) are applied, a set of Steps S114 to S124 in
A method of determining validity is not limited to the above-mentioned method. The average value of the covariance values or the standard deviation may be used and the covariance value smaller than the average value may be determined to be insignificant even though the covariance value is the maximum value. In addition, the level of significance (for example, 5 percent) that is generally used in statistics may be used.
If it is determined that the optimal value C(x) is valid (Yes in Step S126), the CPU 11 determines the changing point of the signal level of the predicted waveform data indicated by the optimal value C(x), that is, the position where the first value indicating a low level changes to the second value indicating a high level to be the second pulse position (Step S128). The CPU 11 stores the information of the second pulse position in the RAM 15. The second pulse position is used in, for example, the process of detecting the minute head position, which will be described below.
Referring to
When the detection of the minute head position (Step S104), that is, minute synchronization ends, codes, such as minute, hour, and day codes, are decoded (Step S106). In Step S106, the CPU 11 and the signal comparator 18 acquire 60 code data items from the minute head position. When the code data is acquired, the CPU 11 determines whether the date (day, month, and year) obtained from the acquired code data is a proper value. When it is determined that there is a consistency in the acquired codes, the current time based on the codes is stored in the RAM 15. In addition, the CPU 11 corrects the current time measured by the internal timer 17 based on the current time obtained from the codes and displays the obtained current time on the display device 13 (Step S108).
The second synchronization and minute synchronization of the signal in JJY and the decoding of the code have been described above. In other standards, such as WWVB and MSF, the second synchronization, the minute synchronization, and the decoding of the code may also be performed.
Next, second synchronization in WWVB or MSF will be described. As shown in
As shown in
Alternatively, as in WWVB or MSF, in order to detect the head position of the second in the data that changes from a high level to a low level at the head position of the second, another predicted waveform data, which is the inverted data of the predicted waveform data P(j), may be used. In
In this embodiment, in the input waveform data with one or more unit time lengths, each sampling point has either the first value −1 indicating a low level or the second value 1 indicating a high level. In addition, in each of a plurality of predicted waveform data item with one or more unit time lengths, each sampling point has any one of the first value −1 indicating a low level in one predetermined section either before or after the changing point of the signal level, the second value 1 indicating a high level in the other predetermined section before or after the changing point of the signal level, and the third value 0 in sections other than the predetermined sections.
When the input waveform data item and the predicted waveform data item have the above-mentioned values, the first values are multiplied by each other or the second values are multiplied by each other to obtain a first calculated value 1 indicating a positive correlation, and the first value is multiplied by the second value to obtain a second calculated value −1 indicating a negative correlation. Therefore, it is possible to increase the correlation when the changing points of the signal levels of the input waveform data and the predicted waveform data and the changes of the signal levels from a low level to a high level are identical to each other and enhance sensitivity when each of the level changing points and the changes of the signal levels are identical to each other. Therefore, when the histogram of the covariance values is considered for each of a plurality of predicted waveform data (for example,
In this embodiment, the third value is set to 0 such that the third value is multiplied by the first value or the second value to produce a value (=0) which does not have an effect on the calculation of the covariance value. In this way, the optimal value of the covariance value is appropriately calculated.
In this embodiment, the CPU 11 determines the changing point of the signal level of the predicted waveform data indicated by the optimal value C(x), that is, the position where the first value indicating a low level changes to the second value indicating a high level to be the second pulse position. In this way, it is possible to appropriately specify the head position of the second.
For example, as in the time code based on the JJY standard, when each code changes from a low level to a high level at the head of the second, the predicted waveform data has the first value −1 in a predetermined section before the changing point of the signal level, the second value 1 in a predetermined section after the changing point, and the third value 0 in the other sections. In this case, the calculated correlation values are compared with each other and the maximum value of the correlation value is selected as the optimal value. In this way, it is possible to detect the predicted waveform data with the highest correlation with the input waveform data.
Alternatively, as in the time code based on the WWVB or MSF standard, even though each code changes from a high level to a low level at the head of the second, the predicted waveform data may has the first value −1 only in a predetermined section before the changing point of the signal level, the second value 1 only in a predetermined section after the changing point, and the third value 0 in the other sections. In this case, the calculated correlation values are compared with each other and the minimum value of the correlation value is selected as the optimal value. In this way, it is possible to detect the predicted waveform data with a large negative correlation with the input waveform data. It is possible to appropriately obtain the head position of the second in the time code according to the WWVB or MSF standard, based on the specified predicted waveform data.
In this embodiment, the head position of the minute in the time code is specified based on the second head position and the signal levels before and after the head position of the time code, and codes included in the time code are acquired. Then, the values of codes including the day, hour, and minute forming the time code are acquired based on values indicated by the codes. Thereafter, the current time is calculated based on the acquired codes. As a result, it is possible to correct the time obtained by the internal timer with the calculated current time.
In the first embodiment, the predicted waveform data has the first value indicating a low level in a predetermined section (temporally old side) before a rising point from a low level to a high level and has the second value having a high level in a predetermined section (temporally new side) after the point. In addition, the predicted waveform data has the third value indicating 0 in sections other than the predetermined sections before and after the point. However, the invention is not limited thereto. For example, sections other than the predetermined sections before and after the point may be excluded from calculation. That is, the predicted waveform data may have an indefinite or invalid value, not the third value 0, in the sections other than the predetermined sections.
In this case, only the data of the predetermined sections before and after the changing point of the signal level of the predicted waveform data, that is, a point where the signal level changes from a low level to a high level is extracted, and the covariance values between the data values of the predetermined sections and the data values of the corresponding input waveform data are calculated. In
According to the above-mentioned structure, it is possible to omit the calculation of the data values of the predicted waveform data and the data value of the input waveform data in sections other than the predetermined sections. Therefore, it is possible to reduce the number of calculations or shorten the time for calculation.
In the first embodiment, the first value indicating a low level is −1, the second value indicating a high level is 1, and the third value other than the first and second values is 0. However, the invention is not limited to these values. The first value and the second value may be as follows.
(1) When the input waveform data indicates the first value and the predicted waveform data indicates the first value, or when the input waveform data indicates the second value and the predicted waveform data indicates the second value, the first value is multiplied by the first value or the second value is multiplied by the second value to obtain a predetermined positive value indicating a positive correlation. That is, when the input waveform data and the predicted waveform data indicate the same value, a predetermined positive value is obtained.
(2) When the input waveform data indicates the first value and the predicted waveform data indicates the second value, or when the input waveform data indicates the second value and the predicted waveform data indicates the first value, the first value is multiplied by the second value to obtain a predetermined negative value indicating a negative correlation. That is, when the input waveform data and the predicted waveform data indicate different values, a predetermined negative value is obtained. It is preferable that the predetermined negative value be opposite to the predetermined positive value in polarity.
In the calculation of the second pulse position, the third value may not be 0. However, the third value should not affect the correlation value, such as the covariance value, when it is multiplied by the first value or the second value.
In the above-described embodiment, the covariance value is used as the correlation value, but the invention is not limited thereto. For example, a residual, which is the total sum of the absolute values of differences, may be used as the correlation value. Alternatively, a mutual correlation coefficient may be used instead of the covariance or the residual.
In the first embodiment, in each of the predicted waveform data, each sampling point has the first value −1 indicating a low level in a section that is 50 ms before the changing point of the signal level, the second value 1 indicating a high level in a section that is 50 ms after the changing point, and the third value 0 in the other sections. That is, as in the predicted waveform data (see reference numeral 1400) shown in
In general, the narrower the predetermined section, the higher the accuracy of detection, as in the predicted waveform data 1400. However, as in the modifications 1401 and 1402, when the predetermined section has a constant width (time length), a stable detection result is likely to be obtained, without being affected by noise.
Next, minute synchronization and the decoding of a code in WWVB or MSF will be described. In WWVB, the data value in the characteristic section is extracted and only the data value of characteristic section is used to calculate the covariance value.
The code 0 is at a high level (data value 1) and has a data value 1 different from those of other codes in the section (see reference numeral 1912) from 200 ms to 500 ms. The code 1 is at a low level (data value −1) and has a data value −1 different from that of the code 0 in the section (see reference numeral 1913) from 200 ms to 500 ms. Therefore, in each of the codes 0 and 1, the section from 500 ms to 800 ms is the characteristic section. In addition, the data values of the characteristic sections are 1 and −1.
Similar to JJY, it is possible to perform the process of detecting the minute head position and the code decoding process using the data value of the characteristic section.
The marker is at a low level (data value −1) and has a data value −1 different from those of other codes in the section (see reference numeral 2011) from 300 ms to 500 ms. In this embodiment, in MSF, the section from 300 ms to 500 ms in the marker is the characteristic section. In addition, the data value of the characteristic section is −1 indicating a low level.
The code 00 is at a high level (data value 1) and has a data value 1 different from those of other codes in the section (see reference numeral 2012) from 100 ms to 300 ms. The code 01 is at a high level (data value 1) in the section (see reference numeral 2013) from 100 ms to 200 ms and is at a low level (data value −1) in the section (see reference numeral 1014) from 200 ms to 300 ms. The code 01 has a combination of values (the first half is 1 and the second half is −1) different from those of other codes in the sections. The code 10 is at a low level (data value −1) in the section (see reference numeral 2015) from 100 ms to 200 ms and is at a high level (data value 1) in the section (see reference numeral 1016) from 200 ms to 300 ms. The code 10 has a combination of values (the first half is −1 and the second half is 1) different from those of other codes in the sections. The code 11 is at a low level (data value −1) and has a data value −1 different from those of other codes in the section (see reference numeral 2017) from 100 ms to 300 ms. Therefore, the section from 100 ms to 300 ms is the characteristic section. The data value of each of the sections is the same as that shown in
In MSF, the data values of the characteristic sections of the codes 00 to 11 are not constant. For example, the data values of the first half and the second half of the characteristic section of the code 01 are 1 and −1, respectively. Therefore, in the code decoding process based on the MSF standard, similar to the detection of the minute head position, the data value in the characteristic section of the input waveform data may be multiplied by a corresponding data value in the characteristic section of the predicted waveform data, the calculated values may be added to obtain the total sum, and the covariance value may be calculated based on the obtained total sum. In this embodiment, the data value accumulator 29 accumulates the data value of the characteristic section, which has a constant and unique data value different from those of other codes, of each of the codes forming time information included in the time code in the input waveform data, for example, the codes 0 and 1 based on JJY and stores the accumulated value in the accumulated value buffer 30. The correlation value calculator 25 multiplies the data value of the characteristic section stored in the accumulated value buffer 30 by the characteristic value, which is the first value or the second value of the characteristic section of a specific code, for example, each of the codes 0 and 1 based on JJY and calculates the correlation values between the input waveform data and the codes based on the multiplied value. Originally, multiplication to calculate the correlation value needs to be performed between the data values of the sampling points of waveform data. However, the code has a constant and unique data value (characteristic value) different from those of other codes in the characteristic section. Therefore, the value obtained only by multiplying the accumulated value by the characteristic value indicates the correlation between the input waveform data and the code. As a result, it is possible to acquire an appropriate correlation value with a small amount of calculation.
In this embodiment, when the head position of the minute in the time code is specified based on the signal levels before and after the head position of the time code, the data value accumulator 29 accumulates the data value of a specific section and stores the accumulated value in the accumulated value buffer 30. When the minute head position is specified, the correlation value calculator 25 extracts the data value of the characteristic section corresponding to the code forming time information from the accumulated value buffer 30 based on the detected minute head position, and multiplies the data value by the characteristic value. Therefore, it is possible to acquire the accumulated value of the data value of the characteristic section while the minute head position is detected, and to start to detect the code forming time information immediately after the detection of the minute head position ends.
For example, in this embodiment, in the input waveform data, the data value of the second characteristic section, which has a constant and unique data value different from those of other codes, of a predetermined code with plural unit time lengths which includes the head position of the minute in the time codes, for example, two continuous codes P in JJY are acquired. The correlation value calculator 25 calculates the correlation value between the input waveform data and the predetermined code based on the value obtained by multiplying the data value of the second characteristic section in the acquired input waveform data by a characteristic value which is the first value or the second value of the characteristic section of the predetermined code with the plural unit time lengths which includes the head position of the minute.
According to the above-mentioned embodiment, it is possible to obtain the correlation value only by calculating the data value of the characteristic section in the detection of the minute head position. Therefore, it is possible to obtain an appropriate correlation value with a small amount of calculation.
For example, the first value is set to −1 and the second value is set to 1. The first value is multiplied by the first value or the second value is multiplied by the second value to obtain a first positive value 1 indicating a positive correlation. Meanwhile, the first value is multiplied by the second value to obtain a second negative value −1 indicating a negative correlation. Thus, the correlation value calculator 25 selects the maximum value of the correlation value as an optimal value. In this way, it is possible to detect a code with the highest correlation with the input waveform data.
In this embodiment, time information forming the time code is acquired and the current time is calculated based on the acquired time information. Therefore, it is possible to correct the time obtained by the internal timer with the calculated current time.
The invention is not limited to the above-described embodiment, but various modifications and changes of the invention can be made without departing from the scope and spirit of the invention. The modifications and changes are also included in the scope of the invention.
In the detection of the second pulse position according to the above-described embodiment, the predicted waveform data has the first value indicating a low level in a predetermined section (temporally old side) before a rising point from a low level to a high level and has the second value having a high level in a predetermined section (temporally new side) after the point. In addition, the predicted waveform data has a third value indicating 0 in sections other the predetermined sections before and after the point. However, the invention is not limited thereto. For example, sections other than the predetermined sections before and after the point may be excluded from calculation. That is, the predicted waveform data may have an indefinite or invalid value, not the third value 0, in sections other than the predetermined sections.
In this case, only the data of the predetermined sections before and after the changing point of the signal level of the predicted waveform data, that is, a point where the signal level changes from a low level to a high level is extracted, and the covariance values between the data values of the predetermined sections and the data values of the corresponding input waveform data are calculated. In
According to the above-mentioned embodiment, it is possible to omit the calculation of the data value of the predicted waveform data and the data value of the input waveform data in sections other than the predetermined sections. Therefore, it is possible to reduce the number of calculations.
In the embodiment, in the detection of the second pulse position, the first value indicating the low level of the input waveform data and the predicted waveform data is −1, the second value indicating the high level thereof is 1, and the third value other than the first and second values is 0. In the detection of the minute head position and the decoding of the code, the first value indicating the low level of the input waveform data and the predicted waveform data is −1 and the second value indicating the high level thereof is 1. However, the invention is not limited to these values. The first value and the second value may be as follows.
(1) When the input waveform data indicates the first value and the predicted waveform data indicates the first value, or when the input waveform data indicates the second value and the predicted waveform data indicates the second value, the first value is multiplied by the first value or the second value is multiplied by the second value to obtain a predetermined positive value indicating a positive correlation. That is, when the input waveform data and the predicted waveform data indicate the same value, a predetermined positive value is obtained.
(2) When the input waveform data indicates the first value and the predicted waveform data indicates the second value, or when the input waveform data indicates the second value and the predicted waveform data indicates the first value, the first value is multiplied by the second value to obtain a predetermined negative value indicating a negative correlation. That is, when the input waveform data and the predicted waveform data indicate different values, a predetermined negative value is obtained. It is preferable that the predetermined negative value be opposite to the predetermined positive value in polarity.
In the calculation of the second pulse position, the third value may not be 0. However, the third value should not affect the correlation value, such as the covariance value, when it is multiplied by the first value or the second value.
In the above-described embodiment, the covariance value is used as the correlation value, but the invention is not limited thereto. For example, a residual, which is the total sum of the absolute values of differences, may be used as the correlation value. Alternatively, a mutual correlation coefficient may be used instead of the covariance or the residual.
In the above-described embodiment, in the detection of the minute head position, the data value in the characteristic section of Sn(i, j) is extracted so as to correspond to the characteristic section of the predicted waveform data (Step 1105 in
When the data value of the predicted waveform data is multiplied by the corresponding data value of the input waveform data to obtain a multiplied value, the amount of calculation increases, but it is possible to accurately specify input waveform data corresponding to the head position of the minute since the entire waveform is compared.
While the description above refers to particular embodiments of the present invention, it will be understood that many modifications may be made without departing from the spirit thereof. The accompanying claims are intended to cover such modifications as would fall within the true scope and spirit of the present invention. The presently disclosed embodiments are therefore to be considered in all respects as illustrative and not restrictive, the scope of the invention being indicated by the appended claims, rather than the foregoing description, and all changes that come within the meaning and range of equivalency of the claims are therefore intended to be embraced therein. For example, the present invention can be practiced as a computer readable recording medium in which a program for allowing the computer to function as predetermined means, allowing the computer to realize a predetermined function, or allowing the computer to conduct predetermined means.
Other embodiments of the present invention will be described. The same portions as those of the first embodiment will be indicated in the same reference numerals and their detailed description will be omitted.
A second embodiment will be described. A block diagram illustrating the structure of a radio wave timepiece according to the second embodiment is the same as that in the first embodiment shown in
A diagram illustrating an example of the structure of a receiver according to the second embodiment is the same as that in the first embodiment shown in
In this embodiment, for example, predicted waveform data and input waveform data are compared with each other to detect the head of the minute and the values of various kinds of codes including time (minute and hour) and date (day, month, and year) codes. When the date and time are specified, it is possible to calculate an error in the internal timer 17 and correct the current time measured by the internal timer 17.
The signal comparator 18 in the radio wave timepiece shown in
The operations of the input waveform data generator 121 and the received waveform data buffer 122 are the same as those the input waveform data generator 21 and the received waveform data buffer 22 according to the first embodiment.
The predicted waveform data generator 123 generates predicted waveform data, which is a comparison target, with a predetermined time length. The predicted waveform data is used in each process, which will be described below. The predicted waveform data generated by the predicted waveform data generator 123 will be described in a process of detecting a second pulse position, a process of detecting a head position of the minute, and a code decoding process. The operations of the waveform extractor 124, the correlation value calculator 125, and the correlation value comparator 126 are the same as those of the waveform extractor 24, the correlation value calculator 25, and the correlation value comparator 26 according to the first embodiment.
The reception level calculator 127 calculates the signal level of a standard time radio wave signal based on the covariance value calculated by the correlation value calculator 125 and outputs the signal level to the CPU 11. The interruption determinator 128 determines whether to continue or stop the process of detecting the second pulse position based on the covariance value.
A flowchart schematically illustrating a process performed in the radio wave timepiece according to this embodiment is the same as that in the first embodiment shown in
Examples of the codes based on the JJY, WWVB, and MSF standards are the same as those shown in
The predicted waveform data used in the process of detecting the second pulse position (Step S102 in
This embodiment differs from the first embodiment in the details of second synchronization.
As shown in
Then, the signal comparator 18B performs the process of calculating the covariance value (Step S164). In the calculation of the covariance value, as shown in
In this embodiment, the input waveform data generator 121 binarizes the analog signal (see reference numeral 910 in
Then, the CPU 11 and the like control the correlation value calculator 125 to initialize a parameter p for specifying the predicted waveform data to 1 (Step S184) and calculate a correlation value (covariance value) C(p) among the input waveform data Sn(j) and the predicted waveform data P(p, j) (Step S186). In addition, the correlation value calculator 125 calculates the accumulated value Ca(p) of the covariance value C(p) (Step S188).
A diagram illustrating an example of the calculation of the covariance value according to this embodiment is substantially the same as
The covariance value is calculated as follows:
C(p)=(1/N)×Σ(Sn(j)×P(p,j))−Sm×Pm
As such, the total sum Σ(Sn(j)×P(p, j)) of the value Sn(j)×P(p, j), which is the product of the data values at the sampling point, is divided by the number N of samples. However, in this embodiment, the covariance value itself is not needed, but is used to detect the optimal value (the maximum value in this embodiment) of the covariance value by using comparison, which will be described below. Therefore, the division by N may be omitted. The omission of the division makes it possible to reduce the amount of calculation. In this embodiment, since the average value of the predicted waveform data P(p, j) is 0, Sm×Pm is also 0.
Therefore, in this embodiment, Σ(Sn(j)×P(p, j)) is used as the covariance value C(p). In other embodiments, Σ(Sn(j)×P(p, j)) may also be used as the covariance value C(p).
When the parameter p is smaller than 20 (No in Step S190), the parameter p increases (Step S192), and the process returns to Step S186. When covariance values C(1) to C(20) are acquired for all of the parameters p (Yes in Step S190), the process ends.
Returning to the flowchart of
As shown in
If the determination result in Step S204 is “Yes,” the reception level calculator 127 increases the value of the reception level (Step S206). Then, it is determined whether the value of the reception level is more than a maximum set value (for example, 5) (Step S208). If it is determined that the value of the reception level is more than the maximum set value (Yes in Step S208), the reception level calculator 127 sets the value of the reception level to the maximum set value (Step S210). Then, the reception level calculator 127 outputs the calculated value of the reception level to the CPU 11. The CPU 11 displays the value of the reception level on a screen of the liquid crystal display device (Step S212). The level value (0 to 5) may be displayed as a bar on the screen of the liquid crystal display device (for example, see reference numeral 1401 in
If the determination result in Step S204 is “No,” the reception level calculator 127 decreases the value of the reception level (Step S214). Then, it is determined whether the value of the reception level is less than 0, which is a minimum set value (Step S216). If it is determined that the value of the reception level is less than the minimum set value (Yes in Step S216), the reception level calculator 127 sets the value of the reception level to 0 (Step S218). Then, the process returns to Step S212.
As such, in this embodiment, the accumulated value of the covariance value in each process is referred to, and when the maximum value of the accumulated value increases, the value of the reception level increases. The maximum value of the accumulated value of the covariance value indicates the maximum degree of alignment between the rising edges of the input waveform data and the predicted waveform data. Therefore, a large maximum value of the accumulated value indicates that the signal with a relatively small amount of noise is received. In addition, the increase of the maximum value of the accumulated value indicates that the signal with a relatively small amount of noise is repeatedly received. In this embodiment, when the maximum value of the accumulated value increases, the level of the reception level increases.
Returning to the flowchart of
The interruption determinator 128 acquires the maximum value Camax of the accumulated value Ca(p) of the covariance value (Step S224). Then, the interruption determinator 128 acquires the determination result of a first interruption condition with reference to a count value interruption condition table stored in the ROM 14 (Step S226).
When the count value calculated in Step S222 is equal to or more than the table count value associated with the number of processes shown in
In the count value interruption condition table shown in
It is allowed that, as the number of repeated processes increases, the count value increases within a predetermined range. The table count value within the allowable range is stored in the count value interruption condition table 1700.
The interruption determinator 118 acquires the determination result of a second interruption condition with reference to a maximum value interruption condition table stored in the ROM 14 (Step S228).
When the maximum value Camax acquired in Step S224 is equal to or less than the table maximum value associated with the number of processes shown in
The maximum value Camax acquired in Step S224 indicates the degree of alignment between the rising edges of the predicted waveform data and the input waveform data. It is preferable that the maximum value increase as the process is repeated.
In this embodiment, it is assumed that, as the process is repeated, the maximum value increases. The minimum allowable value of the increasing maximum value is stored in the maximum value interruption condition table 1710. When the acquired maximum value is equal to or less than the allowable value, the process is stopped.
Then, the interruption determinator 118 determines whether to continue or stop a final second synchronization process based on the determination result of the first interruption condition and the determination result of the second interruption condition (Step S230). In this embodiment, when the determination result of the first interruption condition or the determination result of the second interruption condition indicates “stop,” the interruption determinator 118 determines that the process is stopped. When it is determined that the process can be continuously performed by the interruption condition acquiring process shown in
If the determination result in Step S170 is “No,” the process of detecting the second pulse position ends. In this case, the process of detecting the minute head position or the process of decoding the codes, which will be described below, is not performed.
If the determination result in Step S172 of
That is, the maximum value C(x) of the obtained covariance values C(p) is a predicted waveform with the highest correlation. However, in the covariance value obtained from a sample with insufficient parameters, there is a possibility that the maximum value erroneously appears due to an unexpected factor caused by noise. In order to exclude this case, for example, in Step S176, the following criteria are set to prevent an error in detection:
(1) The number of input waveform data used to calculate the covariance is equal to or more than a predetermined value;
(2) The value of x indicating C(x) appears plural times, the values of x appearing plural times are equal to each other, and the frequency of the value of x is higher than that of other values (x is a mode value);
(3) The values of x that continuously appear a predetermined number of times or more are equal to each other (the continuity of a mode value);
(4) The variance of C(p) is equal to or less than a predetermined value; and
(5) Kurtosis or the degree of distortion which is the amount of statistics of C(p), or an evaluation function equivalent thereto is calculated and it is determined whether the calculation result reaches a predetermined value.
When the criteria (1) to (3) are applied, a set of Steps S164 to S174 in
A method of determining validity is not limited to the above-mentioned method. The average value of the covariance values or the standard deviation may be used and the covariance value smaller than the average value may be determined to be insignificant even though the covariance value is the local maximum value. In addition, the level of significance (for example, 5 percent) that is generally used in statistics may be used.
If it is determined that the optimal value C(x) is valid (Yes in Step S176), the CPU 11 determines the changing point of the signal level of the predicted waveform data indicated by the optimal value C(x), that is, the position where the first value indicating a low level changes to the second value indicating a high level, to be the second pulse position (Step S178). The CPU 11 stores the information of the second pulse position in the RAM 15. The second pulse position is used in, for example, a process of detecting a minute head position, which will be described below.
Similar to the first embodiment shown in
The predicted waveform data generator 123 generates predicted waveform data P(j) with 2 unit time lengths in which two codes P are arranged, under the control of the CPU 11 (Step S242). As shown in
The predicted waveform data generator 123 extracts a data value (characteristic value) in the characteristic section of the generated predicted waveform data P(j) (Step S244).
Therefore, in this embodiment, in the code P, the section from 200 ms to 500 ms is a characteristic section. In the predicted waveform data P(j) shown in
In the code decoding process, the characteristic value of the characteristic section of the predicted waveform data is also used, which will be described below. In the code decoding process, it is necessary to determine whether the code is 0 or 1. However, since the minute synchronization has been completed, it is not necessary to determine whether the code is P.
As shown in
Then, a parameter i for specifying the second head position is initialized (Step S246 in
Then, the correlation value calculator 125 calculates a correlation value (covariance value) C(i) between the input waveform data Sn(i, j) in the characteristic section and the predicted waveform data P(j) in the characteristic section (Step S252). Since the covariance value is calculated by the same method as that in the second synchronization process, only a calculation relating to the characteristic section will be described. In this embodiment, in the input waveform data, Sn(i, 5) to S(i, 10) and Sn(i, 25) to S(i, 30) are extracted as the data values in the characteristic sections. In the predicted waveform data, P(5) to P(10) and P(25) to P(30) are extracted. Therefore, when the covariance value C(i) is calculated, in the total sum ΣSn(i, j)×P(j) of the products between the data values of the input waveform data and the data values of the predicted waveform data, j is 5 to 10 and 25 to 30, respectively. As described with reference to
Then, the CPU 11 determines whether the parameter i is 60 (Step S254). When the determination result in Step S254 is “No,” the parameter i increases (Step S256). Then, in Step S248, the waveform extractor 124 acquires the input waveform data Sn(i, j) with 2 unit time lengths (2 seconds) from the next second head position (that is, the position that is 20 samples away from the previous second head position of the input waveform data) under the control of the CPU 11 and the like. Then, the covariance value between the newly acquired input waveform data Sn(i, j) and the predicted waveform data P(j) is calculated.
As shown in
The data values in the characteristic sections of the input waveform data S(1, j), S(2, j), S(3, j), S(60, j) and the data values in the characteristic sections of the predicted waveform data are used to calculate the covariance values. In
When all of the correlation values (covariance values) C(1) to C(60) are acquired, the correlation value comparator 126 compares the covariance values C(1) to C(60) to find the optimal value (in this case, the maximum value) C(x) (Step S258). The CPU 11 receives the optimal value C(x) and determines whether the optimal value is valid (Step S260). The process of determining whether the optimal value is valid is performed by the same method as that in the second synchronization process (Step S176 in
If the determination result in Step S260 is “No,” the process returns to Step S246 and the waveform extractor 124 acquires input waveform data which is stored in the received waveform data buffer 22, under the control of the CPU 11 and the like.
If the determination result in Step S260 is “Yes,” the CPU 11 determines the head position of the second code P in the input waveform data indicated by the optimal value C(x), that is, the second position where the level changes from a low level to a high level, to be the head position of the minute (Step S262). The CPU 11 stores the information of the head position of the minute in the RAM 15.
Similar to the first embodiment shown in
Then, the waveform extractor 124 extracts the characteristic section of the input waveform data Sn(j) (Step S274). As shown in
Then, a parameter BCD for specifying one's place of the minute indicated by BCD is initialized to “0000” (Step S276). The predicted waveform data generator 123 generates predicted waveform data P(j) with 4 unit time lengths corresponding to the code indicated by the parameter BCD (Step S278). In addition, the predicted waveform data generator 123 extracts the characteristic sections of the predicted waveform data P(j) (Step S280). The characteristic sections have the data values of P(10) to P(16), P(30) to P(36), P(50) to P(56), and P(70) to P(76).
Then, the correlation value calculator 125 multiplies the data values of the characteristic sections of Sn(j) by the corresponding data values (characteristic values) of the characteristic sections of P(j) and calculates the covariance values C(p) based on the multiplied values (Step S282). The number of characteristic sections of the predicted waveform data P(j) is 4 and the data value of each of the characteristic sections is 1 or 0. Therefore, the product of the data values can be obtained as follows:
(the characteristic values of the characteristic sections (P(10) to P(16))×Σ(Sn(10) to Sn(16))+
(the characteristic values of the characteristic sections (P(30) to P(36))×Σ(Sn(30) to Sn(36))+
(the characteristic values of the characteristic sections (P(50) to P(56))×Σ(Sn(50) to Sn(56))+
(the characteristic values of the characteristic sections (P(70) to P(76))×Σ(Sn(70) to Sn(76)).
Therefore, it is not necessary to calculate the total sum of the products of all of the data values.
When the parameter BCD is less than “1001” (No in Step S284), the parameter BCD increases (Step S286) and the process returns to Step S278. If the determination result in Step S284 is “Yes,” the process proceeds to Step S288.
When all of the correlation values (covariance values) C(1) to C(10) are acquired, the correlation value comparator 126 compares the covariance values C(1) to C(10) to find the optimal value (in this case, the maximum value) C(x) (Step S288). The CPU 11 receives the optimal value C(x) and determines whether the optimal value is valid (Step S290). The process of determining whether the optimal value is valid is performed by the same method as that in the second synchronization process (Step S176 in
Similar to the first embodiment shown in
The second synchronization, the minute synchronization, and the code decoding process of the signal of JJY have been described above. In other standards, such as WWVB and MSF, the second synchronization, the minute synchronization, and the decoding of codes may also be performed.
Next, second synchronization in WWVB or MSF will be described. As shown in
As shown in
In the calculation of the reception level (
In Step S222, the position where the accumulated value Ca(p)t is equal to or less than a negative predetermined value is counted. In Step S224, the minimum value Camin of the accumulated value Ca(p)t is acquired. The minimum value interruption condition table is referred to in Step S228 and the minimum value of the accumulated value for each number of processes is stored. In Step S230, when the minimum value Camin acquired in Step S224 is equal to or more than a table minimum value, the determination result of the second interruption condition by the interruption determinator 118 indicates “stop.” On the other hand, when the minimum value Camin acquired in Step S224 is less than the table minimum value, the determination result of the second interruption condition indicates “continuation.”
Alternatively, as in WWVB or MSF, in order to detect the head position of the second in the data that changes from a high level to a low level at the head position of the second, another predicted waveform data, which is the inverted data of the above-mentioned predicted waveform data P(p, j), may be used. In
In this embodiment, the interruption determinator 128 determines whether to continue or stop the detection of the second pulse position based on the correlation value that is repeatedly calculated by the correlation value calculator 125 between the input waveform data generated by the input waveform data generator 121 and the predicted waveform data. The optimal value of the correlation value indicates the highest positive correlation. Therefore, it is possible to determine the amount of noise in the input waveform data with reference to the optimal value and perform accurate second synchronization using the input waveform data having a relatively small amount of noise mixed therewith.
In this embodiment, when the degree of the positive correlation indicated by the optimal value of the correlation value which is repeatedly calculated is less than a predetermined value, the interruption determinator 128 stops the detection of the second pulse position. For the optimal value indicating the highest correlation, the decrease in the degree of the positive correlation means that a large amount of noise is mixed with the input waveform data. Therefore, in this case, the second synchronization is stopped to prevent an inappropriate second head position from being detected.
In this embodiment, the interruption determinator 128 accumulates the optimal value of the correlation value to obtain an accumulated value and determines whether the degree of the positive correlation is less than a predetermined value with reference to the maximum value interruption condition table 1710 including the threshold value of the accumulated value corresponding to the number of times the process is repeated. When the optimal value is the maximum value, for the input waveform data having a relatively small amount of noise mixed therewith, the accumulated value of the optimal value (maximum value) increases as the number of processes repeated increases. Therefore, the minimum allowable value of the increasing maximum value is stored in the maximum value interruption condition table 1710 shown in
In this embodiment, when the correlation value is calculated, the interruption determinator 128 counts a predetermined correlation value indicating a positive correlation and determines whether to continue or stop the detection of the second pulse position based on the count value. The number, of predetermined correlation values indicating the positive correlation indicates the number of positions that are likely to be determined to be the second pulse position. Therefore, as the number of correlation values increases, the number of positions that are likely to be determined to be the second pulse position increases. As a result, it is difficult to detect an accurate second pulse position. Therefore, the number of positive correlation values is counted and it is determined whether to continue or stop the process based on the count value. In this way, it is possible to reliably specify an accurate second pulse position.
In this embodiment, the interruption determinator 128 refers to the count value interruption condition table 1700 including the threshold value of the count value determined by the number of times the correlation value calculating process is repeated, and interrupts the detection of the second pulse position when the count value is equal to or more than a predetermined threshold value of the count value. It is allowed that, as the number of processes repeated increases, the count value increases within a predetermined range. The count value within the allowable range is stored in the count value interruption condition table. When the count value is equal to or more than that stored in the table, the detection of the second head position is stopped. In this way, it is possible to reliably specify an accurate second pulse position.
In this embodiment, the reception level calculator 127 calculates a level value indicating the reception level of the standard time radio wave based on the optimal value of the correlation value which is repeatedly calculated, and displays the level value as, for example, in the form of a bar on the screen of the display device 13. Therefore, the user of an apparatus including the time information-acquiring apparatus, for example, an electronic watch can appropriately check the conditions of the standard time radio wave received by the apparatus.
The reception level calculator 127 increases or decreases the level value based on whether the degree of the positive correlation in the accumulated value increases or decreases, with reference to the optimal value of the accumulated value. In this way, it is possible to appropriately achieve the increase or the decrease of the level value of the reception level over time.
In this embodiment, the predicted waveform data generator 123 generates a plurality of predicted waveform data in which each sampling point has the first value indicating a low level in any one of predetermined sections before and after the changing point of the signal level, the second value indicating a high level in the other one of the predetermined sections before and after the changing point, the third value in the sections other than the predetermined sections, and the heads of the data (level change point) are shifted by a predetermined period of time. The correlation value calculator 125 calculates the correlation value between the predicted waveform data and the input waveform data.
By setting the predicted waveform data to the values described above, when the rising edge position of the predicted waveform data and the rising edge position of the input waveform data are aligned with each other, a value indicating higher positive correlation can be output. Therefore, it is possible to accurately specify the second head position.
In this embodiment, the head position of the minute in the time code is specified based on the second pulse position specified by the above-mentioned process and the signal levels before and after the head position of the time code, and the codes included in the time code are acquired. Then, the values of codes including the day, hour, and minute codes forming the time code are acquired based on values indicated by the codes. Thereafter, the current time is calculated based on the acquired values of the codes. Therefore, it is possible to correct the time obtained by the internal timer 17 with the calculated current time.
The second embodiment may be modified as follows. For example, in the above-described embodiment, when the position of one second pulse is detected, the predicted waveform data having a following configuration is used. That is, the predicted waveform data has the first value −1 indicating a low level in a predetermined section (temporally old side) before a rising point from a low level to a high level, the second value 1 indicating a high level in a predetermined section (temporally new side) after the rising point, and the third value indicating 0 in sections other than the predetermined sections before and after the rising point. However, the invention is not limited thereto. It may be possible to use, for example, predicted waveform data in which a code forming the time code, for example, code 0 is repeated.
Then, the predicted waveform data generator 123 extracts the characteristic sections of the predicted waveform data items P(1, j) to P(20, j) (Step S304). As described above, in the code 0, the section from 500 ms to 800 ms from the head of the code is the characteristic section as shown in
For example, the characteristic sections of the predicted waveform data P(1, j) have the data values of P(1, 10) to P(1, 16), P(1, 30) to P(1, 36), P(1, 50) to P(1, 56), and P(1, 70) to P(1, 76).
The characteristic sections of the predicted waveform data P(2, j) have the data values of P(1, 11) to P(1, 17), P(1, 31) to P(1, 37), P(1, 51) to P(1, 57), and P(1, 71) to P(1, 77).
In general, the characteristic sections of the predicted waveform data (p, j) have the data values of P(p, 10+(p−1)) to P(p, 16+(p−1)), P(p, 30+(p−1)) to P(p, 36+(p−1)), P(p, 50+(p−1)) to P(p, 56+(p−1)), and P(p, 70+(p−1)) to P(p, 76+(p−1)). When the value j on the right side of P(p, j) is greater than 80, j=j−80 is established. In addition, the data value (characteristic value) of the characteristic section is 1 as shown in
Then, a process of calculating the covariance value is performed (Step S306).
Then, the waveform extractor 124 acquires the data values of the characteristic sections of the input waveform data Sn(1) corresponding to the characteristic sections of the predicted waveform data (Step S336). In Step S336, the data values of the characteristic sections of the input waveform data Sn(j) corresponding to the predicted waveform data P(p, j) are Sn(10+(p−1)) to Sn(16+(p−1)), Sn(30+(p−1)) to Sn(36+(p−1)), Sn(50+(p−1)) to Sn(56+(p−1)), and Sn(70+(p−1)) to Sn(76+(p−1)).
Then, the correlation value calculator 127 multiplies the data values of the characteristic sections of Sn(j) by the corresponding data values (characteristic values) of the characteristic sections of P(p, j) and calculates the covariance values based on the result of multiplication (Step S338). As described above, the data values of the characteristic sections of the predicted waveform data P(p, j) are 1. Therefore, in the multiplication of the data values of the characteristic sections of Sn(j) and the corresponding data values (characteristic values) of the characteristic sections of P(p, j), the data values of the characteristic sections of Sn(j) only need to be accumulated to calculate ΣSn(j). In addition, the correlation value calculator 127 calculates the accumulated value Ca(p) of the covariance value C(p) (Step S340).
When the parameter p is smaller than 20 (No in Step S342), the parameter p increases (Step S344) and the process returns to Step S336. If the determination result in Step S342 is “Yes,” the process ends.
In
As described above, in the modification of the second embodiment, the predicted waveform data generator 133 generates a plurality of predicted waveform data with waveforms including a predetermined code in the time code (for example, the code 0) and the correlation value calculator 125 calculates the correlation value between the predicted waveform data and the input waveform data. The use of the predicted waveform data makes it possible to reliably specify accurate second synchronization.
In the process of calculating and displaying the reception level according to the second embodiment, the maximum values of the accumulated values Ca(p) of the covariance values are compared with each other to determine whether the maximum value increases. When the maximum value is determined, another index value V(p)=Ca(p−1)+C(p)+C(p+1) considering the previous and next accumulated values may be used to determine whether the maximum value of the index value V(p) increases.
In the process of calculating and displaying the reception level according to the second embodiment, the maximum value of the accumulated value Ca(p) may be divided by the number of processes and then normalized, and the ratio of the normalized value to a predetermined value corresponding to the maximum level may be used as the level value of the reception level.
In the process of acquiring the interruption conditions according to the second embodiment, the maximum value Camax of the accumulated value is acquired and the second interruption condition is determined based on the acquired maximum value. However, the invention is not limited thereto. The second interruption condition may be determined based on another index value V(p)=Ca(p−1)+C(p)+C(p+1) considering the previous and next accumulated values.
In the second embodiment, when “stop” is determined from the first interruption condition or the second interruption condition, the detection of the second head position is stopped. However, the invention is not limited thereto. For example, when “stop” is determined from both the first interruption condition and the second interruption condition, the detection of the second head position may be stopped.
In the second embodiment, the first value indicating a low level is −1, the second value indicating a high level is 1, and the third value other than the first and second values is 0. However, the invention is not limited thereto. For example, the first value and the second value may be as follows.
(1) When the first value appears from the input waveform data and the first value appears from the predicted waveform data, or when the second value appears from the input waveform data and the second value appears from the predicted waveform data, the values are multiplied to obtain a predetermined positive value indicating a positive correlation. That is, when the same value appears from the input waveform data and the predicted waveform data, a predetermined positive value is obtained.
(2) When the first value appears from the input waveform data and the second value appears from the predicted waveform data, or when the second value appears from the input waveform data and the first value appears from the predicted waveform data, the values are multiplied to obtain a predetermined negative value indicating a negative correlation. That is, when different values appear from the input waveform data and the predicted waveform data, a predetermined negative value is obtained. It is preferable that the absolute values of the predetermined positive value and the predetermined negative value are the same.
The third value may not be 0. However, the third value should not affect the correlation value, such as the covariance value, when it is multiplied by the first value or the second value.
In the second embodiment, the covariance value is used as the correlation value, but the invention is not limited thereto. For example, a residual, which is the total sum of the absolute values of differences, may be used as the correlation value. Alternatively, a mutual correlation coefficient may be used instead of the covariance or the residual.
Next, a third embodiment will be described. A block diagram illustrating the structure of a radio wave timepiece according to the third embodiment is the same as that in the first embodiment shown in
However, the CPU 11 (see
In this embodiment, for example, the predicted waveform data and the input waveform data are compared with each other to detect the head of the minute and the values of various kinds of codes including hour, minute, and date codes. When the date and time are specified, it is possible to calculate an error in the internal timer 17 and correct the current time measured by the internal timer 17.
The ROM 14 (see
A block diagram illustrating an example of the structure of a receiver according to the third embodiment is substantially the same as
In this embodiment, for example, the predicted waveform data and the input waveform data are compared with each other to detect the head of the minute and the values of various kinds of codes including hour, minute, and date codes. When the date and time are specified, it is possible to calculate an error in the internal timer 17 and correct the current time measured by the internal timer 17. The receiver 16 includes, for example, an antenna circuit or a detector. The receiver 16 obtains a demodulated signal from the standard time radio wave received by the antenna circuit and outputs the signal to the signal comparator 18C (
The operations of the input waveform data generator 221 and the received waveform data buffer 222 are the same as those of the input waveform data generator 21 and the received waveform data buffer 22 according to the first embodiment.
The predicted waveform data generator 223 generates predicted waveform data, which is a comparison target, with a predetermined time length. This predicted waveform data is used in each process, which will be described below. The predicted waveform data generated by the predicted waveform data generator 223 will be described in each of a process of detecting a second pulse position, a process of detecting a minute head position, and a code decoding process. The operations of the waveform extractor 224, the correlation value calculator 225, and the correlation value comparator 226 are the same as those of the waveform extractor 24, the correlation value calculator 25, and the correlation value comparator 26 according to the first embodiment.
The transmitting station determinator 227 determines a transmitting station transmitting the standard time radio wave signal based on the covariance value calculated by the correlation value calculator 225 and outputs the information thereof to the CPU 11.
Examples of the codes based on the JJY, WWVB, and MSF standards are the same as those shown in
The standard time radio wave based on the JJY standard, the standard time radio wave based on the WWVB standard, and the standard time radio wave based on the MSF standard which are transmitted from the transmitting stations in Saga, Japan each have a transmission frequency of 60 kHz. Therefore, it is difficult to determine the kind of standard time radio wave by changing a tuning frequency of the receiver. Therefore, in the third embodiment, the kind of standard time radio wave, that is, the transmitting station that transmits the standard time radio wave is determined based on the correlation value (covariance value) between the input waveform data based on the standard time radio wave and predicted waveform data, which will be described below.
In the third embodiment, in order to accurately detect the standard time radio wave signal, for example the signal of JJY which changes from a low level to a high level at the head of the second, a plurality of predicted waveform data is generated in which a predetermined number of waveform data items (four data items in this embodiment) each having a unit time length and a predetermined data value are continuously arranged at a time interval of 50 ms. The correlation values between the plurality of predicted waveform data and the input waveform data are calculated and a changing point of the predicted waveform data indicating the optimal correlation value from a low level to a high level is determined to be the second pulse position (the head position of the second). A plurality of predicted waveform data with the same shape may be used to detect the change of the signal of WWVB or MSF from a high level to a low level at the head of the second.
When Step S352 ends, the CPU 11 and the like detect the head position of the minute, i.e. the head position of one frame of the standard time radio wave signal (Step S354).
Then, the CPU 11 and the like decode various kinds of codes (for example, a code M1 indicating one's place of the minute, a code M10 indicating ten's place of the minute, and other codes indicating the date or day in JJY) of the standard time radio wave signal based on the comparison between the predicted waveform data and the input waveform data (Step S356).
The process (Step S352) of determining the transmitting station and detecting the second pulse position according to the third embodiment will be described in more detail. The predicted waveform data used in second synchronization according to the third embodiment is the same as that shown in
As shown in
Then, the signal comparator 18C performs a process of calculating the covariance value (Step S364). Since the process of calculating the covariance value is the same as that in the second embodiment shown in
After Step S364 (the process of calculating the covariance value) in
As shown in
In these examples, p=3 corresponds to the head position of the second. The correlation value (the accumulated value of the covariance value) Ca(p) shown in the histogram indicates the correlation (the similarity of the waveform) between the input waveform data and the predicted waveform data. The predicted waveform data P(p, j) (in the example of
As described with reference to
The transmitting station determinator 227 determines whether the sum of the maximum value Camax and the minimum value Camin is greater than 0 based on the accumulated value of the covariance value (Step S384). If the determination result in Step S384 is “Yes,” the transmitting station determinator 227 determines whether the transmitting station is a JJY transmitting station (Step S386). After Step S386, the process returns to the main routine (Step S372 in
If the determination result in Step S384 is “No,” it is necessary to determine whether the transmitting station is a WWVB or MSF transmitting station. As shown in
As shown in
In the input waveform data obtained from the standard time radio wave of WWVB, when taking the appearance frequency of the code into consideration, it is expected that the maximum value of the accumulated value will appear at the position that is 200 ms or 500 ms away from the head position of the second. Since the code P is a marker, the appearance frequency of the code P is lower than that of other codes 0 and 1. Therefore, it is not considered that the maximum value of the accumulated value appears at the position that is 800 ms away from the head position of the second.
In the input waveform data obtained from the standard time radio wave of MSF, when the appearance frequency of the code is considered, it is expected that the maximum value of the accumulated value will appear at the position that is 100 ms, 200 ms or 300 ms away from the head position of the second. Since the code M is a marker, the appearance frequency of the code M is lower than that of other codes. Therefore, it is not considered that the maximum value of the accumulated value appears at the position that is 500 ms away from the head position of the second.
If the determination result in Step S384 is “No,” the transmitting station determinator 227 detects the accumulated value Ca(p1) that is at a position 500 ms away from the position where the minimum value Camin of the accumulated value appears (Step S388). Then, the transmitting station determinator 227 determines whether the Ca(p1) is the maximum value of the accumulated value (Step S390). If the determination result in Step S390 is “Yes,” the transmitting station determinator 227 determines that the transmitting station is a WWVB transmitting station (Step S392). After Step S392, the process returns to the main routine (Step S372 in
If the determination result in Step S390 is “No,” the transmitting station determinator 227 detects the accumulated value Ca(p2) that is at a position 800 ms away from the position where the minimum value Camin of the accumulated value appears, in addition to the accumulated value Ca(p1) that is 500 ms away from the position where the minimum value Camin of the accumulated value appears (Step S394), and determines whether Ca(p1) or Ca(p2) is the second largest value of the accumulated value Ca (Step S396). If the determination result in Step S396 is “Yes,” the transmitting station determinator 227 determines that the transmitting station is a WWVB transmitting station (Step S392).
On the other hand, if the determination result in Step S396 is “No,” the transmitting station determinator 227 determines that the transmitting station is an MSF transmitting station (Step S398). After Step S398, the process returns to the main routine (Step S372 in
When the process of determining the transmitting station shown in
Next, the process of determining whether the optimal value is valid when the transmitting station is a JJY transmitting station will be described. The maximum value C(x) of the obtained covariance values C(p) indicates a predicted waveform with the highest correlation. However, in the covariance value obtained from a sample with insufficient parameters, the erroneous maximum value is likely to appear due to an unexpected factor caused by noise. In order to exclude this case, for example, in Step S374, the following criteria are set to prevent an error in detection:
(1) The number of input waveform data used to calculate the covariance is equal to or more than a predetermined value;
(2) The value of x indicating C(x) appears plural times, the values of x appearing plural times are equal to each other, and the frequency of the value of x is higher than that of other values (x is a mode value);
(3) The values of x that continuously appear a predetermined number of times or more are equal to each other (the continuity of a mode value);
(4) The variance of C(p) is equal to or less than a predetermined value; and
(5) Kurtosis or the degree of distortion, which is the amount of statistics of C(p), or an evaluation function thereof is calculated and it is determined whether the calculation result reaches a predetermined value.
When the criteria (1) to (3) are applied, a set of Steps S364 to S374 in
A method of determining validity is not limited to the above-mentioned method. The average value of the correlation values or the standard deviation may be used and the correlation value smaller than the average value may be determined to be insignificant even though the correlation value is the maximum value. In addition, the level of significance (for example, 5 percent) that is generally used in statistics may be used.
If it is determined that the optimal value C(x) is valid (Yes in Step S374), the CPU 11 determines the changing point of the signal level of the predicted waveform data indicated by the optimal value C(x), that is, the position where the first value indicating a low level changes to the second value indicating a high level, to be the second pulse position (Step S376). The CPU 11 stores the information of the second pulse position in the RAM 15. The second pulse position is used in, for example, a process of detecting a minute head position, which will be described below.
As shown in
Next, the case in which the transmitting station is a JJY transmitting station will be described. In this case, predicted waveform data with 2 unit time lengths is generated in which the codes P with a 20% duty are continuously arranged. In addition, 60 input waveform data items each having 2 unit time lengths (2 seconds) starting at the second pulse position (that is, the head position of the second) are generated. It is possible to obtain 60 correlation values (covariance values) C(1) to C(60) by calculating the correlation value between the predicted waveform data and each of the 60 input waveform data items.
A flowchart illustrating an example of the detection of the minute head position (minute synchronization) according to the third embodiment in more detail is the same as
When the detection of the minute head position shown in
A flowchart illustrating an example of the process of detecting one's place of the minute according to the third embodiment is the same as
Other codes, such as ten's place of the minute, one's place and ten's place of the hour, and the day, may be decoded in the same manner as the method of decoding the one's place of the minute. When time information including, for example, the current date, day, and time is acquired through the code decoding process, the CPU 11 stores the obtained time information in the RAM 15. In addition, the CPU 11 corrects the current time measured by the internal timer 17 based on the current time obtained from the code and displays the obtained current time on the display device 13 (Step S358).
The second synchronization, the minute synchronization, and the code decoding process of the signal in JJY have been described above. As described in the first and second embodiments, in other standards, such as WWVB and MSF, the second synchronization, the minute synchronization, and the decoding of the codes may also be performed.
Next, covariance in WWVB or MSF will be described again. As shown in
As shown in
Alternatively, as in WWVB or MSF, in order to detect the head position of the second in the data that changes from a high level to a low level at the head position of the second, another predicted waveform data, which is the inverted data of the predicted waveform data P(p, j), may be used. In
The process of detecting the head position of the minute and the process of detecting one's place of the minute in the case in which the transmitting station is a JJY transmitting station have been described above with reference to
In the detection of the minute head position, similar to
As shown in
As shown in
As shown in
In this embodiment, the transmitting station determinator 227 determines the kind of transmitting station transmitting the standard time radio wave based on the accumulated value of the correlation value calculated by the correlation value calculator 225. The correlation value comparator 226 compares the accumulated values and detects the optimal value of the accumulated value based on the kind of transmitting station determined by the transmitting station determinator 227. The CPU 11 detects the second pulse position in the time code based on the predicted waveform data with the optimal value. As such, the accumulated value of the correlation value is used to determine the kind of transmitting station and is also used to detect the second pulse position. It is possible to determine the kind of transmitting station and specify the second pulse position substantially at the same time using the optimal value of the correlation value. Therefore, it is possible to reduce the processing time and power consumption.
In this embodiment, the transmitting station determinator 227 determines the kind of transmitting station based on the sum of the maximum value and the minimum value of the accumulated value. When the values of the input waveform data and the predicted waveform data change at the same time and have the same phase, the correlation value indicates a positive correlation. On the other hand, when the values of the input waveform data and the predicted waveform data change at the same time and have opposite phases, the correlation value indicates a negative correlation. In this way, according to this embodiment, it is possible to discriminate between the transmitting station (for example, a JJY transmitting station) outputting a code with a waveform that rises at the head position of the second and the transmitting station (for example, a WWVB or MSF transmitting station) outputting a code with a waveform that falls at the head position of the second.
The transmitting station determinator 227 determines the kind of transmitting station based on a difference between the minimum value and the maximum value of the accumulated value or a difference between the maximum value and the minimum value of the accumulated value. For example, in the standard time radio waves of a plurality of standards in which the values thereof change in phase (for example, falling) at the head position of the code, the codes of the standard time radio waves have different shapes. The kind of transmitting station is determined based on the difference between the minimum value (or the maximum value) of the accumulated value that is considered as the head position of the second and the maximum value (or the minimum value) that is considered as the changing point of the value of the code. In this way, it is possible to discriminate a plurality of standards in which the values change in phase at the head position of the code.
For example, in the above-described embodiment, the predicted waveform data generator 223 generates a plurality of predicted waveform data in which each sampling point has any one of the first value indicating a low level in either one of the predetermined sections before and after the changing point of the signal level, the second value indicating a high level in the other one of the predetermined sections before and after the changing point of the signal level, and the third value in sections other than the predetermined sections and the waveforms thereof are arranged at intervals of a predetermined number of samples. When the sum of the maximum value and the minimum value is a positive value, the transmitting station determinator 227 can determine that the kind of transmitting station is a JJY transmitting station outputting a code with a waveform that rises at the head position of the second.
In this embodiment, the head position of the minute in the time code is specified and the codes included in the time code are acquired based on the kind of transmitting station and the second pulse position specified by the above-mentioned process and the signal levels before and after the head position of the time code. Then, the values of the codes including the date, hour, and minute codes are acquired based on the values indicated by the codes, and the current time is calculated based on the acquired values of the codes. Therefore, it is possible to correct the time obtained by the internal timer 17 with the calculated current time.
Next, a modification of the third embodiment will be described. In the third embodiment, JJY, WWVB, or MSF is determined according to whether the sum of the maximum value and the minimum value of the accumulated value of the covariance value is a positive value or a negative value. In the modification, the conditions of determining JJY, WWVB, or MSF are changed considering the influence of noise.
Camax=Ca(q−1)+Ca(q)+Ca(q+1).
Similarly, the transmitting station determinator 227 adds the accumulated values Ca(r−1) and Ca(r+1) before and after a position r indicating the minimum value Camin to the original minimum value Camin (=Ca(r)) (Step S406). After the addition, the minimum value Camin is as follows:
Camin=Ca(r−1)+Ca(r)+Ca(r+1).
The transmitting station determinator 227 determines whether the sum of the maximum value Camax after the addition and the minimum value Camin after the addition is greater than 0 (Step S408). If the determination result in Step S408 is “Yes,” the transmitting station determinator 227 determines that the transmitting station is a JJY transmitting station (Step S410). If the determination result in Step S408 is “No,” the process proceeds to Step S412. Steps S412 to S422 are the same as Steps S388 to S398 shown in
The advantages when the modification of the third embodiment is applied will be described. In some cases, the actual head position of the second is disposed in the vicinity of the center between adjacent sampling points according to the sampling timing. In this case, the accumulated value Ca is the maximum value or the minimum value at one of the adjacent sampling points on both sides of the head position. However, the absolute value of the maximum value or the minimum value is not sufficient and the transmitting station is not likely to be accurately determined.
In
As described above, in order to prevent an error in determination when the head position of the second is disposed between the sampling points, in the modification of the third embodiment, the accumulated values corresponding to the positions before and after the position where the maximum value appears and the accumulated values corresponding to the positions before and after the position where the minimum value appears are considered.
According to the modification of the third embodiment, in the examples shown in
In
Similarly, in
According to the modification of the third embodiment, the transmitting station determinator 227 adds the accumulated values Ca(q−n) to Ca(q+n) (for example, Ca(q−1), Ca(q), and Ca(q+1)) corresponding to a plurality of samples adjacent to the position indicated by the accumulated value Ca(q), which is the maximum value, and acquires the added maximum value. In addition, the transmitting station determinator 227 adds the accumulated values Ca(r−n) to Ca(r+n) (for example, Ca(r−1), Ca(r), and Ca(r+1)) corresponding to a plurality of samples adjacent to the position indicated by the accumulated value Ca(r), which is the minimum value, and acquires the added minimum value. Then, the transmitting station determinator 227 determines the kind of transmitting station based on the sum of the added maximum value and the added minimum value. In this way, even when the second head position is disposed between the sampling points or a relatively large amount of noise is included in the input waveform data, it is possible to appropriately determine the kind of transmitting station.
The invention is not limited to the above-described embodiments, but various modifications and changes of the invention can be made without departing from the scope and spirit of the invention. The modifications and changes are also included in the scope of the invention.
For example, in the third embodiment, the processes in Steps S388 to S398 shown in
Then, the transmitting station determinator 227 determines whether the accumulated value Ca(p1) or Ca(p2) corresponds to one of the top three accumulated values (Step S436). If the determination result in Step S436 is “Yes,” the transmitting station determinator 227 determines that the transmitting station is a WWVB transmitting station (Step S438). On the other hand, if the determination result in Step S436 is “No,” the transmitting station determinator 227 determines that the transmitting station is an MSF transmitting station (Step S440).
Then, the transmitting station determinator 227 determines whether the accumulated value Ca(p4) corresponds to any one of the top three accumulated values (Step S466). If the determination result in Step S466 is “Yes,” the transmitting station determinator 227 determines that the transmitting station is an MSF transmitting station (Step S468). On the other hand, if the determination result in Step S466 is “No,” the transmitting station determinator 227 determines that the transmitting station is a WWVB transmitting station (Step S470).
In the third embodiment, the first value indicating a low level is −1, the second value indicating a high level is 1, and the third value other than the first and second values is 0. However, the invention is not limited thereto. The first value and the second value may be as follows.
(1) When the first value appears from the input waveform data and the first value appears from the predicted waveform data, or when the second value appears from the input waveform data and the second value appears from the predicted waveform data, the values are arithmetically operated to obtain a predetermined positive value indicating a positive correlation. That is, when the same value appears from the input waveform data and the predicted waveform data, a predetermined positive value is obtained.
(2) When the first value appears from the input waveform data and the second value appears from the predicted waveform data, or when the second value appears from the input waveform data and the first value appears from the predicted waveform data, the values are arithmetically operated to obtain a predetermined negative value indicating a negative correlation. That is, when different values appear from the input waveform data and the predicted waveform data, a predetermined negative value is obtained. It is preferable that the predetermined negative value and the predetermined positive value have the same absolute value.
The third value may not be 0. However, the third value should not affect the correlation value, such as the covariance value, when it is arithmetically operated by the first value or the second value.
In the third embodiment, the covariance value is used as the correlation value, but the invention is not limited thereto. For example, a residual, which is the total sum of the absolute values of differences, may be used as the correlation value. Alternatively, a correlation coefficient may be used instead of the covariance or the residual.
In the third embodiment, the accumulated values (for example, Ca(p1) and Ca(p2)) that are respectively 500 ms and 800 ms from the position where the minimum value Gamin appears are referred to in order to determine whether the transmitting station is of WWVB or MSF, (for example, see Steps S388 and S394 in
In the first modification of the third embodiment, the accumulated values corresponding to two samples before and after the position indicating the maximum value Camax are added to the maximum value and the accumulated values corresponding to two samples before and after the position indicating the minimum value Camin are added to the minimum value (see Steps S404 and S406 in
Number | Date | Country | Kind |
---|---|---|---|
2009-220124 | Sep 2009 | JP | national |
2009-244095 | Oct 2009 | JP | national |
2009-248786 | Oct 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
7460012 | Ii | Dec 2008 | B2 |
7848180 | Someya et al. | Dec 2010 | B2 |
20050195690 | Kondo | Sep 2005 | A1 |
20120082008 | Eliezer et al. | Apr 2012 | A1 |
Number | Date | Country |
---|---|---|
2 146 257 | Jan 2010 | EP |
2 219 087 | Aug 2010 | EP |
2005249632 | Sep 2005 | JP |
0175470 | Oct 2001 | WO |
Number | Date | Country | |
---|---|---|---|
20110075522 A1 | Mar 2011 | US |