Digital correlation

Information

  • Patent Application
  • 20040010529
  • Publication Number
    20040010529
  • Date Filed
    July 15, 2002
    22 years ago
  • Date Published
    January 15, 2004
    21 years ago
Abstract
A method for correlating an input signal to a signature is provided. The method compares an input stream with a signature element-by-element as the input stream is received. The method restarts the comparison using the first element of the signature when an element in the input stream does not match the compared element in the signature and declares correlation when consecutive elements in the input stream match corresponding elements of the entire signature.
Description


TECHNICAL FIELD

[0001] The present invention relates generally to the field of electronic circuits and, in particular, to digital correlation of a sampled input to a reference signature.



BACKGROUND

[0002] Electronic circuits perform many functions in a variety of applications and systems. Such systems and applications range from computers and communications systems to automobiles and control systems for other industrial machinery.


[0003] Electronic circuits typically receive one or more inputs and produce one or more outputs. The type of output is determined, at least in part, by the input signal and the function of the electronic circuit. For example, electronic circuits provide outputs that drive visual displays, control mechanical apparatus, drive other electronic circuits, store or manipulate data or provide other appropriate output functions or signals.


[0004] In some electronic systems, input signals are analyzed to determine whether the input signal matches one or more known patterns. When the input signal matches one of the patterns, the electronic circuit takes selected action. For example, in a wireless communication system, when an input stream matches a known synchronization pattern, the system begins processing data received over a wireless link. In computer systems, an input stream is often monitored for one or more known input patterns. When a known pattern is received, a selected screen is displayed on a monitor.


[0005] There are many techniques for matching or correlating a sampled input to a reference signature. Some techniques are based on vector subtraction or exclusive NOR. For example, consider a Boolean (base-2) reference signature S and input signal X, both of length N. Signals S and X are represented as follows:


[0006] S=[K0, K1, K2 . . . KN] and


[0007] X=[I(t), I(t−1), I(t−2), . . . , i(t−(N−1))].


[0008] S is considered correlated (matches) X when the two vectors are equal. A simple test for correlation is to subtract one vector from the other and declare correlation if the result equals zero. Another common hardware implementation is to perform the AND function of the exclusive NOR for corresponding vector elements. Similar approaches also apply to signals of any base-M type.


[0009] Unfortunately, these common techniques require a history of data to be maintained by the electronic circuit. This history is typically maintained via an array in software or a shift register in hardware. These techniques are adequate for systems with small signatures, S, and small bases, e.g., binary signals. Resource efficiency becomes an issue when large vectors are required to determine correlation. This is due, in part, to large quantities of memory, e.g., RAM, used to maintain the input signal history. Further, there is a linear relationship between processor bandwidth and vector size, e.g., N subtractions are performed every time the input is sampled. Thus, processor bandwidth requirements can become large with increasing vector size.


[0010] Therefore, there is a need in the art for more efficient techniques for correlating a sampled input stream to a reference signature.



SUMMARY

[0011] Embodiments of the present invention correlate an input stream to a signature without requiring storage of the input signal. This is accomplished by comparing the input signal element-by-element as received with the elements of the signature. If a string of the input signal does not match the signature, the process starts with the beginning of the signature. Further, when a string of the input signal does match the signature, the process also starts with the beginning of the signature and the next element of the input signal.


[0012] In one embodiment, a method for correlating an input signal to a signature is provided. The method compares an input stream with a signature element-by-element as the input stream is received. The method restarts the comparison using the next element in the input stream and the first element of the signature when an element in the input stream does not match the compared element in the signature and declares correlation when consecutive elements in the input stream match corresponding elements of the entire signature.







BRIEF DESCRIPTION OF THE DRAWINGS

[0013]
FIG. 1 is a block diagram of an embodiment of an electronic circuit with digital correlation according to the teachings of the present invention.


[0014]
FIG. 2 is a flow chart of one embodiment of a process for correlating an input signal to a selected signature according to the teachings of the present invention.







DETAILED DESCRIPTION

[0015] In the following detailed description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific illustrative embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical and electrical changes may be made without departing from the spirit and scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense.


[0016]
FIG. 1 is a block diagram of an embodiment of an electronic circuit, indicated generally at 100, that correlates and input signal to a signature according to the teachings of the present invention. In one embodiment, the input signal comprises a stream of bytes or characters, referred to generally as elements, that are received from a source, e.g., over a telecommunications link, from a user input device or other appropriate signal generation mechanism. Advantageously, electronic circuit 100 determines if a sequence of elements of the input signal correlates to all of the elements of the signature without requiring the storage of a history of the input signal.


[0017] Electronic circuit 100 includes microprocessor 102, memory 104 and input signal interface 108. Bus 106 provides an interface between each of microprocessor 102, memory 104 and input signal interface 108. In one embodiment, memory 104 includes random access memory (RAM) 110 and read only memory (ROM) 112. Other embodiments use any appropriate combination of memory types, including, but not limited to RAM (static or dynamic), ROM, electrically erasable programmable read only memory (EEPROM), electrically programmable read only memory (EPROM), flash memory and the like. In one embodiment, microprocessor 102 comprises a dedicated processor for performing the correlation. In other embodiments, microprocessor 102 performs additional functions for the electronic circuit. Further, in other embodiments, microprocessor 102 comprises a special purpose logic or control circuit with a limited set of functionality.


[0018] In one embodiment, electronic circuit 100 is incorporated into a computer for identifying one or more selected key combinations for initiating one or more selected actions, e.g., displaying selected data on a screen, initiating a program, etc. In other embodiments, electronic circuit 100 is incorporated in other systems such as telecommunications systems and the like to identify when expected input patterns are received so that appropriate action can be taken.


[0019] In one embodiment, electronic circuit 100 uses a number of parameters to determine correlation between the input signal and the signature. For example, electronic circuit 100 uses an index, a signature and a signature length. In one embodiment, the signature is determined at compile time and is stored in ROM 112 as an array of elements, e.g., K0, K1, K2, . . . , and K(N−1) for an array of N elements. In other embodiments, the signature is stored in RAM 110. Further, the length N of the signature is also determined at compile time and stored in ROM 112. In other embodiments, the length N is stored in RAM 110. Finally, the index is maintained in RAM 110 during operation of the process. This index indicates the current level of correlation between the input signal and the signature because the index is related to how many of the signature elements have been matched to sequential elements in the input stream. The index is initialized to zero during power-up initialization.


[0020] In operation, electronic circuit 100 identifies correlation between any set of sequential elements in an input signal received at input signal interface 108 with a selected signature stored in memory 104. Initially, an element of the input signal is received at interface 108. Microprocessor 102 retrieves a next element of the signature from memory 104. Until a match is found with any element of the input stream, microprocessor 102 retrieves the first element of the signature. Once the first element has been matched, microprocessor 102 retrieves successive elements of the signature so long as each element matches successive elements of the input signal. If microprocessor 102 determines that any element of the input signal does not match the compared element of the signature, then the microprocessor returns to the first element of the signature. This allows the signature to be matched without maintaining any history of the input signal in memory.


[0021] In one embodiment, the retrieval and comparison of elements is accomplished using the index value. Elements of the signature are retrieved based on the current value of the index. The index begins at zero. On each match between an element of the input stream and a retrieved element of the signature, the index is incremented. The next element retrieved is retrieved from a memory location determined by a base address for the signature and an offset derived from the index. When the index is equal to the length of the signature, the signature has been matched with a sequential portion of the input signal.


[0022] In another embodiment, electronic circuit 100 uses the process of FIG. 2, described below, to determine correlation between an input signal and a signature.


[0023]
FIG. 2 is a flow chart of one embodiment of a process, indicated generally at 200, for correlating an input signal to a selected signature according to the teachings of the present invention. This process advantageously determines correlation between a received input signal and a signature on an element-by-element basis without maintaining a history of the received signal. As each element is received, it is compared to the next element of the signature. If there is a match, the process moves on to compare additional elements until the end of the signature is reached. If comparisons between successive elements of the input signal and the entire signature are successful, the method declares that this portion of the input signal correlates with the stored signature.


[0024] The process begins at block 202. At block 204, the process initializes one or more parameters used in the process. For example, in one embodiment, a signature of length N is used. In this embodiment, this signature is determined at compile time and is stored in ROM or RAM. Further, at compile time, the length of the signature is also determined and stored in ROM. In this embodiment, the process also initializes an index and stores it in memory. The index is used to selectively retrieve elements of the signature from memory during operation of the process. In other embodiments, other appropriate parameters are initialized for use in the process.


[0025] At block 206, the process receives the input signal. In one embodiment, the process receives a digital signal one element or character, e.g., one byte, at a time. Each element is processed in-turn as received and therefore it is not necessary to maintain a history of the received data. At block 208, the method compares the received element with the next element of the signature. In one embodiment, the next element of the signature is retrieved from memory based on a base address of the signature in memory and an offset based on the current value of the index. Unless the last element of the input matched its associated element of the signature, the index is zero and the received element is compared to the first element of the series. If the last element of the input signal matched an element of the signature, the index value is used to select the next element of the signature to compare to the received element.


[0026] At block 210, the method determines whether there is a match between the current element of the signature and the received element of the input signal. If not, the method proceeds to block 212 and resets to the beginning of the signature. In one embodiment, this includes resetting the index to zero. If there is no match, this means that the current string does not match the signature. The process proceeds to block 213 and compares the current element of the input stream with the first element of the signature. The process begins again with the next received element at block 206.


[0027] At block 210, if there is a match, the process next determines whether the end of the signature has been reached. In one embodiment, reaching the end of the signature is determined by comparing the index value to the stored length of the signature. If the index value is equal to the length of the signature, then the end of the signature has been reached. If the end of the signature has not been reached, the method returns to block 206 and processes the next received element because a sequence of received elements have been received and processed that match a first portion of the signature. Returning to block 206 allows the comparison to continue until all of the elements in the signature have been matched in sequence in the input signal. If at block 214, the method determines that the current element of the input signal matched the last element of the signature, e.g., the process has reached the end of the signature, and then the process proceeds to block 216 and declares correlation. The method ends at block 218.


[0028] In other embodiments, instructions are stored on a machine-readable medium for causing a machine to perform one or more of the processes described above. For purposes of this specification, “machine-readable medium” means a medium such as a disc, an optical disc, a dynamic or static random access memory device (DRAM, SRAM), read only memory (ROM), flash memory, electrically programmable read only memory (EPROM), electrically erasable programmable read only memory (EEPROM) or other appropriate medium for storing instructions to be read and executed by a microprocessor, a processor, an embedded processor or other appropriate logic device.


Claims
  • 1. A method for correlating an input signal to a signature, the method comprising: receiving an element of the input signal; comparing the element of the input signal to an element of the signature; when the element of the input signal matches the element of the signature, receiving and comparing a next element of the input signal to a next element of the signature; when the element of the input signal does not match the element of the signature, comparing the element of the input signal to the first element of the signature; and declaring correlation when the input signal sequentially matches all of the elements of the signature.
  • 2. The method of claim 1, wherein receiving an element comprises receiving a byte of data at an input signal interface.
  • 3. The method of claim 1, and further comprising determining the next element of the signature based on an index.
  • 4. The method of claim 3, and further comprising incrementing the index when the element of the input signal matches the element of the signature.
  • 5. The method of claim 3, and further determining when the input signal sequentially matches all of elements of the signature based on comparing the index with the size of the signature.
  • 6. A method for correlating an input signal to a signature, the method comprising: initializing an index value; sampling an input signal; comparing the current sample of the input signal to an element of a signature stored at a location offset by the index value from a signature base address; when a match is not detected, resetting the index value and returning to sampling the input signal; when a match is detected, incrementing the index; comparing the index to a selected length; when the index does not match the selected length, returning to sampling the input signal; and when the index does match the selected length, declaring correlation.
  • 7. The method of claim 6, wherein initializing the index value comprises setting the index value to zero.
  • 8. The method of claim 6, wherein sampling the input signal comprises receiving a byte of data from the input signal interface.
  • 9. The method of claim 6, wherein comparing the index to a selected length comprises comparing the index to a length of the signature.
  • 10. A method for correlating an input signal to a signature, the method comprising: comparing an input stream with a signature element-by-element as the input stream is received; restarting the comparison using the first element of the signature when an element in the input stream does not match the compared element in the signature; and declaring correlation when consecutive elements in the input stream match corresponding elements of the entire signature.
  • 11. The method of claim 10, wherein restarting the comparison comprises comparing the element in the input stream with the first element of the signature.
  • 12. The method of claim 10, and further comprising storing the signature, a signature length and an index value in memory prior to comparing the input stream with the signature.
  • 13. The method of claim 10, wherein comparing the input stream with the signature comprises: receiving an element of the input stream; and comparing the element of the input stream with an element of the signature selected based on an index.
  • 14. The method of claim 13, and further comprising: incrementing the index when an element of the input stream matches the selected element of the signature; and resetting the index when an element of the input stream does not match the selected element of the signature.
  • 15. An electronic circuit, comprising: a processor; a memory for storing a signature; an input signal interface, adapted to receive an input signal; a bus, communicatively coupled to the processor, the memory and the input signal interface; and wherein the processor is adapted to compare elements of the input signal with elements of the signature, element-by-element as the elements are received to determine correlation between the input signal and the signature without storing the input signal.
  • 16. The electronic circuit of claim 15, wherein the memory further stores an index and a size of the signature.
  • 17. The electronic circuit of claim 15, wherein the processor compares an element of the input stream with the first element of the signature following a mismatch between the element of the signature and an element of the input signal.
  • 18. A machine-readable medium having instructions stored thereon for performing a method for correlating an input signal to a signature, the method comprising: receiving an element of the input signal; comparing the element of the input signal to an element of the signature; when the element of the input signal matches the element of the signature, receiving and comparing a next element of the input signal to a next element of the signature; when the element of the input signal does not match the element of the signature, comparing the element of the input signal to the first element of the signature; and declaring correlation when the input signal sequentially matches all of the elements of the signature.
  • 19. The machine-readable medium of claim 18, wherein receiving an element comprises receiving a byte of data at an input signal interface.
  • 20. The machine-readable medium of claim 18, and further comprising determining the next element of the signature based on an index.
  • 21. The machine-readable medium of claim 20, and further comprising incrementing the index when the element of the input signal matches the element of the signature.
  • 22. The machine-readable medium of claim 20, and further determining when the input signal sequentially matches all of elements of the signature based on comparing the index with the size of the signature.
  • 23. A machine-readable medium having instructions stored thereon for performing a method for correlating an input signal to a signature, the method comprising: initializing an index value; sampling an input signal; comparing the current sample of the input signal to an element of a signature stored at a location offset by the index value from a signature base address; when a match is not detected, resetting the index value and returning to sampling the input signal; when a match is detected, incrementing the index; comparing the index to a selected length; when the index does not match the selected length, returning to sampling the input signal; and when the index does match the selected length, declaring correlation.
  • 24. The machine-readable of claim 23, wherein initializing the index value comprises setting the index value to zero.
  • 25. The machine-readable of claim 23, wherein sampling the input signal comprises receiving a byte of data from the input signal interface.
  • 26. The machine-readable of claim 23, wherein comparing the index to a selected length comprises comparing the index to a length of the signature.
  • 27. A machine-readable medium having instructions stored thereon for performing a method for correlating an input signal to a signature, the method comprising: comparing an input stream with a signature element-by-element as the input stream is received; restarting the comparison using the first element of the signature when an element in the input stream does not match the compared element in the signature; and declaring correlation when consecutive elements in the input stream match corresponding elements of the entire signature.
  • 28. The machine-readable of claim 27, wherein restarting the comparison comprises comparing the element in the input stream with the first element of the signature.
  • 29. The machine-readable of claim 27, and further comprising storing the signature, a signature length and an index value in memory prior to comparing the input stream with the signature.
  • 30. The machine-readable of claim 27, wherein comparing the input stream with the signature comprises: receiving an element of the input stream; and comparing the element of the input stream with an element of the signature selected based on an index.
  • 31. An electronic circuit, comprising: a processor; a memory for storing a signature; an input signal interface, adapted to receive an input signal; a bus, communicatively coupled to the processor, the memory and the input signal interface; wherein the processor is adapted to compare elements of the input signal with elements of the signature, element-by-element as the elements are received to determine correlation between the input signal and the signature without storing the input signal; and wherein the processor is further adapted to restart with the first element of the signature when either the full signature is matched or an element of the input signal does not match a compared element of the signature.