The present invention relates generally to utility meters, and more particularly, to data logging in utility meters.
Utility meters are used to monitor the consumption of a utility-delivered commodity, such as, gas, water and/or electricity. The consumption information generated by a utility meter is typically used for billing purposes. For example, in its simplest form, a utility meter detects consumption and records a value representative of a total consumption over time. The consumer of the commodity is billed in proportion to the customer's usage of the commodity as measured by the meter.
Accordingly, one of the goals of electricity metering is to accurately measure the use or consumption of electrical energy resources. With such measurements, the cost of generating and delivering electricity may be allocated among consumers in relatively logical manner. Another goal of electricity metering is to help identify electrical energy generation and delivery needs. For example, cumulative electricity consumption measurements for a service area can help determine the appropriate sizing of transformers and other equipment. Such goals apply similarly to gas and water metering.
In order to study energy usage patterns, and in some circumstances, adjust billing practices appropriately, it is sometimes advantageous to log commodity consumption as a function of time. In electricity metering, this practice is known as load profiling. A load profiling meter stores a series of records identifying one or more metered quantities and a time of day in which the metered quantity was consumed. For example, a load-profiling electricity meter may record and store energy consumption (i.e. watt-hrs), average power, apparent energy consumption (VA-hrs) and amp-hours for each fifteen minute interval in time. The resulting load profile data is stored in a memory, preferably non-volatile memory, within the meter. The meter may communicate the load profile data log to a utility computer by either remote transmission, or through a local connection. Once the load profile data is transferred from the meter, the data may be erased or overwritten within the meter.
Although meters and load profiling systems are designed such that load profile data can be erased from the meter periodically, the storage of load profile data can still require significant amounts of memory. Presently, it is common for meters to generate metering values of up to 32 bits. Storing 32 bit values for multiple quantities every five to fifteen minutes, along with appropriate time and date stamps, can consume substantial memory over the course of time, for example, a month. In addition to the memory requirements, the transfer of such data can occupy significant bandwidth. Accordingly, there is a need to ease the memory requirement and transmission requirements to carry out load profiling.
A first aspect of the invention is a method of recording data for load profiling or other purposes within a meter that employs a time recovery scheme for load profiling data stored in a data stream.
A first embodiment is a method for storing information within a utility meter that includes storing a data stream comprising a plurality of data values regarding a metered quantity delivered to a load corresponding to a plurality of time periods, wherein the plurality of data values are stored sequentially based on their corresponding time periods. The method also includes responsive to a power outage, inserting into the data stream a time stamp corresponding to a time period in the plurality of time periods in which the power outage occurred.
The above described features and advantages, as well as others, will become more readily apparent to those of ordinary skill in the art by reference to the following detailed description and accompanying drawings.
In general, the meter 10 is configured to store load profile data in a compressed way in at least one of the memories 112, 113. As mentioned above, a load profile is a series of periodic snap-shots of measured information (such as voltage, current or energy), which may be used to capture a customer's consumption profile through time, for diagnostic or billing purposes. A load profile may include periodic measurements of a single quantity, such as energy (watt-hrs), or periodic measurement of multiple quantities, each forming a “channel” of the load profile data.
For example, a load profile could record watt hour consumption in a first channel, and VAR-hrs in another channel. The exemplary load profile could store values in both channels for every 5 minute interval over several weeks. An “interval” is the amount of time that corresponds to each piece of data stored, in this case, a five (5) minute time period.
In the embodiment described herein, the load profile data is compressed before being stored in memory 112, preferably an EEPROM inside the meter 10. Unlike generic compression methods, the compression method for load profile data must be adapted for use with a never-ending stream of data, and furthermore does not rely on a dictionary of commonly found patterns (such as used in LZW compression method). Such a dictionary of patterns would quickly become obsolete or would refer to ancient data that would be overwritten.
Instead, the compression method described herein is partly based on the idea that, throughout the course of a day, the load is somewhat stable. Because the load is relatively stable, the data from one interval is not, in general, significantly different from the data of the previous interval. Thus, part of this compression scheme relies on the use of differential values, or in other words, storing for each interval the difference of the actual value measured from the same measured value in the prior interval.
To achieve a compression ratio of about 60% of less, this algorithm:
a) Divides the memory 112 in blocks of data that are “self-contained”, meaning that no data from another block is needed to decode that block. This is needed in order to be able to read only part of the data stream without having to decode the stream from the very end of it;
b) Stores the actual value of the data “as is” only for the first or last interval of every block. For every other interval, only the delta (difference between that interval and the next one) is stored. That allows for a smaller number to be stored, per interval, per channel; and
c) Compresses smaller numbers using fewer bits than those used for bigger numbers. Since the values being recorded are relatively stable (and hence the differential values are small), more small numbers are recorded than bigger numbers.
Referring again specifically to
In any event, the digital signals are typically sequences of digital samples representative of an instantaneous voltage or current measurement on one phase with respect to either neutral or another phase. Circuits capable of generating such signals are known in the art.
The processing circuit 116 is configured to calculate one or more energy consumption values based on the digital signals. The energy consumption values may be communicated to a remote device using the communication circuit 118, displayed using the display 120, stored in the data store 112, or preferably some combination of the foregoing. At least some energy consumption values are stored in the first memory 112 using one or more of the compression techniques disclosed herein.
In further detail, the scaling circuit 110 may suitably comprise current and voltage sensors, not shown. The voltage sensors, which may, for example, include voltage dividers, generate a scaled down version of the voltage present on phases of the power lines 12. The current sensors, which may suitably include current transformers, shunts, embedded coil devices and the like, generate a voltage or current signal that is a scaled down version of the current present on the phases of the power lines 12. Various voltage and current sensors are conventional. However, the embodiments of the invention may readily be employed with non-conventional sensors as well.
The ADC circuit 114 includes one or more analog-to-digital converters that convert the scaled measurement signals into digital voltage and current measurement signals. Many circuits capable of generating digital voltage and circuit waveform signals are well known in the art. Suitable examples of analog to digital conversion circuits having such capabilities are described in U.S. Pat. No. 6,374,188; U.S. Pat. No. 6,564,159; U.S. Pat. No. 6,121,158 and U.S. Pat. No. 5,933,004, all of which are incorporated herein by reference. Moreover, the ADC circuit 114 may readily be a part of an integrated metering chip package, as will be discussed below.
The processing circuit 116 is a device that employs one or more processing devices such as microprocessors, microcontrollers, digital signal processors, discrete digital circuits and/or combinations thereof. In general, the processing circuit 116 executes software operations stored in memory to perform the various operations ascribed to the processing circuit 116 herein. As mentioned above, the processing circuit 116 is operable to generate energy consumption data based on the digital signals. In one example, the processing circuit 116 generates watt-hour information based on an accumulation of products of contemporaneous voltage and current samples. For example, true watt-hours for a particular phase may be calculated as the vector product of the current waveform and the voltage waveform. This vector product may be carried out with sampled voltage (Vn) and sampled current (In) by the formula:
Whrs=ΣVn*In. (3)
where Whrs is an accumulated energy value (i.e. watt-hours) for a time frame from a starting time n0 to a time corresponding to n.
In addition, the processing circuit 116 may generate VA, VA-hrs, watt-hours, VAR-hrs, power factor, root-mean-square voltage and/or current, or combinations of any of the foregoing. Various processing circuits operable to generate energy consumption data from digital voltage and digital current measurement signals are well known in the art. Suitable examples of such circuits are described in U.S. Pat. No. 6,374,188; U.S. Pat. No. 6,564,159; U.S. Pat. No. 6,121,158 and U.S. Pat. No. 5,933,004. However, in one preferred embodiment, the processing circuit is (or includes) a processing element of a metering integrated circuit chip such as the Maxim 71M6533 measurement chip.
In accordance with one embodiment, the processing circuit 116 is configured to generate first information regarding a metered quantity delivered to a load corresponding to a first period of time. The first information may be an actual measured quantity over the first period time (e.g. watt-hrs consumed over the first period of time, average power during the first period of time, etc.), or a difference between a measured quantity over the first period time and the measured quantity over a previous period of time (e.g. a differential value). The processing circuit is further configured to obtain a stored code associated with one of a plurality of predetermined ranges of values in which the first information falls. In particular, within the meter, each possible value of the metering quantity (e.g. a 32-bit value) is associated with one of a plurality or ranges of values. The processing circuit 116 is configured to determine which of the ranges of values the first information falls within, and determine the code associated with that range of values. The processing circuit 116 is also configured to generate a compressed value representative of a numerical position of the first information within one of the plurality of predetermined ranges of values. Finally, the processing circuit 116 is further configured to store the code and the compressed value in a memory, for example, the first memory 112.
In at least some embodiments, the second memory 113 includes memory located within the integrated package that houses the processing circuit 116. The second memory 113 may suitably be a random access memory, EEPROM, other memory, or a combination of several types of memory. The second memory 113 includes a software program that is executed by the processing circuit 116 to perform the operations of the processing circuit 116 described herein, including those of
The communication circuit 118 is a device that is in some embodiments configured to communicate data between the metering unit 10 and one or more remote devices. In a system such as that shown in
In addition or in the alternative, the communication circuit 118 is configured to communicate with a locally coupled device, such as a portable computing device via an optical port. The communication circuit 118 may include an optical or electrical data port, not shown, for this purpose.
The meter display 120, which is optional, may be a digital display such as a liquid crystal display. It will be appreciated that the exact nature of the display is not particularly important to the implementation of the invention. Nevertheless, there is an advantage of including at least some display capabilities. LCD displays, moreover, have been found to have a particularly advantageous set of qualities for use in electronic meters.
In general, the scaling unit 110 of the meter 10 is operably connected to the electrical service lines to obtain voltage measurements and current measurements representative of the voltage and current delivered to the load. The scaling unit 110 is further operably coupled to provide voltage and current measurement signals to the ADC circuit 114.
The ADC circuit 114, in turn, samples each of the voltage and current measurement signals and generates corresponding digital sample streams. The sample rate is typically many times the cycle frequency of the AC waveform, such that the samples collectively provide an accurate sampled representation of the corresponding analog waveform. The operations of the scaling unit 110 and the ADC circuit 114 as discussed above are conventional.
The processing circuit 116 then calculates watt-hrs by multiplying contemporaneous voltage and current samples, and accumulating the resulting products. Using sampling, the processing circuit 116 may suitably perform the following calculations:
Watt-hra=Σ(Va(s)*Ia(s)) (1)
Watt-hrb=Σ(Vb(s)*Ib(s)) (2)
Watt-hrc=Σ(Vc(s)*Ic(s)) (3)
Watt-hr=Watt-hra+Watt-hrb+Watt-hrc (4)
wherein Vx(s) is the sampled voltage at a time s on phase x at the meter 10, and Ix(s) is the sampled current at a time s on phase x at the meter 10. In the above equations, the term Watt-hr is actually an energy measurement in terms of watt-hrs.
The processing circuit 116 may suitably calculate vector (or load) VARs using equations that use 90 phase degree shifted voltage measurements, as is known.
VARa=Σ(Va(s+90°)*Ia(s)) (5)
VARb=Σ(Vb(s+90°)*Ib(s)) (6)
VARc=Σ(Vc(s+90°)*Ic(s)) (7)
VAR=VARa+VARb+VARc (8)
It will be appreciated that the various other value may be calculated using the samples signals Va(s), Vb(s), Vc(s), Ia(s), Ib(s), and Ic(s), include per-phase or aggregate average power, amp-hrs, VA, VA-hrs, and the like.
The processing circuit 116 performs such calculations in an ongoing manner to thereby detect, track and record various aspects about the energy being delivered to the load. Thus, the scaling circuit 110, the ADC circuit 114 and at least a part of the processing circuit 116 collectively form a metrology circuit 117 that is operably coupled to power lines 12 to a load and configured to generate energy consumption values based on the voltage and current provided to the load. It will be appreciated that the metrology circuit 117 may take other forms that are conventional.
In addition, from time to time, for example, every five to fifteen minutes, the processing circuit 116 stores information relating to one or more metering values in the memory 112 as part of a data log or “load profile”. Each stored value is associated with a defined time interval. It will be appreciated that the processing device(s) of the circuit 116 that perform load profiling may or may not be or include the same processing device of the processing circuit 116 that forms a part of the metrology circuit 117.
In accordance with embodiments of the present, the memory 112 is an EEPROM memory divided into physical blocks. Referring now to
Referring now to the embodiment of
In
It can be seen from the above table that each range of uncompressed values includes in this embodiment a negative side and a positive side, to allow negative numbers to be logged as well. In general, each prefix 206x defines which range (i.e. which row in the table) is applicable, and the suffix 208x represents a numerical or sequential position of the corresponding uncompressed value within the range. So for example, consider a value 204a compressed as 10100000001111. This value splits into a prefix 206a of 101000, and a suffix 208a of 00001111. From the above table, the prefix 206a of 101000 identifies that the value is in the range of −256 to −129 and 129 to 256. The first bit of the value “00001111”, which is 0, indicates that the value is in the positive half-range: 129 to 256. The binary value 0001111 corresponds to 15, which indicates that the value is the fifteenth in sequence in the range of 129 to 256. Because 129+15=144, the decompressed value is 144. In other words, the compressed value of 10100000001111 equates to 144. It will be appreciated that although the decompressed value could be any 32-bit value, this particular value has been compressed to 14 bits.
It will be appreciated that information representative of the Table 1, or at least the portion thereof related to the prefixes and the corresponding ranges of values, may be stored in a memory that is different than the memory 112, for example, the memory 113 or some other memory. In this way, the compressed load profile data may be stored separately from operating data of the meter 10.
Referring again to
Referring again specifically to
In operation, the processing circuit 116 performs normal metering operations to obtain various metering values, such as watt-hours (real energy), VA-hrs (apparent energy), and VAR-hrs (reactive energy), current, voltage, as well as other values. At specific intervals, for example, the processing circuit 116 compresses and stores information relating to those meter values in the memory 112. In this embodiment, the processing circuit 116 stores a compressed version of an actual metering value, such as watt-hrs consumed in the last interval, or overall, as the first value 204a for the first interval after the time stamp 212a. For subsequent time intervals (until the block 210a is full), the processing circuit 116 compresses and stores the difference in the metering value from the last time interval. Thus, each block 210x starts with a time stamp value 212x, a first value 204a that is a compressed version of an absolute metering value, and a plurality subsequent values 204b, 204c, etc. that are compressed versions of a differential metering value.
In step 306, the processing circuit 116 obtains a time and date stamp and stores it in the first bit locations of a new block 210x of the memory 112. The processing circuit 116 then (step 308) performs a compression step on the metering value that is being “profiled” or logged. As discussed above, this value may be the watt-hrs consumed over the last time interval, VAR-hrs consumed over the last time interval, total watt-hrs, or other values. As will be discussed below, the data log may be divided into multiple channels so that several values may be logged, each value occupying a different, but consistent channel.
In any event, after step 308, the processing circuit 116 stores the compressed value (step 310) in the next memory locations in the memory 112. Thereafter, the processing circuit 116 resets NEW_BLOCK (step 312) and then returns to step 302 to await the next time interval.
Referring back to step 304, if it was determined that NEW_BLOCK is not set, then the processing circuit 116 determines the difference between the current metering value to be logged, and the previously logged metering value (step 314). Thus, in step 314, the processing circuit 116 determines a differential value for the metering value being logged or profiled. In step 316, the processing circuit 116 performs the compression operation on the determined differential value. The processing circuit 116 thereafter proceeds to step 318.
In step 318, the processing circuit 116 determines whether the current block 210x of the memory 112 has sufficient space for the compressed value generated in step 316. If so, then the processing circuit 116 stores the compressed value in the next memory locations of the current block 210x (step 320) and returns to step 302 to await the next time interval. If not, however, then the processing circuit 116 sets NEW_BLOCK=1 (step 322) and proceeds directly to step 304.
It will be appreciated that the above-operations may readily be adapted for multiple channels of data logging, as will be discussed below in connection with
It will further be appreciated that the compression steps 308, 316 both operate in the same manner on their respect values to be compressed. In step 308, the value to be compressed, CV, is the metering value. In step 316, the value CV is the determined differential value. In either case, the processing circuit 116 uses a look-up table or the like to determine the appropriate prefix 206 (e.g. from
Thus, several features of this embodiment are particularly useful in load profiling in electricity meters. In particular, the use of differential values for a large portion of the stored interval data combined with the significant compression of smaller values can result in substantial overall reduction in memory usage as compared to storing full 32-bit values for each new interval. It will be appreciated that the inventive compression scheme described herein may readily be adapted to other value sizes, such as 16-bit or 64-bit values, as well as others.
There are quasi unlimited ways to implement this principle. But the basic ideas are to: Extract the differences between slowly changing numbers; Encode them in bit patterns of smaller size for smaller values and bigger size for larger values (e.g. Table 1); and Place markers at regular intervals so that the bit stream hence created doesn't need to rely on the existence of data that is too old (e.g. the time and data stamps 212a, 212b, etc.). Thus, old data can be discarded and the bit stream can still be read. It will further be appreciated that the compression scheme is lossless, meaning that the decompressed data does not experience any loss of information from the original data that was compressed.
Referring to
Referring to
In the embodiment of
The compressed interval 505 then includes a sequential series of prefixes 612y and suffixes 614y for each of a plurality of channels, where y is the channel index. As discussed above, each “channel” corresponding to a specific metering value that is logged in every time interval. Each channel is compressed separately. To this end, each channel prefix 612y is generated in the same way as the prefix 206 of
Referring again to
Referring again to
Referring again to
Referring now to
In step 408, the processing circuit 116 obtains the metering values for the current interval. In this embodiment, multiple metering values, including a set of status values, are logged for each time interval. It will be appreciated that any number of channels may be logged in the memory 112, one channel per value. In this example, the values of watt-hours and amp-hours for the current interval are tracked, as well a set of status bits for the meter 10. Each of these values is a 32-bit value in uncompressed format. Status codes can include flags indicating whether there has been a power outage in the interval, whether there has been a clock change or tampering event during the interval, etc.
The processing circuit 116 then, in step 410, determines the difference between the metering values for the current interval, and same metering values from the prior interval. Thus, in step 410, the processing circuit 116 determines a differential value for the metering values being logged or profiled. Thus, in the example described herein, the processing circuit 116 would determine the difference between watt-hours consumed in the prior interval and the current interval, the difference between amp-hours consumed in the prior interval and the current interval, and the difference in status codes (numerical) between the prior interval and the current interval. This is done for each channel being profiled or logged.
In step 412, the processing circuit 116 performs the compression operation on each determined differential values separately, using the method described above in connection with
It will be appreciated that steps 410 and 412 are performed on a channel-by-channel basis.
In step 414, the compressed values are stored in the current physical data block, e.g. the data block 550. If the data block 550 overflows (after reserving space for the time stamp data 512 and the overflow length block 542), then the compressed data is stored to an overflow buffer.
After all of the channel data for the interval is stored in step 414, the processing circuit 116, in step 416, determines whether the data overflowed the current physical data block. As discussed above, the current physical data block overflows if the compressed interval data determined in steps 410, 412 exceeds the available bit-locations in the physical data block, while reserving a predetermined number of bits for the time stamp data 512 and the overflow length value 542. For example, at the end of the compressed interval 505n-1 of
If the processing circuit 116 determines in step 416 that no overflow has occurred, then the processing of the current interval is completed, and the process ends. If the processing circuit 116 determines instead that an overflow has occurred, then the processing circuit 116 proceeds to step 418 to process the end of the logical data block 510.
In step 418, the processing circuit 116 first generates an absolute data block 514 using the current interval metering values. Thus, after step 418, the processing circuit 116 has generated both the compressed interval (CIn) based on the current metering values and the prior interval metering values, and a compressed absolute data block 514 based on the current metering values. Thereafter, in step 420, the processing circuit 116 determines how many bits of the compressed interval and the absolute data block will be stored in the next physical data block (e.g. physical data block 552). For example, in the example of
Thereafter, in step 426, the processing circuit 116 writes overflow data (e.g. blocks 505nb and 514) to the next physical data block 552. The overflow data is written in the first (or last) bit-locations in the physical data block 552. Subsequent compressed intervals 505x from the next logical data block 510NEXT will be stored sequentially thereafter in the physical data block 552. In step 428, the processing circuit 116 sets NEW_BLOCK to 1 and then ends the processing of the current interval.
As discussed above, one advantage of the embodiment described herein is that the logical data block 510 (and hence physical data blocks 550, 552, etc.) are written in one direction, and read out in the opposite direction.
In the example of
At 9:05, the interval Intvl1 is complete (step 402). The processing circuit 116 determines that NEW_BLOCK=1 in step 404, and performs no further actions, other than to reset the NEW_BLOCK=0 (step 406).
At 9:10, the interval Intvl2 is complete (step 402). The processing circuit 116 determines that NEW_BLOCK=0 in step 404, proceeds to step 408. The processing circuit 116 obtains the metering values Status(Intv2), Metering 1(Intv2), and Metering 2(Intv2) for the interval Intvl2 (step 408). Such values, of course, may be maintained in an ongoing basis by the processing circuit 116 to the extent that the processing circuit 116 forms a part of the metrology circuit 117 of the meter 10 of
Status(δ)=Status(Intvl1)−Status(Intvl2)
Metering 1(δ)=Metering 1(Intvl1)−Metering 1(Intvl2)
Metering 2(δ)=Metering 2(Intvl1)−Metering 2(Intvl2).
The processing circuit 116 then performs compression operations on each of the differential values Status(δ), Metering 1(δ), and Metering 2(δ) to generate corresponding compressed values Status(CV), Metering 1(CV) and Metering 2(CV) (step 412). As per the compression algorithm discussed herein, each of the compressed values Status(CV), Metering 1(CV) and Metering 2(CV) may have a different bit-length, which is identified in the code portion (e.g. 612y, of
The processing circuit 116 stores the compressed values Status(CV), Metering 1(CV) and Metering 2(CV) as a compressed interval 5051 in bit-position sequence in the memory block 510. (Step 414). Referring to
After storing the compressed bit-stream portion C1, and assuming no overflow occurred (step 416), the processing circuit 116 awaits the next time interval, or until 9:15.
At 9:15, the interval Intvl3 is complete. (Step 402). The processing circuit 116 determines that NEW_BLOCK=0 in step 404, proceeds to step 408. The processing circuit 116 obtains the metering values Status(Intv3), Metering 1(Intv3), and Metering 2(Intv3) for the interval Intvl3 (step 408). The processing circuit 116 then determines the difference between each of the values Status(Intv3), Metering 1(Intvl3), Metering 2(Intvl3) and the respective values from the previous interval and Status(Intv2), Channel 1(Intv2), and Channel 2(Intv2) (step 410). In other words, the processing circuit 116 performs the following operations:
Status(δ)=Status(Intvl2)−Status(Intvl3)
Metering 1(δ)=Metering 1(Intvl2)−Metering 1(Intvl3)
Metering 2(δ)=Metering 2(Intvl2)−Metering 2(Intvl3).
The processing circuit 116 then performs compression operations on each of Status(6), Metering 1(δ), and Metering 2(δ) to generate corresponding compressed values Status(CV), Metering 1(CV) and Metering 2(CV). (Step 412). The processing circuit 116 stores the compressed values Status(CV), Metering 1(CV) and Metering 2(CV) in sequence in the memory block 510. (Step 414). In
After storing the compressed bit-stream portion C2, and assuming no overflow (step 416), the processing circuit 116 awaits the next time interval, or until 9:20.
The processing circuit 116 performs analogous operations at 9:20 (Intvl4) to store the next compressed differential values of Status, Metering 1, and Metering 2 as C3 in the memory location adjacent to that storing C2. The compressed interval C3 corresponds to the compressed interval 5053 of
At 9:25, the fifth interval Intvl5 is complete (step 402). The processing circuit 116 performs analogous operations at 9:20 to store the next compressed differential values of Status, Metering 1, and Metering 2 as C4 in the memory location adjacent to that storing C3. The compressed interval C4 corresponds to the compressed interval 5054 of
As a result, the processing circuit 116 then stores the absolute values Status(CAV), Metering 1(CAV), and Metering 2(CAV) in the block 510 after the value C4 as the value AC5. As discussed above, part of the interval values C4 and AC5 with the other part of C4 may be in adjacent physical memory blocks.
One of the advantages of the operations of
In general, the communication circuit 806 receives data, such as the load profile data from the memory 112, and provides the data to the processing circuit 802. The processing circuit 802 receives and decompresses the data, which may then be stored for processing by the processing circuit 802 or another processing circuit, not shown. The processing circuit 802 in some cases may simply store the compressed data 802 in the memory 804 when first received, and then perform the decompression operations at a subsequent time.
In step 902, the processing circuit 802 obtains the load profile or data log parameters for the compressed data received by the communication circuit 806 from the meter 10. Such parameters can include the number of channels (i.e. values per time interval), the length of each interval. In some cases, the parameters can include an identification of the compression scheme and possibly even the Table 1 information. It will be appreciated that in some embodiments, the parameters may be entered manually, or preprogrammed into the memory.
Once the parameters of the compressed data log are known, the processing circuit 802 then begins by starting the decompression of the next block to be decompressed (step 904). As mentioned above, the decompression operation takes place by reading out data for each block in the opposite order in which it was stored. Thus, with reference to
Accordingly, in step 906, the processing circuit 802 obtains the first bit of the data, which will include a code for the type of data that will be the following bits. The processing circuit 802 then performs different steps depending on the retrieved code. In this embodiment, if the first code bit is “1”, then the ensuing data will be a compressed interval 505. (See element 610 of
It will be appreciated that other four-digit codes may be used to signal and end of the block or the insertion of other types of data.
In the case of step 910 (TS data), the processing circuit 802 obtains the next P bits and processes the time stamp data 512 to obtain the time stamp value. As discussed above the time stamp value is compressed into the time stamp data 512 using other techniques, or a special look-up table. The number P is predetermined because the length of time stamps is relatively consistent. In this embodiment, the processing circuit 802 stores the time stamp value and associates it with immediately previously received uncompressed values. If no uncompressed values were previously received, then the processing circuit 802 uses the time stamp value to identify a power interruption or other malfunction, and fixes the log accordingly. The processing circuit 802 then returns to step 906.
In the case of step 912 (absolute value data), the processing circuit 802 obtains and decompresses the absolute value data block 514. To this end, the processing circuit 802 employs the operations of steps 908 and steps 914-922, discussed further below. The processing circuit 802 stores the uncompressed meter values and proceeds to step 928, also discussed below.
In the case of step 908 (compressed interval), the processing circuit 802 retrieves the next bit, which is the first bit of the compressed interval 510. The first bit is the first (or only) bit of the code value 6121 for the first channel of data. If the first bit is a 0, then the processing circuit 802 proceeds to step 914. In step 914, the processing circuit 914 determines the uncompressed value to be 0. As discussed above, a code value of “0” indicates that the compressed value is also zero, and therefore a separate compressed value is not present. (See, e.g. Channel 2 code 6122 of
If, however, the processing circuit 802 determines in step 908 that the first bit is not a 0, then the processing circuit 802 proceeds to step 916. In step 916, the processing circuit 802 obtains the next Q bits to obtain the full non-zero code value 612x. As can be seen from Table 1 above, the number Q is determinative of length. If the first five bits are 10000, 10001 or 10010, then the number Q is five bits. If any other combination occurs, then the number Q is six bits. The processing circuit 802 then proceeds to step 918. In step 918, the processing circuit 802 uses a look-up table in the memory 804 to identify the range of values for the associated compressed value 614x based on the code value 612x. For example, if the code value 612x is 101001, then the processing circuit 802 determines that the associated value range is the −512 to −257 and 257 to 512 (including sign bit).
Thereafter, in step 920, the processing circuit 802 obtains the next R bits, which constitute the compressed value 614x. The number of bits R is predetermined for the range of values identified by the code value 612x. To this end, the look-up table in the memory 804 also associates a number of bits for each code value 612x. In step 922, the processing circuit 802 uses the compressed value 614x to identify the corresponding number in the identified range from step 918. To this end, the first sign bit is identified, and then the remaining compressed value represents the numerical position of the value within the identified range. Thus, in the above example having a code value of 100110, the nine compressed value bits include a sign bit and eight value bits. In an example having a positive sign bit and remaining bits of 00000010, the processing circuit 802 would identify the corresponding uncompressed value of 257+(00000010) or 259. Once the decompressed value for the channel is identified, the processing circuit 802 proceeds to step 924.
In step 924, the processing circuit 802 first adds the uncompressed value to the stored, uncompressed absolute metering value from the prior interval. In other words, because the compressed values of a compressed interval 505x are differential, the uncompressed values must be added to the previously processed value, which are absolute values, to obtain the full uncompressed value for the present interval.
The processing circuit 802 stores the uncompressed absolute metering value for the current channel and current interval, which in turn will be used to recreate the uncompressed absolute metering value for the next interval. In addition, the processing circuit 802 stores the uncompressed value in a way that associates the uncompressed value with a corresponding time stamp. The corresponding time stamp is determined based on the previously stored interval time minus the interval time period. Thus, if the current interval is the next interval after the time stamp obtained in step 910, then the associated time is B minutes earlier than the time stamp obtained in step 910, where B is determined by the log parameters obtained in step 902. Otherwise, the current time stamp is just the previous time stamp identified from the last processed compressed interval 505, minus B minutes. Thus, because the data is read out from the block 510 in reverse, they are read out in reverse chronological order and the time stamps decremented for each new interval that is decompressed.
In step 926, the processing circuit 802 determines if additional channels are to be processed for the current interval. The processing circuit 802 determines this from the log parameters received in step 902. If so, then the processing circuit returns to step 908. If not, then the processing circuit 802 proceeds to step 928.
In step 928, the processing circuit 802 has completed decompressing the compressed interval. The processing circuit 802 then sets the “previous time stamp” equal to the current time stamp, and returns to step 906 to process the next bit.
In this manner, the processing circuit 802 stores in its memory 804 an uncompressed load profile. The uncompressed load profile data may have a standardized data format dictated by ANSI standards known in the art. The processing circuit 802 may then communicate the uncompressed data to another processor, not shown, for analysis. It will be appreciated that in some cases, the meter processing circuit 116 can be programmed to perform the steps of
It is known that the meter 10 can undergo a power failure from time-to-time, which can interrupt load profile log. It is necessary to identify or otherwise smoothly handle interruptions in the load profile log, particularly in systems such as the one identified above where the data stream of the load profile log has few time stamps.
In general, when the meter 10 undergoes a power failure, the processing circuit 116 stores the time of the power failure. When power is restored, the processing circuit 116 performs certain load profiling steps based on information on the power failure. (See, e.g.
When the compressed data of
In particular, since the load profile compressed data is read-out backwards, from the present to the past, the time of each interval being read back is determined by simply deducting the length of an interval from the time of the previous interval. In the case of a power outage, one or more intervals may not be recorded into the compressed data stream. Therefore, what is needed is the time of the end of the interval that will be read after processing the gap. Thus, when reading the compressed data stream of
It will be appreciated that the use of the “time stamp” interval illustrated in
However, the clock is not always lost in a power outage. As discussed above in connection with
With general reference to
In addition,
The operations of
Referring specifically to
Thereafter, in step 1425, the load profile operations determine if the current time (and date) are equal to or less than the end time determined in step 1420. For example, it is possible that the power outage only lasted a minute or two, and that power was restored prior to the end of the interval. Thus, if the current time (and date) are equal to or less than the end time determined in step 1420, the load profile operations may merely return to normal load profile operations awaiting the end of the current interval. In general, the normal load profile operations can be the operations of
If, however, the current time (and date) are not equal to or less than the end time determined in step 1420, then the load profile operations proceed to step 1430. In step 1430, the load profile operations determined if the current time (and date) are equal to or less than the end time of the next interval, i.e. a time that is an interval greater than the end time determined in step 1420. If so, then the load profile operations may suitably return to the normal operations of
If, however, in step 1430 is determined that the current time is more than a whole interval past the end of the interval in which the power went down, then the load profile operations proceed to step 1435. In step 1435, the load profile operations store in the compressed data stream (e.g. stream 1110 of
Thereafter in step 1440, the load profile operations determine whether the meter 10 was in “standby” when power was lost. As discussed above, standby is a state of the meter 10 in which the meter clock has been lost and the meter processor 116 operates from a temporary clock (e.g. starting at 00:00, Jan. 1, 2000 or some other past reference date and time) until an accurate time and date can be obtained. Upon the restoration of power, other functions of the meter processor 116 attempt to obtain the real-time clock. If the processing circuit 116 determines that the clock has been lost, then the processing circuit 116 starts the clock at the temporary reference time, and sets a flag or other indicator identifying that the meter 10 is in standby. If a subsequent power down occurs, this “standby” flag may suitably be stored in one of the memories 112, 113. If, however, the processing circuit 116 identifies that a valid clock still exists on power up, then it does not set the standby flag and it maintains the current, accurate real-time clock. In such a case, no standby flag is stored in the memories 112, or 113 if power is lost.
Accordingly, in step 1440, the load profile operations identify whether the standby flag maintained by other processes of the processing circuit 116 was stored when power was lost. If so, then the load profile operations proceeds to step 1445 to mark the time stamp generated in step 1435 as a standby time stamp. Such information may be used later if and when the meter 10 receives an accurate real time for the real time clock, as will be discussed further below. In any event, after step 1445, the load profile operations may return to the normal operations of
An example execution of the steps 1415 to 1435 may be understood with reference to
In step 1425, the processing circuit determines that the current time, 9:18, is not within the load profile interval that ends at 9:10. Thus, the processing circuit 116 proceeds to step 1430. In step 1430, the processing circuit 116 determines that the current time, 9:18, is not within the next load profile interval, which ends at 9:15. Accordingly, the processing circuit 116 in step 1435 records the time stamp 9:10 in the compressed data stream. In step 1440, the processing circuit 116 determines that the meter 10 was not in standby mode and resumes the load profile writing operations of
The operations of
However, as shown in the power signal 1115 of
Accordingly, when power is restored at 9:43, the processing circuit 116 stores the time stamp of 00:15 (i.e. the end of the interval including the power down time 00:12) in the compressed data stream 1110 (as per step 1435), but also determines in step 1440 that the meter 10 was in standby at the time of the power outage. Thus, the processing circuit 116 in step 1445 marks the time stamp 00:15 in the compressed data stream 1110 as a standby time stamp. The processing circuit 116 then resumes normal load profile operations as per
At a later point, during the normal operations of
It will be appreciated that when the real-time clock is restored, the intervals in standby time will not always align with the intervals in real-time. Accordingly, in at least some embodiments, the processing circuit 116 is configured to re-align the intervals after a reset of the real time clock. In general, there are basically three cases (from simpler to more complex) for when the meter 10 enters standby and then the clock is reset to the proper time:
1) The meter 10 enters standby and then, shortly after that, the proper time is recovered. In this case, all that is required is to re-synchronize intervals as best as possible, creating a long or short interval in the process. Through this process, a short interval should be no shorter than 0.5 times a normal interval and a long interval no longer than 1.5 times a normal interval. Thus, for example, if the reset of
2) The meter 10 enters standby and then, before the actual time and date is recovered, the meter 10 experiences one or more short power outage(s). When the time is set, the offset value is inserted in the bit-stream in such a way that the time stamp of any previous power outage can be adjusted to calculate the real time when the power outage happened. This allows for the data to be returned as if standby did not happen, when any recorder is read. This scenario is illustrated in
3) The meter 10 enters standby, but before actual time is recovered, the meter 10 experiences an event such as a long power outage that causes the meter to re-enter standby. In this case, the exact time for the recorded data is unknown, but that it is bound by older data and new data whose time is known. This data is labeled “unaligned”, and the user (i.e. the utility) has the choice to include or not include this data when reading any particular recorder.
The result of the operations of
Referring to
As discussed above, the load profile data in the packed stream 1110 is stored such that the deltas (see, e.g. step 410) between metering values of two intervals is encoded and recorded, which provides a smaller number that is easier to encode to a shorter bit pattern. However, the output of the reading algorithm must be absolute (actual) values for each interval. Because each sets of interval values (e.g. C1, C2, C5 of stream 1110) is representative of deltas of values between two intervals, the encoded bit pattern that represents a particular interval is always delayed by one interval before it shows up in the bit-stream. (See, e.g.
In step 1505, the readout process obtains the prefix (code) of the next data block (hereinafter referred to as the “current data block”) in the compressed data stream 1110. As discussed above in connection with
In step 1515, the readout process branches on the obtained prefix code of the current data block. If the prefix indicates an end-of-block (EOB), then the readout process proceeds to step 1518. If the prefix indicates a load profile value (LP), then the readout process proceeds to step 1520. If the prefix indicates an absolute value (ABS), then the readout process proceeds to step 1530. If the prefix indicates a time stamp (TS), then the readout process proceeds to step 1540. If the prefix value indicates an offset (OS), then the readout process proceeds to step 1560.
Accordingly, the readout process executes step 1518 if an end-of-block indicator is identified. In such a case, the readout process directly creates the ANSI end of block data segment and insert a time stamp in the ANSI data block (e.g. time stamp 1210 and end of block segment 1215 of ANSI block 1205 of
The readout process executes step 1520 if the prefix code identifies a load profile value, e.g. a compressed interval 505 discussed above in connection with
In any event, in step 1525, compressed interval values of the current data block are now processed. Specifically, the compressed differential values of the current data block are decompressed, as per steps 908-922 and 926 of
Referring again to step 1515, the readout process executes step 1530 if the prefix of the value obtained in step 1505 indicates an absolute value. In step 1530, the existing values in the LP buffer are provided to the data insertion process for final processing and insertion into the ANSI data block, and are subsequently cleared from the LP buffer. In step 1535, the absolute values of the data block are decompressed and then stored in the LP buffer. As discussed above, the absolute values are not differential, and thus are not added or subtracted from previous values. Thus, the LP buffer is cleared (in step 1530) before the absolute values in the suffix are added to the LP buffer (step 1535). The readout process thereafter proceeds to step 1605 of
If in step 1515 it is determined that a time stamp has been received in the suffix in step 1505, then in step 1540, the readout process determines if the time stamp is marked as a standby time stamp. As noted above, time stamps generated in “standby” mode are based on a temporary clock that is not accurate. If the time stamp is marked as a standby time stamp, then the readout process proceeds to step 1545. If not, then the readout process proceeds to step 1550.
In step 1545, a stored “offset” value from an offset buffer is added to the time-stamp. To this end, the compressed data stream 1110, which is read out in reverse chronological order, can include an offset value (e.g. 1112) generated by the load profile operations when the real time clock is recovered in standby operation. The offset value stored in the offset buffer represents the difference between the recovered real-time clock and the temporary clock that was used during standby. For example, referring to
Referring again generally to the operations of
If in step 1515 the detected prefix indicates that the current data block is an offset value (e.g. offset value block 1112 of
As discussed above,
If, however, the value received in step 1605 is a time stamp, then the data insertion function proceeds to step 1640 to process the time stamp. Referring to step 1640, the data insertion function determines, based on the time stamp and the internal tracking of the current interval, whether any intervals are missing. In particular, the data insertion function keeps track sequential of the end times of each successive interval as they are written to the ANSI block 1210. However, after a power outage, it is possible that the time stamp will not coincide with the expected time tracked by the processing circuit 116, due to the fact that the power outage lasted more than the time period of a load profile interval. For example, referring to
If there are intervals missing, then the data insertion function in step 1645 writes zero values to each ANSI block time interval segment corresponding to the missing intervals. Thus, in the example of
If in step 1640 it is determined that no intervals are missing, then the readout process executes step 1650. In step 1650, it is determined whether the time has been set backwards. In rare cases, the real time clock of a meter can be set backwards, sometimes for a period covering several intervals. This is illustrated in
Referring again to step 1610, if it is determined that the data insertion function has received load profile metering values (as opposed to a time stamp), then the data insertion function executes step 1615. In step 1615 the data insertion function determines whether the counter N>0. If so, then the data insertion function is in the process of merging intervals, and proceeds to step 1630. If not, then the data insertion function proceeds to step 1620.
In step 1620, the decompressed metering/LP values received from the operations of
In any event, in step 1622, the contents of the merge buffer are written to or stored in the next segment of the ANSI block 1210, and the merge buffer is cleared. As shown in
In step 1630, which occurs when the merge counter N is greater than 0, the data insertion function adds the decompressed LP values received from the operations of
The above-discussed operations thus show how a compression scheme similar to that described above in connection with
It will be appreciated that the above-described embodiments are merely illustrative, and that those of ordinary skill in the art may readily devise their own modifications and implementations that incorporate the principles of the present invention and fall within the spirit and scope thereof.
This application claims the benefit of U.S. provisional patent application Ser. No. 62/062,130, filed Oct. 9, 2014, which is incorporated herein by reference, and is a continuation-in-part of U.S. patent application Ser. No. 14/252,502, filed Apr. 14, 2014, which in turn claims the benefit of U.S. Provisional Patent Application No. 61/811,604, filed Apr. 12, 2013.
Number | Date | Country | |
---|---|---|---|
62062130 | Oct 2014 | US | |
61811604 | Apr 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14252502 | Apr 2014 | US |
Child | 14880170 | US |