A spectrum analysis engine (SAGE) that comprises a spectrum analyzer component, a signal detector component, a universal signal synchronizer component and a snapshot buffer component. The spectrum analyzer component generates data representing a real-time spectrogram of a bandwidth of radio frequency (RF) spectrum. The signal detector detects signal pulses in the frequency band and outputs pulse event information entries output, which include the start time, duration, power, center frequency and bandwidth of each detected pulse. The signal detector also provides pulse trigger outputs which may be used to enable/disable the collection of information by the spectrum analyzer and the snapshot buffer components. The snapshot buffer collects a set of raw digital signal samples useful for signal classification and other purposes. The universal signal synchronizer synchronizes to periodic signal sources, useful for instituting schemes to avoid interference with those signals.
|
24. A method for detecting signal pulses comprising steps of:
a. detecting one or more peaks in spectral information representing activity in a frequency band; and b. detecting signal pulses that meet one or more characteristics from the detected one or more peaks, wherein the step of detecting a signal pulse comprises examining, for each detected peak, one or more of a bandwidth, center frequency and duration and determining whether it is within a corresponding range to determine whether it is a signal pulse that satisfies the one or more characteristics.
31. A processor readable medium encoded with instructions that, when executed by a processor, cause the processor to perform steps of:
a. detecting one or more peaks in spectral information representing activity in a frequency band; and b. detecting signal pulses that meet one or more characteristics from the detected one or more peaks by examining, for each detected peak, one or more of a bandwidth, center frequency and duration and determining whether it is within ranges of those parameters to determine it is a signal pulse that satisfies the one or more characteristics.
87. A signal detector circuit comprising:
a. a peak detector that receives as input spectral information for successive time intervals of activity in a frequency band, detects one or more peaks in the spectral information and outputs information identifying peaks for each time interval; and b. a plurality of pulse detectors each coupled to receive as input the output of the peak detector, wherein each pulse detector detects signal pulses that satisfy one or more characteristics based on the output of the peak detector, wherein at least one of the pulse detectors outputs a trigger signal in response to detecting a certain type of pulse.
67. A method for detecting radio signals in a frequency band comprising steps of:
a. operating a radio receiver in a wideband mode so as to generate a downconverted signal representing activity in the entire frequency band; b. performing spectral analysis on the downconverted signal to generate spectral information of the frequency band; and c. detecting signal pulses of signals expected to be present in the frequency band from the downconverted signal by examining, from the spectral information, one or more of a bandwidth, center frequency and duration of peaks in the spectral information and determining whether it is within a corresponding range of one or more of those parameters.
1. A signal detector circuit comprising:
a. a peak detector that receives as input spectral information for successive time intervals of activity in a frequency band, detects one or more peaks in the spectral information and outputs information identifying peaks for each time interval; and b. at least one pulse detector coupled to the peak detector, the pulse detector detects signal pulses that satisfy one or more characteristics based on the output of the peak detector, wherein the pulse detector examines, for each detected peak, one or more of a bandwidth, center frequency and duration and determines whether it is within a corresponding range to determine whether it is a signal pulse that satisfies the one or more characteristics.
69. A processor readable medium encoded with instructions that, when executed by a processor, cause the processor to perform steps of:
a. computing Fast Fourier Transform (FFT) values for each of a plurality of frequency bins from a digital signal representing activity in a frequency band for a time interval; b. computing the power at each frequency bin from the FFT values; c. detecting one or more peaks from the FFT values; and d. detecting signal pulses that meet one or more characteristics from the detected one or more peaks; e. comparing the occurrence of the pulse with a local clock signal; f. determining a phase error between the occurrence of the pulse and a state of the local clock signal; and g. delaying or advancing the local clock signal by an amount corresponding to the phase error.
68. A processor readable medium encoded with instructions that, when executed by a processor, cause the processor to perform steps of:
a. computing Fast Fourier Transform (FFT) values for each of a plurality of frequency bins from a digital signal representing activity in a frequency band for a time interval; b. computing the power at each frequency bin from the FFT values; c. detecting one or more peaks from the FFT values; and d. detecting signal pulses that meet one or more characteristics from the detected one or more peaks; e. computing one or more of a running sum of the power at each frequency bin over time intervals, a duty count comprising a running sum at each time interval of the number of times the power at each frequency bin exceeds a power threshold, a maximum power for each frequency bin for the current and prior time intervals, and a running count of the number of time intervals in which a certain number of peaks have been detected.
50. A processor readable medium encoded with instructions that, when executed by a processor, cause the processor to perform steps of:
a. computing Fast Fourier Transform (FFT) values at a plurality of frequency bins from a digital signal representing activity in a frequency band during a time interval; b. computing the power at each frequency bin; c. adding the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to obtain a running sum of the power at each frequency bin; d. comparing the power at each frequency bin with a power threshold to obtain a duty count of the number of times that the power at each frequency bin exceeds the power threshold over time intervals; and e. comparing the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to track the maximum power in each frequency bin over time intervals.
45. In a radio device that operates in a frequency band, a method for analyzing activity in the frequency band based on signals received by the radio device, comprising steps of:
a. computing Fast Fourier Transform (FFT) values at a plurality of frequency bins from a digital signal representing activity in a frequency band during a time interval; b. computing the power at each frequency bin; c. adding the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to obtain a running sum of the power at each frequency bin; d. comparing the power at each frequency bin with a power threshold to obtain a duty count of the number of times that the power at each frequency bin exceeds the power threshold over time intervals; and e. comparing the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to track the maximum power in each frequency binover time intervals.
36. A system for synchronizing to a communication signal, comprising:
a. a clock module comprising: i. at least N registers, each of which stores a programmable duration value associated with one of two states of a pulse of the communication signal, where N is equal to 2 times the number of pulses in a cycle of the communication signal; ii. a down counter driven by a clock signal that counts down with each clock pulse from a value corresponding to the content of one of the N registers; iii. a mod(N) counter coupled to the down counter that counts up to N-1 by one in response to the down counter reaching zero and when reaching N-1, causing content of the next of the N registers to be loaded into the down counter; b. a pulse detector circuit that detects a signal pulse in the communication signal; and c. a processor coupled to the clock module and to the signal detector circuit, wherein the processor examines the count values of the down counter and the mod(N) counter to measure a phase error between the clock signal used to drive the down counter and the pulse of the communication signal.
93. A system comprising:
a. a Fast Fourier Transform (FFT) block that receives as input a digital signal representing activity in the frequency band and computes FFT values for a plurality of frequency bins for a time interval; and b. a power calculation block coupled to the FFT block that computes the power at each frequency bin at each time interval; c. a peak detector that receives as input an output of the power calculation block for successive time intervals of activity in a frequency band, detects one or more peaks in the spectral information and outputs information identifying peaks for each time interval; d. at least one pulse detector coupled to the peak detector, the pulse detector detects signal pulses that satisfy one or more characteristics based on the output of the peak detector; and e. a memory that stores one or more of a running sum of the power at each frequency bin over time intervals; a duty count comprising a running sum at each time interval of the number of times the power at each frequency bin exceeds the power threshold; a maximum power for each frequency bin for the current and prior time intervals; and a running count of the number of time intervals in which a certain number of peaks have been detected.
51. A spectrum analysis device for use in a radio device that operates in a frequency band, comprising:
a. a Fast Fourier Transform (FFT) block that receives as input a digital signal representing activity in the frequency band for a time interval, wherein the FFT block computes FFT values for each of a plurality of frequency bins from the digital signal; b. a power calculation block that computes the power at each frequency bin and outputs a power data field comprising power values for the plurality of frequency bins; c. a signal detector circuit comprising: i. a peak detector that receives as input the power data field for successive time intervals of activity in a frequency band, and detects one or more peaks in the spectral information, the peak detector outputting information identifying peaks for each time interval; and ii. at least one pulse detector coupled to the peak detector that detects signal pulses that satisfy characteristics based on the output of the peak detector; d. a memory that stores one or more of: a running sum of the power at each frequency bin over time intervals; a duty count comprising a running sum at each time interval of the number of times the power at each frequency bin exceeds the power threshold; a maximum power for each frequency bin for the current and prior time intervals; and a running count of the number of time intervals in which a certain number of peaks have been detected.
2. The signal detector circuit of
3. The signal detector circuit of
4. The signal detector circuit of
5. The signal detector circuit of
6. The signal detector circuit of
7. The signal detector circuit of
8. The signal detector circuit of
9. The signal detector circuit of
10. The signal detector circuit of
11. The signal detector circuit of
12. The signal detector circuit of
13. The signal detector circuit of
14. The signal detector circuit of
15. A system comprising the signal detector circuit of
16. The system of
17. The system of
18. The system of
19. The system of
20. A system comprising the signal detector circuit of
21. The system of
a. a running sum of the power at each frequency bin over time intervals; b. a duty count comprising a running sum at each time interval of the number of times the power at each frequency bin exceeds the power threshold; c. a maximum power for each frequency bin for the current and prior time intervals; and d. a running count of the number of time intervals in which a certain number of peaks have been detected.
22. The system of
23. The system of
25. The method of
26. The method of
27. The method of
28. The method of
29. The method of
30. The method of
32. The processor readable medium of
33. The processor readable medium of
34. The processor readable medium of
35. The processor readable medium of
37. The system of
38. The system of
39. The system of
40. The system of
41. The system of
42. The system of
43. The system of
44. The system of
46. The method of
47. The method of
48. The method of
49. The method of
52. A radio device comprising the spectrum analysis device of
a. a radio frequency (RF) receiver that downconverts a received radio frequency signal and outputs a baseband signal; and b. an analog-to-digital converter that converts the baseband signal to the digital signal representing activity in the frequency for time intervals.
53. The radio device of
54. In combination, the radio device of
55. The combination of
56. A system comprising the spectrum analysis device of
57. The system of
58. A system comprising the spectrum analysis device of
a. a clock module comprising: i. at least N registers, each of which stores a programmable duration value associated with one of two states of a pulse of the communication signal, where N is equal to 2 times the number of pulses in a cycle of the communication signal; ii. a down counter driven by a clock signal that counts down with each clock pulse from a value corresponding to the content of one of the N registers; iii. a mod(N) counter coupled to the down counter that counts up to N-1 by one in response to the down counter reaching zero and when reaching N-1, causing content of the next of the N registers to be loaded into the down counter; b. a processor coupled to the clock module and to the signal detector circuit, wherein the processor examines the count values of the down counter and the mod(N) counter to measure a phase error between a clock signal used to drive the down counter and the pulse of the communication signal.
59. The system of
60. The system of
61. The system of
62. The system of
63. The system of
64. The system of
65. The system of
66. The system of
70. The processor readable medium of
71. The processor readable medium of
72. The signal detector circuit of
73. The method of
74. The processor readable medium of
75. The signal detector circuit of
76. The device of
77. The device of
79. The device of
80. The device of
81. The combination of
82. The method of
83. The method of
84. The method of
85. The method of
86. The processor readable medium of
88. A system comprising the signal detector circuit of
89. The system of
90. The system of
91. The system of
92. The system of
94. The system of
95. The system of
96. The system of
97. The system of
98. The system of
99. The system of
100. The system of
|
This application claims priority to the following U.S. Provisional Patent Applications, all of which are incorporated herein by reference:
U.S. Application No. 60/374,365, filed Apr. 22, 2002.
U.S. Application No. 60/380,890, filed May 16, 2002.
U.S. Application No. 60/319,435, filed Jul. 30, 2002.
U.S. Application No. 60/319,542, filed Sep. 11, 2002.
This application is related to each of the following commonly assigned U.S. Non-Provisional Applications, filed on even date (the entirety of both of which is incorporated herein by reference):
U.S. application Ser. No. 10/246,364, entitled "System and Method for Classification of Unknown Signals in a Frequency Band."
U.S. application Ser. No. 10/246,363, entitled "System and Method for Spectrum Management of a Shared Frequency Band."
The present invention is directed to technology used in a radio communication device to derive information about the signals active in a radio frequency band where the radio communication device is operating, such as an unlicensed radio frequency band shared by many different devices.
In certain radio communication systems, it would be desirable to know whether and what types of other signals or devices are active. For example, an unlicensed radio frequency band is, by its nature, free to be used by any device that emits radiowave energy within certain power levels in that part of the allocated spectrum. It is possible that many devices would share the unlicensed frequency band at the same time, potentially causing interference with each other. Under these circumstances, what would be useful is to provide the capability of processing signals that represent activity in the frequency spectrum over a time interval to derive information about the basic characteristics of those signals in order to identify or classify them.
A real-time spectrum analysis engine (SAGE) is provided that generates information about the signal activity in a frequency band. The SAGE has several components to produce generalized spectrum information as well as specific information concerning the type of signal pulses in the frequency band at any given time.
The SAGE is, for example, a hardware accelerator that resides in a communication device and comprises a spectrum analyzer component, a signal detector component, a universal signal synchronizer component and a snapshot buffer component. The spectrum analyzer component generates data representing a real-time spectrogram of a bandwidth of radio frequency (RF) spectrum. The signal detector detects signal pulses in the frequency band and outputs pulse event information entries which include the start time, duration, power, center frequency and bandwidth of each detected pulse. The signal detector also provides pulse trigger outputs which may be used to enable/disable the collection of information by the spectrum analyzer and the snapshot buffer components. The snapshot buffer collects a set of raw digital signal samples useful for signal classification and other purposes. The universal signal synchronizer synchronizes to periodic signal sources, useful for instituting schemes to avoid interference with those signals. Some or al of the functions of the SAGE may be implemented entirely in software executed by a processor.
The above and other objects and advantages will become readily apparent when reference is made to the following description taken in conjunction with the accompanying drawings.
The spectrum analysis engine, hereinafter referred to as "SAGE" is a hardware accelerator useful to generate in real-time information about the activity in a frequency band.
The SAGE 10 comprises a spectrum analyzer (SA) 100, a signal detector (SD) 200, a snapshot buffer (SB) 300 and a universal signal synchronizer (USS) 400. The SA 100 generates data representing a real-time spectrogram of a bandwidth of radio frequency (RF) spectrum, such as, for example, up to 100 MHz. As such, the SA 100 may be used to monitor all activity in a frequency band, for example, the 2.4-2.483 GHz ISM band, or the 5.15-5.35 GHz and 5.725-5.825 GHz UNII bands. Power vs. frequency information generated by SAGE 10 is stored in a dual-port RAM (DPR) 500 and is also used by the signal detector 200.
The signal detector 200 detects signal pulses in the frequency band and outputs pulse event information entries, which include one or more of the start time, duration, power, center frequency and bandwidth of each detected pulse. The signal detector 200 also provides pulse trigger outputs which may be used to enable/disable the collection of information by the spectrum analyzer 100 and the snapshot buffer 300 components.
The snapshot buffer 300 collects a set of raw digital signal samples useful for signal classification and other purposes, such as time of arrival location measurements. The snapshot buffer 300 can be triggered to begin sample collection from either the signal detector 200 or from an external trigger source using the snapshot trigger signal SB_TRIG.
The universal signal synchronizer 400 synchronizes to periodic signal sources, such as Bluetooth SCO headsets and cordless phones. The USS 400 interfaces with medium access control (MAC) logic 750 that manages scheduling of packet transmissions in the frequency band according to a MAC protocol, such as, for example, the IEEE 802.11 protocols. The MAC logic 750 may be implemented in DSP firmware, or in higher level software.
The SAGE 10 is useful in a radio communication device where a radio transceiver 600 (or a radio receiver) is used to process received RF signals and convert them to baseband signals. A microprocessor control unit (MCU) 700 interfaces with the SAGE 10 to receive spectrum information output by SAGE 10, and to control certain operational parameters of SAGE 10 for particular functions described in detail hereinafter. The MCU 700 may be any suitable microprocessor that resides either on the same semiconductor chip as the SAGE 10, or on another chip. The MCU interfaces with SAGE 10 through the DPR 500 and the control registers 560. The SAGE 10 interfaces with the MCU 700 through a memory interface (I/F) 550 that is coupled to the DPR 500.
The control registers 560 include registers to enable the MCU 700 to configure control and monitor the SAGE 10. There is a control/status register, an interrupt enable register, an interrupt flags register, spectrum analyzer control registers, signal detector control registers, snapshot buffer control registers and USS control registers. The control/status register includes a field to perform a reset of the SAGE components. The interrupt enable register is used to indicate one or more pending interrupt conditions to the MCU 700. The MCU 700 also uses the interrupt flags register to clear any processed interrupts.
Two clock signals are used to drive the SAGE 10. The main clock signal, CLK, runs at the sampling rate of the ADC 810 and controls most of the SAGE logic. The other clock, BUSCLK, is used to control the MCU side of DPR 500, interface to the control registers 560, the global timer interfaces (GFIs), and the lower medium access control (LMAC) interfaces. The DPR 500 is driven using a separate clock on each port: CLK on the SAGE side and BUSCLK on the MCU side. The control registers 560 may be double-buffered to avoid synchronization problems between SAGE and MCU control logic.
The SAGE 10 operates on digital signals derived from the baseband signals output by the radio transceiver 600. An RF interface 800 is provided that pre-processes the baseband signals for processing by the SAGE 10.
Turning to
The radio transceiver 600 that generates the received (Rx) baseband signals may have an RF receiver in which the local oscillator (LO) for the quadrature downconverter is placed at the center of the band of interest. As such, DC, amplitude and phase offset compensation circuits are provided before the Fast Fourier Transform (FFT) to maximize LO and sideband suppression.
The Rx baseband signals are sampled at the CLK frequency using two ADCs, one for the in-phase signal (I), and another for the quadrature signal (Q). Only one ADC is shown in
The AGC block 820 dynamically adjusts the gain of the receiver to optimize the placement of the Rx signal within the dynamic range of the ADC 810. A slow, feedback-driven algorithm is useful, in which the Rx gain is adjusted to place the maximum signal level received in the last T seconds (nominally T=1 second) 6 dB below full-scale on the ADC 810. The use of a "slow" AGC algorithm is beneficial because it prevents the ADC 810 from saturating when sampling the entire frequency band of interest (wideband mode) whenever strong signals appear suddenly in the band, without requiring rapid adjustments in gain which can cause distortion and discontinuities in Rx signal pulses. The output of the AGC 820 is an AGCcomp signal, the use of which is described hereinafter.
The DC correction and amplitude/phase correction blocks 830 and 840, respectively, compensate for LO leakage and amplitude/phase imbalance in the quadrature mixer of the radio transceiver. DC correction is performed adaptively by estimating the DC offset at the ADC output and updating a correction DAC to remove large DC offsets. Any residual DC offset after course correction is removed after the ADC via digital subtraction. The MCU estimates the amplitude and phase imbalance and programs the correction values into the appropriate control registers.
The output of the RF interface 800 comprises a digital signal Datal representing the in-phase received signal and a digital signal DataQ representing the quadrature phase received signal. The signals DataI' and DataQ' represent the output of the summer 835, uncorrected for DC and amplitude/phase, and can be supplied as the raw data to the snapshot buffer 300.
The SAGE 10 can be used in a radio communication device that includes a RF receiver capable of operating in a wideband mode or narrowband mode. In a wideband mode, the RF receiver may downconvert an entire or a substantial portion of a frequency band in which the radio communication device operates. In the wideband mode, the RF interface 800 supplies digital signals representing activity in the entire frequency band for successive time intervals as input to the SAGE 10. In a narrowband mode, the RF receiver may downconvert only a single RF channel or portion of the frequency band, in which case, the RF interface 800 would supply digital signals representing activity in that single RF channel or portion of the frequency band. An example of a radio receiver having a wideband mode as part of a radio transceiver is disclosed in commonly assigned U.S. Provisional Application No. 60/319,434 filed Jul. 30, 2002, the entirety of which is incorporated herein by reference.
Turning to
The Spectrum Analyzer
With reference to
The spectrum analyzer 100 comprises a windowing block 110, a Fast Fourier Transform (FFT) block 120, a power calculation block 130, a lowpass filter block 140, a linear-to-log converter (dB conversion) block 150, a history buffer 160, stats logic 170 and a spectrum analyzer memory controller 190.
As shown in
The output of the windowing block 110 is coupled to the input of the FFT block 120. The FFT block 120 is, for example, a 256 frequency bin FFT block that provides (I and Q) FFT data for each of 256 frequency bins that span the bandwidth of frequency band of interest. An example of the FFT data field is shown in FIG. 5. For each FFT sampling time interval, the FFT block outputs M (such as 10) bits of data for each FFT frequency bin, for example, 256 bins. Thus, it can be seen that two-dimensional data structure can be defined for the FFT data fields across time intervals. This diagram is a useful paradigm to understand the further operations that are performed on the FFT data.
The output of the FFT block 120 is coupled to the power calculation block 130. The power calculation block 130 comprises two multipliers 132 and 134 and an adder 136. The multipliers 132 and 134 compute (FFTdataI)2 and (FFTdataQ)2, respectively, and the adder 136 adds them together, to output a power value.
The lowpass filter block 140 comprises a multiplier 142, multiplier 144, an adder 145, a flip-flop 146 and a history RAM 148. The lowpass filter block 140 performs a unity-gain, single-pole lowpass filtering operation on the power values of the signal at each FFT frequency bin. Using Pfft(k) to denote the power value at FFT frequency f(k), the lowpass filter output Plpf(k) is updated once per FFT interval (t) as follows: Plpf(k, t) :=α1P(k, t)+(1-α1)Plpf(k, t-1), 1≦k≦256, where α1 and (1-α1) are parameters for the multipliers 142 and 144, respectively specifying the LPF bandwidth which is configured by the MCU 700. The history RAM 148 stores the FFT power data for the previous FFT interval that is used with multiplier 144 according to the mathematical relationship described above.
The dB conversion block 150 at the output of the lowpass filter block 140 computes the decibel value PDB(k)=10*log(|Plpf(k, t)|) for each FFT bin value Plpf(k, t) (in dBFS, i.e., dB from full-scale on the ADC). The ROM 152 stores a table used for the dB conversion computation and the adder 152 subtracts the gain compensation AGCcomp output by the AGC 820. The output of the dB conversion block is a PDB(k) data field (k=number of frequency bins) containing dB power data at each frequency bin and a PDBSTART signal that indicates the start of the following PDB(k) field.
The stats logic block 170 will be described hereinafter in conjunction with FIG. 10.
The spectrum analyzer 100 has two operating modes for writing data into the DPR 500. In a continuous mode, one power vs. frequency value is written to the DPR 500 every N FFT cycles (N=decimation factor). In a transitional mode, a power vs. frequency value is written whenever a pulse event is detected by the signal detector 200, in response to a spectrum analyzer trigger event signal SD_SAEVT, described hereinafter. The transitional mode generally improves DPR storage efficiency over the continuous mode since in the former case power vs. frequency information is written to the DPR only after pulse transitions.
Examples of control registers for the spectrum analyzer include a control field, a register for the lowpass filter parameter α, registers for the DPR address of the DPR buffers that store the spectrum analyzer stats, a register that counts the number of times the stats have been updated, a register that stores a value that determines the number of FFT intervals for a statistic update cycle, a register that stores the power threshold value for the duty cycle stats (described hereinafter), and a register for the structure for the power vs. frequency circular list.
The spectrum analyzer control register includes fields to, among other things, indicate received signal strength indicator (RSSI) mode, absolute or relative. The relative mode means that power measurements are in units of dB full scale; absolute mode means the measurements are in units of dBm. In addition, there is a field to indicate the operational mode of the spectrum analyzer, continuous mode or transitional mode.
The Signal Detector
With reference to
As shown in
The peak detector 210 detects a peak as a set of FFT points in contiguous FFT frequency bins, each above a configured minimum power level. Once per FFT interval, the peak detector 210 outputs data describing those frequency bins that had a FFT value above a peak threshold and which frequency bin of a contiguous set of frequency bins has a maximum value for that set. In addition, the peak detector 210 passes the PDB(k) data field for each FFT interval. This can be represented by the pseudo code (where k is the frequency bin index):
PDBdiff(k)= PDB(k) - SD_PEAKTH; | |
If(PDBdiff(k) ≧ 0) | |
PDBpeak(k)= PDB(k); | |
PEAKEN(k)= 1; | |
Else | |
PDBpeak(k)= 0; | |
PEAKEN(k)= 0; | |
end | |
The peak detector 210, as shown in
The signal detector 200 has one or more pulse detectors 220 (such as 4), allowing several pulses to be detected and characterized simultaneously. As shown in
Pulse Shaping Rules: How should pulse information be extracted from raw peak information--performed by the pulse identifier 230.
Pulse Detection Rules: Under what conditions is the start of a pulse detected--performed by the pulse finder 250.
Pulse Termination Rules: Under what conditions should an individual pulse be considered complete--performed by the pulse tracker 270.
Pulse Shaping Rules.
For a detected FFT peak at frequency index k0, the bandwidth of the peak is defined as FPBW=Bandwidth (Hz)=(kh-kl+1)*fs/NFFT, where kl and kh are the smallest and largest integers, respectively, satisfying (1) kl≦k0≦kh, and (2) P(k)≧P(k0)-BW_THRESH for any kl≦k≦kh, where fs is the ADC sampling rate in Hz, NFFT is the number of points/bins in the FFT, and P(k) denotes the power (in milliwatts) at FFT frequency bin k.
Similarly, the center frequency of the peak is FPCENTER=Center Frequency (Hz)=[(kh+kl)/2]*fs/NFFT. This definition of center frequency locates the signal in the Nyquist band only. The actual center frequency at RF is given by RF Center Frequency (Hz)=FPCenter-fs/2+fLO, where fLO is the RF LO frequency used to convert the FFT band to baseband, and a zero-IF receiver architecture is assumed (i.e., the LO is in the center of the RF band).
The peak detector 210 uses the following formula to estimate the power of a peak: Power (dBm)=ΣPDBpeak(k), from k=kl to kh. This is only an estimate and its accuracy depends on the signal itself and the value of BW_THRESH. The pulse identifier 230 shown in
Pulse Detection Rules. The pulse detection rules specify the conditions under which the start of a pulse is to be detected and these rules are performed by the pulse finder 250. For example, a pulse is considered DETECTED if there is a peak from the pulse shaping rules that satisfies ALL of the following conditions:
1) Estimated power is between the peak detector minimum power and the peak detector maximum power. The pulse power level DETECT_POWER which triggered the detection of this specific pulse is used by the pulse termination rules.
2) Center frequency of the peak is between a center frequency minimum and a center frequency maximum. The detected center frequency DETECT_CFREQ is used in pulse termination rules.
3) Bandwidth of the peak is within a bandwidth minimum and a bandwidth maximum.
Pulse Termination Rules. A pulse may be considered TERMINATED if, for example, the pulse duration exceeds a duration maximum, or NONE of the detected peaks from the peak detector satisfies ALL of the following conditions:
1) Estimated power of the peak is within +/- a power hold value of the power of the pulse when it was originally detected.
2) Center frequency of the peak is within +/- a frequency hold value of the center frequency of the peak when it was originally detected.
3) Bandwidth of the peak is within a bandwidth hold value of the bandwidth of the peak when it was originally detected.
The pulse tracker 270 comprises components to detect the termination of a pulse according to these rules.
When a pulse terminates, the pulse detector 220 writes a pulse event entry into the pulse event list if the pulse duration exceeds a pulse duration threshold value. Otherwise, the pulse event entry is discarded. The conditions which terminate the pulse are stored in a bit field which is included in the pulse event structure for the pulse. The pulse event structure will be described hereinafter.
Each pulse detector has its own configuration register (as part of the signal detector control registers) that stores values for each of the pulse parameters (described above) within which a pulse detector will process peak information. The following are examples of these parameters.
PWRMIN: Minimum power threshold (1 dBm)
PWRMAX: Maximum power threshold (1 dBm)
BWTHRESH: Bandwidth threshold (1 dBm)
CFREQMIN: Min center frequency (fs/NFFT Hz)
CFREQMAX: Max center frequency (fs/NFFT Hz)
BWMIN: Min pulse bandwidth (fs/NFFT Hz)
BWMAX: Max pulse bandwidth (fs/NFFT Hz)
DURMAX: Max pulse duration (TMR_PULSE)
DURMIN: Min pulse duration (TMR_PULSE)
PWRHOLD: Power hold value (1 dB)
FRQHOLD: Frequency hold value (fs/NFFT Hz)
BWHOLD: Bandwidth hold value (fs/NFFT Hz)
FPCENTER: Current pulse center frequency (fs/NFFT Hz)
FPBW: Current pulse bandwidth (fs/NFFT Hz)
PWR: Current pulse power estimate (1 dBm)
The terms fs and TMR_PULSE are described above and/or referenced in
Each pulse detector can be configured by the MCU 700. The MCU 700 writes appropriate values to the configuration register(s) of the signal detector to configure one or more pulse detectors to look for and characterize a certain type of pulse in the frequency band. The control register controls clearing and resetting of a pulse detector so that it can be reconfigured to look for a different type of pulse. The pulse detector control register includes a field that identifies which, if any, universal clock module of the universal signal synchronizer 400 is to be associated with the pulse detector. The universal clock module (UCM) is described hereinafter. When there is an association between the pulse detector and the universal clock module, the pulse detector stores the counter value of that universal clock module into the pulse event list whenever it detects a pulse. The counter values can be used by the MCU 700 to phase lock a universal clock module to a periodic interference source, as described hereinafter.
Each pulse detector outputs pulse event data for storage in the DPR 500. The following is an example of pulse event data.
SDID: Pulse detector identifier.
TERMCODE: Pulse termination codes:
Bit 0 (LSB): Pulse power outside of hold range
Bit 1: Center frequency outside of hold range
Bit 2: Bandwidth outside of hold range
Bit 3: Duration exceeds durMax
FCENTER: Center frequency (at beginning of pulse)
BW: Pulse bandwidth (at beginning of pulse)
DUR: Pulse duration in TMR_PULSE cycles. The pulse duration value is given by toff-ton, where toff and ton denote the TMR_TSTMP values latched at the FFT_START pulse associated with the first and last FFT of a detected pulse, respectively.
TIMEON: Timestamp for start of pulse event. TIMEON contains the TMR_TSTMP value latched at the FFT_START pulse associated with the first FFT that produces a pulse detection match.
UCMCNT: Counter values from an associated universal clock module (UCM, described hereinafter) in the USS. The low-order 16 bits contain the UCM down counter value at the beginning of the pulse event. The least-significant 2 bits in the upper half-word contain the mod(N) counter value (also in the associated UCM) at the beginning of the pulse event. If there is no associated UCM with a pulse detector, this field is set to all zeros.
PWR: Pulse power estimate (at beginning of pulse, 1 dBm)
The signal detector 200 outputs descriptions of detected pulses as pulse events, containing the data described in the table above for example, into a circular list called the pulse event list in the DPR 500. A single list is used by all of the pulse detectors. The source pulse detector of an individual pulse event in the list is indicated by the pulse event "SDID" field.
Two pulse detectors are configured in a device where it is expected that an 802.11b signal and a frequency hopping signal would occur. A first pulse detector is configured to detect signals, such as the 802.11 signals, and would have the following parameters:
Pulse Bandwidth: | 10 to 20 MHz |
Center Frequency: | 36-38 MHz (To cover channel 6-2437 MHz) |
Pulse Duration: | 70 microsec to 20 msec |
Power: | -30 dBm to -80 dBm |
It is possible that the first pulse detector could be configured to detect a pulse on any frequency, but through prior general knowledge that can be acquired by looking at the spectrum statistics, it is possible to determine that an 802.11 signal pulse is occurring at a particular frequency in the frequency band.
A second pulse detector is configured to detect signals such as the frequency hopping signal and would have, for example, the following parameters:
Pulse Bandwidth: | less than 2 MHz |
Center Frequency: | 0 to 83 Mhz (i.e., anywhere in the 2.4 GHz band) |
Pulse Duration: | Up to 1 msec |
Power: | -50 dBm to -75 dBm |
Exemplary pulse event data for these pulses are listed below. For simplicity, the time-on data associated with these pulses is omitted.
Pulse 1 | ||
SDID: | 1 (identifying pulse detector 1) | |
Pulse Bandwidth: | 11 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 1.1 msec | |
Power: | -75 dBm | |
Pulse 2 | ||
SDID: | 1 | |
Pulse Bandwidth: | 11 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 200 microsec | |
Power: | -60 dBm | |
Pulse 3 | ||
SDID: | 1 | |
Pulse Bandwidth: | 12 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 1.1 msec | |
Power: | -75 dBm | |
Pulse 4 | ||
SDID: | 1 | |
Pulse Bandwidth: | 11 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 200 microsec | |
Power: | -60 dBm | |
Pulse 5 | ||
SDID: | 1 | |
Pulse Bandwidth: | 13 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 18 msec | |
Power: | -75 dBm | |
Pulse 6 | ||
SDID: | 1 | |
Pulse Bandwidth: | 11 MHz | |
Center Frequency: | 37 MHz | |
Pulse Duration: | 200 microsec | |
Power: | -60 dBm | |
The pulse event data for pulses 7-14 are very similar to each other, with the exception of the center frequency. For example, pulses 7-14 may have a pulse bandwidth of 1 MHz, a pulse duration of 350 microsec, whereas the center frequency will vary across nearly all of the 2400 MHz to 2483 MHz frequency band. The SDID for pulses 7-14 is 2, since pulse detector 2 is configured to detect these types of pulses.
There are other signal detector functions. One or more pulse detectors in the signal detector 200 may be configured to monitor pulse activity and the signal detector 200 may send a snapshot buffer trigger signal (SD_SBEVT) to the snapshot buffer 300 when a pulse event occurs corresponding to a configured pulse detector. The signal detector will monitor all pulse detectors and if any one of them detects such an event, the snapshot trigger signal SD_SBEVT is generated, either on the rising edge or falling edge of the detected pulse. The snapshot buffer trigger signal SD_SBEVT will cause the snapshot buffer 300 to capture samples of the DataI and DataQ signals, as described hereinafter.
Similarly, the signal detector may be configured to monitor activity on each pulse detector and send a spectrum analyzer trigger signal (SD_SAEVT) to the spectrum analyzer 100 (presumed to be in the transitional mode) when a desired pulse event is detected by any one of the pulse detectors. Again, this spectrum analyzer trigger signal is generated either on the rising edge or falling edge of the detected pulse. The SD_SAEVT signal is coupled to the SA memory controller 190 which will output to the DPR 500 samples (snapshots) of the PDB(k) data fields.
Turning to
To accumulate power stats, the PDB(k) data field is supplied to the stats logic block 170. It may be decimated by an optional decimator 172. The power at each frequency bin for a previous time interval is added by the adder 174 to the power at that frequency bin for the current time interval. The running power sum at each frequency bin is output to the DPR 500 as a SumPwr stat.
A duty count stat is generated by comparing the PDB at each frequency bin k with a power threshold (SA_PWRTHRESH) at the adder 176 and MSB block 178. Each time the power at a frequency bin exceeds the power threshold, the previous duty count statistic for that frequency bin is incremented by the increment block 180. The output of the increment block 180 is the duty count stat (DutyCnt), which again, is a running count of the number of times the power at a FFT frequency exceeds the power threshold.
A maximum power stat (MaxPwr) is tracked at each frequency bin. The current maximum power value at each frequency k is compared to the new power value at each frequency k by the adder 182 and MSB block 183. The multiplexer 184 selects for output either the current power maximum or the new PDB(k), depending on whether the new PDB(k) exceeds the current power maximum at the frequency.
The number of peaks that are detected by the peak detector during each FFT time interval is counted by the counter 185, buffered in the flip-flop (FF) 186 and stored in the histogram registers 187 for output to the DPR 500. The PEAKEN signal is the output of the peak detector that goes high when a peak is detected. The PKDETSTART signal restarts the counting process for a statistic update cycle.
The Snapshot Buffer
The snapshot buffer 300 is a flexible data storage and triggering mechanism used to collect a set of raw ADC samples (DataI and DataQ or DataI' and DataQ',
In a pre-store mode, the snapshot buffer 300 writes continuously to the DPR 500 and stops writing and interrupts the MCU when a snapshot trigger signal is detected. In a post-store mode, the DPR write operation begins only after a trigger is detected. A combination pre and post store scenario may be created (using the DELAYSTART and DELAYEND control registers) to capture samples of the receive data signals both before and after a snapshot trigger condition.
There are two types of snapshot trigger signals supported: SB_TRIG and SD_SBEVT. The snapshot trigger signal SD_SBEVT is sourced from the signal detector 200 as described above, and the SB_TRIG signal is sourced from a module external to the SAGE 10, such as a location measurement module. For example, the MCU 700 may be programmed to collect raw ADC samples when a particular signal pulse is detected for signal classification processes. The MCU 700 configures a pulse detector to generate the snapshot trigger signal SD_SBEVT upon detecting a pulse that meets a certain set of characteristics, as described above. The snapshot buffer 300 clears this bit when it has finished its processing (usually within one clock).
The snapshot buffer 300 samples may be stored in a variety of formats. One example of a format is one complex sample per 32-bit word. The high-order 16 bits contain the real part of the sample; the low-order 16-bits contain the imaginary part. The real and imaginary parts may be stored in a Q15 format, where 0 represents 0V on the ADC in the RF Interface 800, and 0x7FFF and 0x8000 represent positive and negative full-scale, respectively. A B-bit QN fractional number x takes on the values {n/2N, n=-2B-1, . . . , 2B-1-1}. The B-bit signed integer n=2N*x is used to represent x and is usually stored as a signed, two's complement integer.
Examples of the control registers (and what they do) for the snapshot buffer are described below.
DELAYSTART: Number of samples to wait after the SB_TRIG signal before starting to write into DPR. Only valid if CNTRL.PRESTORE=0.
DELAYEND: Number of samples to write into DPR before DPR writes are disabled and a "snapshot complete" interrupt is posted to the MCU.
The count begins (1) when a trigger condition is asserted in prestore mode, or (2) DELAYSTART samples after a trigger condition in poststore mode.
STARTADDR: Address in DPR of first word of snapshot buffer.
ENDADDR: Address in DPR of last word of snapshot buffer.
WADDR: Starting write address into snapshot buffer (STARTADDR<=WADDR<=ENDADDR). When writing to the snapshot buffer, WADDR is incremented and after a write to ENDADDR, WADDR wraps back to STARTADDR. After a snapshot operation is complete, MCU may use this register to determine the address of the most recent write into the DPR.
TSTMP: Contains the TMR_TSTMP value latched immediately after the most recent snapshot trigger condition was asserted.
The control register includes the fields described below.
PRESTORE: Trigger prestore mode select. 1=Prestore mode (samples are written continuously to DPR while SB looks for a trigger signal) 0=Poststore mode (samples written to DPR DELAY_START samples after trigger detected).
REP: Repetition mode select. 1=Continuous mode--After a trigger signal is detected, immediately start looking for next trigger and continue writing to DPR if prestore mode enabled. STATUS always reads 1 in this mode. 0=One shot mode--Perform one snapshot buffering operation (during which STATUS will set to 1) and set STATUS to zero when done.
GO: Begin snapshot buffering operation. When GO is set to 0, SB is idle and does not look for a trigger. When the MCU sets GO to 1, SB starts looking for a trigger signal and prestoring samples in DPR (only if PRESTORE set to 1).
STATUS: Status field. 00=SB in idle state due to GO=0. 01=Waiting for trigger. Always set to 1 in continuous mode. 10=SB_TRIG detected in one shot mode and snapshot buffering operation complete. 11=SD_SBEVT detected in one shot mode and snapshot buffering operation complete. The SDID field indicates which pulse detector (1-4) caused the trigger.
SDID: Indicates which pulse detector caused the trigger condition.
The Dual Port RAM
The DPR 500 will be described with reference to
Referring first to
The DPR 500 is, for example, a 32-bit wide, synchronous DPR. Different clocks are used to drive the logic at each port. The CLK signal is used on SAGE components side and the BUSCLK signal is used on the MCU side. The DPR 500 is word addressable from the SAGE side and byte addressable from the MCU side. An AHB bus interface maps an internal MCU byte address into the corresponding word addresses (MDADDR) and byte enable (MDBYTEN) signals attached to the MCU side of the DPR.
The data structures used to manage the DPR buffers 510-540 are stored in the control registers associated with DPR. The MCU 700 is responsible for configuring the addresses and relative sizes of each buffer using these control registers after reset.
Referring to
When performing input/output with a circular list, read and write indices are maintained to indicate the next entry to be read or written. Whenever the end of the list is reached the index is wrapped back to the starting position (i.e., circular list). Whenever a read or write index is wrapped to the starting position, a corresponding read pass number or write pass number is incremented. This combination of index and pass number is called a "position" or ClistPosition. The ClistPosition is, for example, a 32-bit quantity consisting of a 16-bit "pass" and a 16-bit "index." When the pass number is updated, the entire 32-bit ClistPosition is written out as a single "atomic" operation. Similarly, a read operation reads the entire 32-bit ClistPosition to ensure the pass number and index components are consistent when wrap occurs.
The Universal Signal Synchronizer
The universal signal synchronizer 400 is useful to lock to interfering periodic signal sources. The USS 400 consists of multiple programmable clock generators referred to as USS clock modules (UCMs) 410. The MCU 700 can detect interference from a periodic signal source such as a Bluetooth™ headset, a cordless phone, etc., by examining traffic statistics gathered by the host communication device. For example, the MAC logic 750 will accumulate traffic statistics indicating how successful the host communication device has been in transmitting to and receiving information from other devices according to a MAC protocol, such as IEEE 802.11x, employed by the device. Traffic statistics that may reveal the presence of an interferer are: (1) un-acknowledged messages; (2) repeated cyclic redundancy code (CRC) errors; (3) low received signal strength, etc. For example, the fact that several messages are sent from the device that are not acknowledged by the intended destination device is very revealing of interference in the frequency band.
When the MCU determines to look for the cause of the interference, it configures the appropriate frequency and phase parameters corresponding to the interference source into a UCM 410, and, using pulse timing information from the signal detector 200, phase/frequency locks the UCM timing to the transmit timing for the interference source. After phase/frequency lock has taken place, the UCM can be used as a timing reference to prevent data transmissions to/from the MAC logic 750 (
A block diagram of a UCM 410 is shown in
A down counter 424 is connected to the output of the multiplexer 420 and counts down from the duration of each duration segment. A mod(N) counter 426 is connected to the down counter 424 and is used to reload the down counter 424 with the duration of the next segment after the down counter 424 counts down to zero. For the case shown, the mod(N) counter 426 is a mod4 counter. An accumulator 428 is coupled to the mod4 counter 424 and has a carry output that is coupled back to the adder 422. The most significant bit (MSB) output of the mod4 counter 426 is used to drive the count input of the accumulator 428. The accumulator 428 is a Z bit accumulator used to offset the UCM clock frequency, advancing or delaying the UCM clock by one TMR_CLK cycle every 2Z/freqOffset UCM cycles, where the freqOffset parameter is configurable by the MCU via an adder 430 coupled to the accumulator 428. There is a phaseOffset register 425 and a freqOffset register 427 that the MCU writes to for the purposes explained hereinafter.
In general, the clock module comprises at least N registers, each of which stores a programmable duration value associated with one of two states of a pulse of the communication signal, where N is equal to 2 times the number of pulses in a cycle of the communication signal, and the mod(N) counter coupled to the down counter counts up to N-1 by one in response to the down counter reaching zero and when reaching N-1, causing content of the next of the N registers to be loaded into the down counter. The count input of the Z-bit accumulator 428 is coupled to an output of the mod(N) counter, and the adder 430 adds an output of the accumulator 428 with the frequency offset value and supplies the sum to an input of the accumulator, wherein a carry output of the accumulator is coupled to the Nth register to increment or decrement the value of the Nth register before it is loaded into the counter, thereby extending or contracting the length of a cycle of the clock signal used to drive the down counter by one clock pulse every 2Z/(frequency offset value) clock cycles.
A UCM TMR_CLK frequency of fTMR
Output frequency=fCLK/[(M+freqOffset)/216]≈fCLK/M{1-(freqOffset/M216)}Hz, where M=DurOn1+DurOff1+DurOn2+DurOff2.
Frequency Resolution≈fCLK/(M2216)Hz=106/(M216)
Output clock frequency range: 1.9 Hz (DurOn1=DurOff1=DurOn2=DurOff2=218-1) to 500 kHz (DurOn1=DurOff1=DurOn2=DurOff2=1)
When the MCU 700 detects and classifies a periodic interference source, it takes the following steps to lock the UCM timing to the transmission timing associated with the interference source.
First, the MCU initializes and configures a UCM 410 to the appropriate (nominal) frequency using the DurOn and DurOff registers and it sets the content of the freqOffset register 425 to zero. The MCU writes values to the duration registers based on knowledge gained about the interferer from pulse events output by a pulse detector 220 (
The MCU examines the count values of the down counter and the mod(N) counter to measure a phase error between the clock signal that drives the down counter and the occurrence of the pulse of the communication signal. The MCU removes the initial phase offset/error between the UCM 410 and the interference source by loading a phase adjustment value into the PhaseOffset register 425. This causes the UCM 410 to retard the phase by the value specified in the PhaseOffset register 425 the next time the down counter 424 and mode counter 426 cycle to zero.
After removing the initial phase offset, the MCU periodically monitors the phase count values of the down counter and the mod(N) counter in the pulse event data to measure the phase error. The MCU generates a frequency offset between the interference source (from the pulse detector) and the UCM clock and updates the FreqOffset register 427 to compensate for frequency drift between the two signals. A block diagram of an update technique using a second order phase lock loop (PLL) is shown in
When the phase offset samples converge to zero, the UCM is said to be phase/frequency locked to the interference source. Once the loop is locked, the MCU may let the UCM clock "flywheel" for a period of time without monitoring the phase offset from the interference source. The MCU may continue to periodically monitor the phase offset and update the loop parameters since the clocks will eventually drift (primarily due to temperature changes in the near and far end reference oscillators). A good rule of thumb to use for estimating the drift rate in this case is ½ microsecond per second, assuming an oscillator with +/-20 ppm of variation over 70 degrees C. (4/7 ppm per degree C.), and 3 degrees F.=1.7 degrees C. temperature variation over 5 minutes (due to air conditioner hysteresis, etc.).
Reference is now made to
Examples of the registers used to control and monitor a UCM 410 from the MCU are described below.
DURON1: Duration in TMR_PULSE cycles of first "on" interval of a UCM clock cycle. The MCU may update this value anytime (regardless of whether the UCM is enabled).
DUROFF1: Duration in TMR_PULSE cycles of first "off" interval of a UCM clock cycle. The MCU may update this value anytime (regardless of whether the UCM is enabled).
DURON2: Duration in TMR_PULSE cycles of second "on" interval of a UCM clock cycle. The MCU may update this value anytime (regardless of whether the UCM is enabled).
DUROFF2: Duration in TMR_PULSE cycles of second "off" interval of a UCM clock cycle. The MCU may update this value anytime (regardless of whether the UCM is enabled).
FREQOFFSET: Creates a frequency offset of
relative to the nominal clock frequency (FTMR
PHASEOFFSET: Retards the phase of the UCM clock by PHASEOFFSET TMR_PULSE cycles by loading the value PHASEOFFSET into the Down Counter at the end of the next Dur1Off interval. The phase adjustment is made once each time the PHADJUST bit in the CNTRL register is set.
MINGAP: If the time between two consecutive interference events on the UCM signals specified by USS_SELECT is less than MINGAP TMR_PULSEs, the USS will merge the two events and report on them as if they were one interference event spanning both interference pulse durations.
DOWNCTR: Contents of UCM down counter register (updated once per TMR_PULSE)
The fields of the control register for a UCM are defined below.
ENABLE: UCM enable. Setting the ENABLE bit for 1 TMR_PULSE cycle causes the clock to start counting in the Dur1Off state. Clearing ENABLE for 1 or more TMR_PULSEs causes the UCM clock to stop counting.
PHADJUST: Writing a 1 to this bit causes the UCM to retard its clock phase by PHASEOFFSET TMR_PULSE cycles by loading the value PHASEOFFSET into the Down Counter at the end of the next Dur1Off clock segment. The UCM clears this bit after the phase change has taken place.
FOFFSET: Specifies whether a positive or negative frequency offset is to be applied using the FREQOFFSET field. 1=Positive frequency offset applied. 0=negative frequency offset applied
MOD4CT: Contents of Modulo 4 counter
The USS 400 passes UCM timing information to an external component, such as the MAC logic 750, using the NEXTINTFDUR and NEXTINTFTIME signals described hereinafter. The USS_SELECT signals, also described in the table above, allow for selection of which UCMs to include in next event calculation.
Other Interfaces to the SAGE
With reference to
The SAGE 10 communicates timing information for periodic interference sources (such as Bluetooth headsets or cordless phones) to another hardware element (external to the SAGE 10), such as the MAC logic 750. There are primarily three MAC interface signals, USS_SELECT, NEXTINTFDUR and NEXTINTFTIME. NEXTINTFDUR is the duration in TMR_PULSEs of the next interference event among the selected UCM clocks via USS_SELECT. The interference condition is said to be active (due to an interferer's transmission) when any of the selected UCM clocks is high. When all of the selected interference sources are inactive (i.e., all UCM clocks are low), NEXTINTFDUR indicates the duration of the next interference event in TMR_PULSEs. When at least one of the interference sources is active, NEXTINTFDUR indicates the time in TMR_PULSEs until the end of the current interference transmission, and is updated once per TMR_PULSE.
NEXTINTFTIME is the time remaining in TMR_PULSEs until the next interference event among the selected UCM clocks via USS_SELECT. The interference condition is said to be active (due to an interferer's transmission) when any of the selected UCM clocks is high. When all of the selected interference sources are inactive, NEXTINTFTIME indicates the time until the next interference event and is updated once per TMR_PULSE. When at least one of the interference sources is active, NEXTINTFTIME reads zero.
USS_SELECT is a signal that selects which USS UCMs 410 to include in the next interference event calculations, as reported to the MAC logic 750 through the NEXTINTFXXX signals. USS_SELECT[i]=1 means include UCM(i) in the calculation.
Examples of MCU interface signals are described below. Some of these signals are identified in
ADDR: Control register word address
BUSCLK: Clock used to control the MCU side of the DPR, USS, Lower MAC and Global Timer interfaces:
IRQ: Level-triggered interrupt request to MCU. Whenever an enabled interrupt condition becomes active, SAGE 10 asserts an interrupt to the MCU by setting IRQ to 0. The MCU clears the interrupt by clearing the appropriate bits in the IF register. SAGE automatically sets IRQ to 1 when all active interrupt conditions have been cleared in the IF register.
MDADDR: DPR word address--MCU side
MDBYTEEN: DPR byte enable--MCU side
MDRD: DPR read strobe--MCU side
MDRDATA: DPR read data--MCU side
MDWR: DPR write strobe--MCU side
MDWDATA: DPR write data--MCU side
RD: Control register read strobe
RDATA: Control register read data
SDADDR: DPR word address--SAGE side
SDRD: DPR read strobe--SAGE side
SDRDATA: DPR read data--SAGE side
SDWR: DPR write strobe--SAGE side
SDWDATA: DPR write data--SAGE side
WR: Control register write strobe
WDATA: Control register write data
Operation and Uses of the SAGE
With reference to
There are many ways to employ the features and functions of the SAGE 10, some examples of which are explained. The MCU 700 or the host processor 900 may be programmed to configure the receiver portion of the radio transceiver 600 to operate in a wideband mode, thereby sampling activity in an entire frequency band for a time period, such as 100 msec or longer. In addition, the MCU 700 or host processor 900 may configure certain basic parameters of the SAGE 10, such as the decimator factor, the cycle count of the number of spectrum analyzer updates (i.e., FFT intervals) before forwarding the stats to the MCU 700, the minimum power threshold for duty counting, the lowpass filter parameter of the spectrum analyzer. The receiver portion of the radio transceiver 600 may also be configured to operate in a narrowband mode at a configurable center frequency.
While the radio transceiver 600 is operated in a wideband mode, the SAGE 10 is activated to "sniff" the spectrum with the spectrum analyzer component of the SAGE 10. The spectrum analyzer stats, such as those shown in
Still another possibility is to iteratively change the configuration of one or more pulse detectors so as to cycle through pulse detector configurations over time. For example, the center frequency, bandwidth, pulse duration and/or time between pulses parameters can be changed to process incoming signal data. The incoming signals are processed during each cycle with the one or more pulse detectors. Eventually, by cycling through different pulse detector configurations, the goal is to eventually find a pulse detector configuration that fits the type of signal activity occurring in the frequency band. This is useful, for example, in a signal classification process.
Further operation of the SAGE to gather output from the signal detector may occur while the radio is in a wideband mode or a narrowband mode, depending on the demands of the radio for communication services and the type of signals suspected to be present in the frequency band. Whether configured based on information gathered from a sniff mode, or operated using predetermined configuration information, the pulse detectors will generate pulse event information that is output to the MCU 700, together with spectrum analyzer stats and any snapshot buffered data. In addition, the universal signal synchronizer component of the SAGE 10 may be operated by the MCU to synchronize to the clocks of potentially interfering communication signals in the frequency band. This synchronization information can be used in an interference mitigation or co-existence algorithm executed by the MCU 700 or the host processor 900 to schedule transmissions by the communication device so as to avoid collisions with other communication signals in the frequency band.
In addition, the output of the SAGE 10 can be used in a signal classification process to identify/classify signals in a frequency band, such as for example: a wireless headset operating with a frequency hopping communication protocol (e.g., Bluetooth™ ); wireless file/print services; radar systems; microwave ovens, an IEEE 802.11 wireless local area network; a HomeRF™ network; a FHSS cordless phone; an analog cordless phone; wireless infant/security monitors; devices operating using the IEEE 802.15.3 communication protocol. A signal classification process is disclosed in the aforementioned commonly assigned patent application.
One or more radio receivers may be coupled to the radio I/F 800. For example, one radio receiver 610 may be dedicated to one frequency band (such as the 2.4 GHz unlicensed band) and another radio receiver 620 may be dedicated to another frequency band (such as the 5 GHz unlicensed bands). Each radio receiver 600 and 610 may have the capability of operating in a wideband mode for purposes of downconverting energy in the entire frequency band for a time interval. An example of a radio receiver is identified above. A switch 630 selects the baseband analog output from one of the radio receivers, and couples it to an ADC 640, which is in turn coupled to the radio I/F 800. The DAC 650 is used to couple control signals to the radio receivers to, for example, control the bandwidth of operation of the radio receiver for wideband or narrowband operation. The dotted block around the radio receivers 610 and 620, the ADC and DAC, the SAGE 10, the DPR, and the radio I/F in
In this use of the SAGE 10, the host processor 900 performs the functions that are otherwise performed by the MCU 700 to control, and interface with, the SAGE 10, as well as other functions. One use of the SAGE 10 is to display the various outputs of the SAGE 10. For example, an application program residing in the memory 910 of the host device 1000 may generate a graphic user interface display of the SAGE output, as shown in FIG. 22. In addition, there may controls to trigger display of newly captured data as shown by the buttons at the top of FIG. 22.
Moreover, the radio I/F 800, SAGE 10 and DPR 500 are shown in phantom to indicate that all of the functions of these components may be performed by a software program stored in the memory 910 and executed by the host processor 900. In this configuration, the output of the ADC 640 is coupled through an interface, such as the cardbus interface 570 to the host processor 900, which executes processes that would otherwise be performed in hardware by the SAGE 10, as well as the other processes referred to above.
In sum, a signal detector circuit is provided comprising a peak detector that receives as input spectral information for successive time intervals of activity in a frequency band, detects one or more peaks in the spectral information and outputs information identifying peaks for each time interval; and at least one pulse detector coupled to the peak detector, the pulse detector detects signal pulses that satisfy configurable characteristics based on the output of the peak detector. An analogous signal detection method is also provided comprising steps of detecting one or more peaks in spectral information representing activity in a frequency band; and detecting signal pulses that meet one or more characteristics from the detected one or more peaks. The same steps may be implemented by instructions stored on a processor readable medium that, when executed, cause the processor to perform those steps.
Also provided is a system for synchronizing to a communication signal, comprising a clock module, a pulse detector circuit and a processor. The clock module comprises at least N registers, each of which stores a programmable duration value associated with one of two states of a pulse of the communication signal, where N is equal to 2 times the number of pulses in a cycle of the communication signal; a down counter driven by a clock signal that counts down with each clock pulse from a value corresponding to the content of one of the N registers; a mod(N) counter coupled to the down counter that counts up to N-1 by one in response to the down counter reaching zero and when reaching N-1, causing content of the next of the N registers to be loaded into the down counter. The pulse detector circuit detects a signal pulse in the communication signal. The processor is coupled to the clock module and to the signal detector circuit, and examines the count values of the down counter and the mod(N) counter to measure a phase error between the clock signal used to drive the down counter and the pulse of the communication signal.
Similarly, a method is provided for synchronizing to a communication signal, comprising steps of: detecting a pulse of the communication signal; comparing the occurrence of the pulse with a local clock signal; determining a phase error between the occurrence of the pulse and a state of the local clock signal; and delaying or advancing the local clock signal by an amount corresponding to the phase error. This process may also be implemented by instructions encoded on a processor readable medium that, when executed by a processor, cause the processor to perform these same steps.
A method is provided for use in a radio communication device that operates in a frequency band, the method for analyzing activity in the frequency band based on signals received by the communication device, comprising steps of: computing Fast Fourier Transform (FFT) values at a plurality of frequency bins from a digital signal representing activity in a frequency band during a time interval; computing the power at each frequency bin; adding the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to obtain a running sum of the power at each frequency bin; comparing the power at each frequency bin with a power threshold to obtain a duty count of the number of times that the power at each frequency bin exceeds the power threshold over time intervals; and comparing the power at each frequency bin for a current time interval with the power at the corresponding frequency bin for a previous time interval to track the maximum power in each frequency bin over time intervals. This process may also be implemented by instructions encoded on a processor readable medium that, when executed by a processor, cause the processor to perform these same steps.
Still further provided is a spectrum analysis device for use in a radio communication device that operates in a frequency band, comprising a Fast Fourier Transform (FFT) block that receives as input a digital signal representing activity in the frequency band for a time interval, wherein the FFT block computes FFT values for each of a plurality of frequency bins from the digital signal; a power calculation block that computes the power at each frequency bin and outputs a power data field comprising power values for the plurality of frequency bins; and a signal detector circuit. The signal detector circuit comprises a peak detector that receives as input the power data field for successive time intervals of activity in a frequency band, and detects one or more peaks in the spectral information, the peak detector outputting information identifying peaks for each time interval; and at least one pulse detector coupled to the peak detector that detects signal pulses that satisfy configurable characteristics based on the output of the peak detector. A system may be provided that further includes a clock module comprising: at least N registers, each of which stores a programmable duration value associated with one of two states of a pulse of the communication signal, where N is equal to 2 times the number of pulses in a cycle of the communication signal; a down counter driven by a clock signal that counts down with each clock pulse from a value corresponding to the content of one of the N registers; a mod(N) counter coupled to the down counter that counts up to N-1 by one in response to the down counter reaching zero and when reaching N-1, causing content of the next of the N registers to be loaded into the down counter; and a processor coupled to the clock module and to the signal detector circuit, wherein the processor examines the count values of the down counter and the mod(N) counter to measure a phase error between a clock signal used to drive the down counter and the pulse of the communication signal.
Still further provided is a method for detecting radio signals in a frequency band comprising steps of operating a radio receiver in a wideband mode so as to generate a downconverted signal representing activity in the entire frequency band; performing spectral analysis on the downconverted signal to generate spectral information of the frequency band; and detecting signal pulses of signals expected to be present in the frequency band from the downconverted signal based on knowledge gained from the spectral information of the frequency band.
Yet further provided is a processor readable medium encoded with instructions that, when executed by a processor, cause the processor to perform steps of computing a Fast Fourier Transform (FFT) values for each of a plurality of frequency bins from a digital signal representing activity in a frequency band for a time interval; computing the power at each frequency bin from the FFT values; detecting one or more peaks from the FFT values; and detecting signal pulses that meet one or more characteristics from the detected one or more peaks.
The above description is intended by way of example only and is not intended to limit the present invention in any way.
Miller, Karl A., Sugar, Gary L., Baek, Jong Sup
Patent | Priority | Assignee | Title |
10070437, | Oct 18 2006 | Shared Spectrum Company | Methods for using a detector to monitor and detect channel occupancy |
10104555, | Aug 15 2007 | Shared Spectrum Company | Systems and methods for a cognitive radio having adaptable characteristics |
10484927, | Dec 29 2006 | Shared Spectrum Company | Method and device for policy-based control of radio |
7035593, | Jul 28 2003 | Cisco Technology, Inc | Signal classification methods for scanning receiver and other applications |
7076401, | Apr 30 2002 | Intel Corporation | Method and apparatus for measuring data timing using unity time-voltage sawtooth ramps |
7116943, | Apr 22 2002 | Cisco Technology, Inc | System and method for classifying signals occuring in a frequency band |
7120546, | Apr 23 2003 | Texas Instruments Incorporated | Integrated spectrum analyzer for tuners |
7142108, | Aug 19 2004 | Cisco Technology, Inc | System and method for monitoring and enforcing a restricted wireless zone |
7171161, | Jul 30 2002 | Cisco Technology, Inc | System and method for classifying signals using timing templates, power templates and other techniques |
7224752, | Apr 22 2002 | Cisco Technology, Inc | System and method for real-time spectrum analysis in a communication device |
7251284, | Nov 26 2001 | LANTIQ BETEILIGUNGS-GMBH & CO KG | QAM receiver |
7254191, | Apr 22 2002 | Cisco Technology, Inc | System and method for real-time spectrum analysis in a radio device |
7269151, | Apr 22 2002 | Cisco Technology, Inc | System and method for spectrum management of a shared frequency band |
7292656, | Apr 22 2002 | Cisco Technology, Inc | Signal pulse detection scheme for use in real-time spectrum analysis |
7302022, | Apr 10 2003 | INTELLECTUAL DISCOVERY CO , LTD | Automatic gain control device and method in orthogonal frequency division multiplexing system with DC offset compensation function, and recording medium storing program containing the method |
7317419, | Jun 23 2004 | Cisco Technology, Inc | Self-calibrated path loss position estimation and zone of impact determination |
7395292, | Oct 08 2003 | Method for displaying spectral trends in complex signals | |
7460499, | Jan 17 2003 | Texas Instruments Incorporated | Modulation noise estimation mechanism |
7466960, | Feb 08 2005 | Cisco Technology, Inc | Cognitive spectrum analysis and information display techniques |
7511848, | Oct 18 2004 | Microsoft Technology Licensing, LLC | Method and system for configuring an electronic device |
7546357, | Jan 07 2004 | Rovi Technologies Corporation | Configuring network settings using portable storage media |
7564816, | May 12 2006 | Shared Spectrum Company | Method and system for determining spectrum availability within a network |
7577181, | Aug 01 2000 | Itron, Inc | Frequency hopping spread spectrum system with high sensitivity tracking and synchronization for frequency unstable signals |
7606335, | Apr 22 2002 | Cisco Technology, Inc | Signal pulse detection scheme for use in real-time spectrum analysis |
7616588, | Mar 31 2005 | Microsoft Technology Licensing, LLC | Simplified creation and termination of an ad hoc wireless network with internet connection sharing |
7620396, | Feb 08 2005 | Cisco Technology, Inc | Monitoring for radio frequency activity violations in a licensed frequency band |
7657612, | Jan 07 2004 | Rovi Technologies Corporation | XML schema for network device configuration |
7688779, | May 16 2006 | Lenovo PC International | Handling the use of multiple 802.11n channels in a location where there are a small number of available channels |
7710587, | Oct 18 2004 | Microsoft Technology Licensing, LLC | Method and system for configuring an electronic device |
7769995, | Jan 07 2004 | Rovi Technologies Corporation | System and method for providing secure network access |
7774437, | Oct 18 2004 | Microsoft Technology Licensing, LLC | Configurable multi-connector storage device |
7826833, | Feb 17 2005 | Microsoft Technology Licensing, LLC | Channel assay for thin client device wireless provisioning |
7835319, | May 09 2006 | Cisco Technology, Inc | System and method for identifying wireless devices using pulse fingerprinting and sequence analysis |
7916814, | May 30 2007 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Method and apparatus for real-time pulse parameter estimator |
7945407, | Sep 19 2006 | Tektronix, Inc | Signal analyzers and frequency domain data production methods |
8023575, | Jun 13 2006 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Approach for spectrum analysis in a receiver |
8027249, | Oct 18 2006 | Shared Spectrum Company | Methods for using a detector to monitor and detect channel occupancy |
8045655, | Nov 03 2005 | Samsung Electronics Co., Ltd. | Apparatus and method for signal detection in a cognitive radio-based wireless communication system |
8055204, | Aug 15 2007 | Shared Spectrum Company | Methods for detecting and classifying signals transmitted over a radio frequency spectrum |
8060035, | Oct 13 2004 | McMaster University | Transmit power control techniques for wireless communication systems |
8064840, | May 12 2006 | Shared Spectrum Company | Method and system for determining spectrum availability within a network |
8086199, | May 22 2008 | Cisco Technology, Inc. | Sharing AGC loop between demodulator and spectrum analysis system |
8111783, | Jun 17 2008 | Cisco Technology, Inc. | Capturing and using radio events |
8144600, | Jan 10 2008 | Cisco Technology, Inc. | Optimization for wireless access point management |
8145735, | Jan 07 2004 | Rovi Technologies Corporation | Configuring network settings using portable storage media |
8155649, | May 12 2006 | Shared Spectrum Company | Method and system for classifying communication signals in a dynamic spectrum access system |
8175539, | Apr 22 2002 | Cisco Technology, Inc. | System and method for management of a shared frequency band |
8179118, | Nov 04 2005 | Tektronix, Inc | Wide-bandwidth spectrum analysis of transient signals using a real-time spectrum analyzer |
8184653, | Aug 15 2007 | Shared Spectrum Company | Systems and methods for a cognitive radio having adaptable characteristics |
8184678, | Jun 10 2003 | Shared Spectrum Company | Method and system for transmitting signals with reduced spurious emissions |
8190162, | Sep 15 2003 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Radar detection circuit for a WLAN transceiver |
8224254, | Oct 13 2004 | McMaster University | Operating environment analysis techniques for wireless communication systems |
8326313, | Oct 18 2006 | Shared Spectrum Company | Method and system for dynamic spectrum access using detection periods |
8346163, | Jul 21 2006 | Vodafone Group PLC | Radio frequency signal distribution using data cable system |
8416295, | Jul 24 2008 | Triasys Technologies Corporation | Surveillance data recording device and method |
8514729, | Apr 03 2009 | NetScout Systems, Inc | Method and system for analyzing RF signals in order to detect and classify actively transmitting RF devices |
8515473, | Mar 08 2007 | Bae Systems Information and Electronic Systems Integration INC | Cognitive radio methodology, physical layer policies and machine learning |
8547911, | May 21 2008 | SEQUANS COMMUNICATIONS | Method and system for channel scanning in a wireless communications system |
8559301, | Oct 18 2006 | Shared Spectrum Company | Methods for using a detector to monitor and detect channel occupancy |
8581695, | May 27 2009 | Overhead Door Corporation | Channel-switching remote controlled barrier opening system |
8666319, | Jul 15 2011 | Cisco Technology, Inc. | Mitigating effects of identified interference with adaptive CCA threshold |
8675781, | Sep 08 2011 | ThinkRF Corporation | Radio frequency receiver system for wideband signal processing |
8676144, | Apr 14 2011 | Cisco Technology, Inc. | Adaptive interference nulling for MIMO receiver based on interference characteristics |
8718560, | Jul 07 2011 | Cisco Technology, Inc. | Dynamic clear channel assessment using spectrum intelligent interference nulling |
8755754, | Aug 15 2007 | Shared Spectrum Company | Methods for detecting and classifying signals transmitted over a radio frequency spectrum |
8767556, | Aug 15 2007 | Shared Spectrum Company | Systems and methods for a cognitive radio having adaptable characteristics |
8793791, | Aug 15 2007 | Shared Spectrum Company | Methods for detecting and classifying signals transmitted over a radio frequency spectrum |
8818283, | Aug 19 2008 | Shared Spectrum Company | Method and system for dynamic spectrum access using specialty detectors and improved networking |
8818437, | Aug 02 2011 | Cisco Technology, Inc. | Narrowband interference avoidance for dynamic channel assignment |
8824970, | Sep 12 2012 | Qualcomm Incorporated | System and method for identifying and managing overlapping spectrum use |
8938200, | Oct 13 2004 | McMaster University | Operating environment analysis techniques for wireless communication systems |
8997170, | Dec 29 2006 | Shared Spectrum Company | Method and device for policy-based control of radio |
9143370, | Sep 26 2013 | Cisco Technology, Inc. | DC correction for accurate detection of pulses |
9215710, | Oct 18 2006 | Shared Spectrum Company | Methods for using a detector to monitor and detect channel occupancy |
9306722, | Jul 02 2013 | Cisco Technology, Inc.; Cisco Technology, Inc | Tracking radar frequency enabling more channels |
9491636, | Oct 18 2006 | Shared Spectrum Company | Methods for using a detector to monitor and detect channel occupancy |
9538388, | May 12 2006 | Shared Spectrum Company | Method and system for dynamic spectrum access |
9584251, | Mar 31 2015 | Allen-Vanguard Corporation | System and method for classifying signal modulations |
9590762, | Sep 08 2014 | Cisco Technology, Inc. | Concurrent on-channel servicing of wireless client traffic and off-channel pre-scanning for radar in a wireless access point |
9621207, | Aug 06 2012 | Google Technology Holdings LLC | Methods and apparatus for detecting presence of a jamming signal |
9632183, | Nov 22 2013 | Raytheon Company | Mitigation of radio frequency interference (RFI) in global positioning system (GPS) signals |
9854461, | Aug 15 2007 | Shared Spectrum Company | Methods for detecting and classifying signals transmitted over a radio frequency spectrum |
9900782, | May 12 2006 | Shared Spectrum Company | Method and system for dynamic spectrum access |
9942880, | Feb 03 2016 | Kabushiki Kaisha Toshiba | Transmit and receive apparatus and method |
RE43066, | Jun 13 2000 | Shared Spectrum Company | System and method for reuse of communications spectrum for fixed and mobile applications with efficient method to mitigate interference |
RE44237, | Jun 13 2000 | Shared Spectrum Company | System and method for reuse of communications spectrum for fixed and mobile applications with efficient method to mitigate interference |
RE44492, | Jun 13 2000 | Shared Spectrum Company | System and method for reuse of communications spectrum for fixed and mobile applications with efficient method to mitigate interference |
RE46905, | Jun 13 2000 | Shared Spectrum Company | System and method for reuse of communications spectrum for fixed and mobile applications with efficient method to mitigate interference |
RE47120, | Jun 13 2000 | Shared Spectrum Company | System and method for reuse of communications spectrum for fixed and mobile applications with efficient method to mitigate interference |
Patent | Priority | Assignee | Title |
3992666, | Jan 27 1975 | The United States of America as represented by the Secretary of the Navy | Technique for detecting energy and determining the frequency of constituent energy components |
4054785, | Sep 16 1976 | Sangamo Weston, Inc. | Spectrum analyzer with multiple operational modes |
4084245, | Aug 16 1975 | U.S. Philips Corporation | Arrangement for statistical signal analysis |
4166980, | Aug 25 1977 | Sanders Associates, Inc. | Method and apparatus for signal recognition |
4227255, | Apr 11 1979 | Telcom, Inc. | Signal classifier |
4336541, | Aug 08 1980 | The United States of America as represented by the Secretary of the Air | Simultaneous signal detector for an instantaneous frequency measurement receiver |
4501020, | Sep 21 1982 | MILLER COMMUNICATIONS SYSTEMS LTD | Spectrum surveillance receiver system |
4597107, | Apr 01 1983 | WACHOVIA BANK, NATIONAL | Modulation detector and classifier |
4818949, | Jan 06 1988 | U.S. Government as represented by Director, National Security Agency | Microwave and millimeter-wave spectrum analyzer |
4839582, | Jul 01 1987 | Anritsu Corporation | Signal analyzer apparatus with automatic frequency measuring function |
4947338, | Aug 22 1986 | Tektronix, Inc. | Signal identification method |
4950999, | Mar 06 1989 | Self-contained, real-time spectrum analyzer | |
5005210, | Dec 30 1987 | The Boeing Company | Method and apparatus for characterizing a radio transmitter |
5144642, | Jun 07 1990 | Exelis Inc | Interference detection and characterization method and apparatus |
5210820, | May 02 1990 | NIELSEN ENTERTAINMENT, LLC, A DELAWARE LIMITED LIABILITY COMPANY; THE NIELSEN COMPANY US , LLC, A DELAWARE LIMITED LIABILITY COMPANY | Signal recognition system and method |
5230087, | Sep 12 1990 | BELAR ELECTRONICS LABORATORY, INC , A CORP OF PA | Device for measuring various characteristics of a radio frequency signal |
5271036, | Nov 16 1990 | Thomson-CSF | Method and device for the recognition of modulations |
5303262, | Feb 21 1992 | Agilent Technologies Inc | Method and apparatus for triggering measurements from a TDMA signal |
5323337, | Aug 04 1992 | Lockheed Martin Corporation | Signal detector employing mean energy and variance of energy content comparison for noise detection |
5432862, | Nov 09 1990 | Visidyne, Inc. | Frequency division, energy comparison, source detection signal processing system |
5436556, | Dec 20 1989 | Signal detector and method for detecting signals having selected frequency characteristics | |
5574979, | Jun 03 1994 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Periodic interference avoidance in a wireless radio frequency communication system |
5697078, | Mar 25 1994 | TELECOM HOLDING PARENT LLC | Wideband channel sniffer for monitoring channel use in a wireless communication system |
5706202, | Mar 08 1995 | Anritsu Corporation | Frequency spectrum analyzing apparatus and transmitter characteristics measuring apparatus using the same |
5745777, | May 10 1994 | Seiko Instruments Inc | Analyzer for frequency modulated signals |
5905949, | Dec 21 1995 | AUTHORIZE NET LLC | Cellular telephone fraud prevention system using RF signature analysis |
5956638, | Jan 24 1996 | TTI Inventions C LLC | Method for unlicensed band port to autonomously determine interference threshold and power level |
6084919, | Jan 30 1998 | GENERAL DYNAMICS ADVANCED INFORMATION SYSTEMS, INC; GENERAL DYNAMICS MISSION SYSTEMS, INC | Communication unit having spectral adaptability |
6130907, | Jan 14 1998 | WSOU Investments, LLC | Interference detection for spread spectrum systems |
6229997, | Apr 21 1997 | Honeywell International Inc | Interference detecting receiver |
6229998, | Apr 12 1999 | Qualcomm Inc.; Qualcomm Incorporated | Method and system for detecting in-band jammers in a spread spectrum wireless base station |
6233529, | Oct 14 1997 | Advantest Corporation | Frequency spectrum analyzer having time domain analysis function |
6349198, | Jan 25 2000 | Aster Wireless | Wireless control system for periodic noise sources |
6374082, | Jun 02 1998 | Aster Wireless | RF wireless communication system operating in periodic noise environments |
6385434, | Sep 16 1998 | GENERAL DYNAMICS ADVANCED INFORMATION SYSTEMS, INC; GENERAL DYNAMICS MISSION SYSTEMS, INC | Wireless access unit utilizing adaptive spectrum exploitation |
6484111, | Dec 02 1997 | Sony/Tektronix Corporation | Real time signal analyzer |
6509728, | May 28 1998 | Anritsu Corporation | Spectrum analyzer having function of displaying amplitude probability distribution effectively |
6584419, | Oct 12 2000 | Agilent Technologies, Inc. | System and method for enabling an operator to analyze a database of acquired signal pulse characteristics |
20010055952, | |||
20020086641, | |||
20020142744, | |||
20020154614, | |||
20020155811, | |||
20020177446, | |||
20030050014, | |||
20030067662, | |||
CA2260336, | |||
CA2298316, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Sep 17 2002 | SUGAR, GARY L | COGNIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 013304 | /0270 | |
Sep 17 2002 | MILLER, KARL A | COGNIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 013304 | /0270 | |
Sep 17 2002 | BAEK, JONG SUP | COGNIO, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 013304 | /0270 | |
Sep 18 2002 | Cognio, Inc. | (assignment on the face of the patent) | / | |||
Oct 12 2007 | COGNIO, INC | COGNIO LLC | CONVERSION WITH NAME CHANGE | 020617 | /0317 | |
Jan 08 2008 | COGNIO LLC | Cisco Technology, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020617 | /0155 |
Date | Maintenance Fee Events |
Sep 07 2007 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 23 2011 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Sep 30 2015 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Mar 30 2007 | 4 years fee payment window open |
Sep 30 2007 | 6 months grace period start (w surcharge) |
Mar 30 2008 | patent expiry (for year 4) |
Mar 30 2010 | 2 years to revive unintentionally abandoned end. (for year 4) |
Mar 30 2011 | 8 years fee payment window open |
Sep 30 2011 | 6 months grace period start (w surcharge) |
Mar 30 2012 | patent expiry (for year 8) |
Mar 30 2014 | 2 years to revive unintentionally abandoned end. (for year 8) |
Mar 30 2015 | 12 years fee payment window open |
Sep 30 2015 | 6 months grace period start (w surcharge) |
Mar 30 2016 | patent expiry (for year 12) |
Mar 30 2018 | 2 years to revive unintentionally abandoned end. (for year 12) |