This invention relates to video signal processing and, more specifically, to a system and method for detecting and processing horizontal and vertical synchronization signaling.
Composite video signals, commonly used in video broadcasts or transmissions, contain image data and synchronization information. The image data typically includes a brightness signal (luminance, luma or Y) and a color signal (chrominance, chroma or C), where the color signal is modulated into a color sub-carrier and added to the brightness signal prior to transmission. The synchronization information includes horizontal sync pulses to define horizontal line-to-line transitions of the image data, and vertical sync pulses to identify field-to-field transitions. Accurate detection and processing of these horizontal and vertical sync pulses allows systems to properly display the image data.
Typically, display systems generate synchronization signals from the horizontal and vertical sync pulses 23 and 30 for use in processing and display of the image data 24 within composite video signal 10. Since picture quality depends upon the accuracy of the synchronization signals relative to the composite video signal 10, any corruption of the composite video signal 10 can cause undesirable results when the image data 24 is displayed. For instance, when time-based errors or temporal shifts are present within the composite video signal 10, a rapid phase shift of the synchronization signals is needed to maintain a lock with the composite video signal 10. Under noisy signal conditions, however, detection of the sync pulses 23 and 30 becomes unreliable, and thus correction of synchronization signals may degrade lock with the composite video signal 10. Current display systems generate their synchronization signals optimizing one of the signal locking techniques, to the detriment of the other technique. For instance, display systems that rapidly compensate for time-based errors are susceptible to miscorrecting their synchronization signals during noisy conditions. Conversely, display systems that minimize correction to synchronization signals to reduce correction-errors during noisy signaling conditions, cannot rapidly compensate for time-based errors. Accordingly, a need remains for a system and method for improved horizontal and vertical sync pulse detection and processing.
The foregoing and other objects, features, and advantages of the invention will become more readily apparent from the following detailed description of an embodiment that proceeds with reference to the following drawings.
Likewise, a video receiver or decoder 122 may optionally decode an analog video signal 112 from a video source 104 when the input is in the composite or s-video format. The video source 104 may be a video camcorder, tape player, digital video disk (DVD) player, or any other device capable of generating the analog or digital video signal 112. The video source 104 may read (or play) external media 101. In an embodiment, a DVD player 104 plays the DVD 101. In another embodiment, a VHS tape player 104 plays a VHS tape 101. The decoder 122 converts the analog video signal 112 into the digital video signal 109 and provides it to the panel controller 150. The decoder 122 is any device capable of generating digital video signal 109, e.g., in Y/C or CVBS format, from the analog video signal 112. A person of reasonable skill in the art knows well the design and operation of the video source 104 and the video decoder 112.
A modem or network interface card (NIC) 124 receives data 114 from a global computer network 106 such as the Internet®. The data 114 may be in any format capable of transmission over the network 106. In an embodiment, the data 114 is packetized digital data. But the data 114 may also be in an analog form. Likewise, the modem 124 may be a digital or analog modem or any device capable of receiving data 114 from a network 106. The modem 124 provides digital video signal 109 to the panel controller 150. A person of reasonable skill in the art knows well the design and operation of the network 106 and the modem/NIC 124.
A Digital Visual Interface (DVI) or high definition multimedia interface (HDMI) receiver 126 receives digital signals 116 from a digital source 108. In an embodiment, the source 108 provides digital RGB signals 116 to the receiver 126. The receiver 126 provides digital video signal 109 to the panel controller 150. A person of reasonable skill in the art knows well the design and operation of the source 108 and the receiver 126.
A tuner 128 receives a wireless signal 118 transmitted by the antenna 119. The antenna 119 is any device capable of wirelessly transmitting or broadcasting the signal 118 to the tuner 128. In an embodiment, the antenna 119 transmits a television signal 118 to the television tuner 128. The tuner 128 may be any device capable of receiving a signal 118 transmitted wirelessly by any other device, e.g., the antenna 119, and of generating the digital video signal 109 from the wireless signal 118. The tuner 128 provides the digital video signal 109 to the controller 150. A person of reasonable skill in the art knows well the design and operation of the antenna 119 and the tuner 128.
The digital video signal 109 may be in a variety of formats, including composite or component video. Composite video describes a signal in which luminance, chrominance, and synchronization information are multiplexed in the frequency, time, and amplitude domain for single wire transmission. Component video, on the other hand, describes a system in which a color picture is represented by a number of video signals, each of which carries a component of the total video information. In a component video device, the component video signals are processed separately and, ideally, encoding into a composite video signal occurs only once, prior to transmission. The digital video signal 109 may be a stream of digital numbers describing a continuous analog video waveform in either composite or component form.
The controller 150 generates image data 132 and control signals 133 by manipulating the digital video signal 109. The panel controller 150 provides the image data 132 and control signals 133 to a panel device 160. The panel 160 includes a pixelated display that has a fixed pixel structure. Examples of pixelated displays are active and passive LCD displays, plasma displays (PDP), field emissive displays (FED), electro-luminescent (EL) displays, micro-mirror technology displays, low temperature polysilicon (LTPS) displays, and the like. A person of reasonable skill in the art should recognize that flat panel 160 may be a television, monitor, projector, personal digital assistant, and other like applications. Although
The controller 150 includes a synchronization processing system 200 to detect and process synchronization signaling within digital video signal 109. Synchronization processing system 200 may be integrated into a monolithic integrated circuit or hardwired using any number of discrete logic and other components. Alternatively, the controller 150 may be a dedicated processor system that includes a microcontroller or a microprocessor to implement the synchronization processing system 200 as a software program or algorithm. We explain the synchronization processing system 200 in more detail below.
In an embodiment, the controller 150 may scale the digital video signal 109 for display by the panel 160 using a variety of techniques including pixel replication, spatial and temporal interpolation, digital signal filtering and processing, and the like. In another embodiment, the controller 150 may additionally change the resolution of the digital video signal 109, changing the frame rate and/or pixel rate encoded in the digital video signal 109. Scaling, resolution, frame, and/or pixel rate conversion, and/or color manipulation are not central to this embodiment and are not discussed in further detail.
Read-only (ROM) and random access (RAM) memories 140 and 142, respectively, are coupled to the display system controller 150 and store bitmaps, FIR filter coefficients, and the like. A person of reasonable skill in the art should recognize that the ROM and RAM memories 140 and 142, respectively, may be of any type or size depending on the application, cost, and other system constraints. A person of reasonable skill in the art should recognize that the ROM and RAM memories 140 and 142, respectively, are optional in the system 100. A person of reasonable skill in the art should recognize that the ROM and RAM memories 140 and 142, respectively, may be external or internal to the controller 150. RAM memory 142 may be a flash type memory device. Clock 144 controls timing associated with various operations of the controller 150.
Embodiments of the synchronization processing system 200 will be explained with reference to
The low pass filter 210 may include a finite-impulse-response (FIR) low pass filter 212 and an adaptive low pass filter 214. Since under-filtering the digital video signal 109 causes the sync slicer 220 to falsely detect noise as the sync pulses and over-filtering rejects the sync pulses from the digital video signal 109, the low pass filter 210 adapts its filtering of the digital video signal 109 according to the noise-level associated the digital video signal 109. The FIR low pass filter 212 filters the digital video signal 109 and provides an output signal 213 to the adaptive low pass filter 214 and a noise estimator 300. A person of reasonable skill in the art knows well the design and operation of the FIR low pass filter 212. The noise estimator 300 generates a noise estimate 302 according to the output signal 213 and provides the noise estimate 302 to the adaptive low pass filter 214. The noise estimator 300 may also generate and provide a line rejection signal 304 to a synchronization processing unit 400. Embodiments of the noise estimator 300 will be shown and described below in greater detail with reference to
The adaptive low pass filter 214 filters the output signal 213 according to the noise estimate 302 from the noise estimator 300. In some embodiments, the adaptive low pass filter 214 may be an infinite-impulse-response (IIR) low pass filter with a time-constant that is adjustable according to the noise estimate 302. For instance, as the noise estimate 302 increases, the adaptive IIR filter 214 lowers its cut-off frequency to provide better noise rejection. A person of reasonable skill in the art knows well the design and operation of the IIR low pass filter 214. The adaptive low pass filter 214 provides the noise-rejected signal 215 to the sync slicer 220. As previously mentioned, over-filtering the output signal 213 also rejects the synchronization signaling, thus during increased noise conditions the adaptive low pass filter 214 may pass noise along within the noise-rejected signal 215 to avoid over-filtering.
The sync slicer 220 detects a predetermined point corresponding to the synchronization signaling embedded in the noise-rejected signal 215. This detection of a predetermined point allows output-matching of the sampling phase, thus preserving the output frequency up to the Nyquist limit. To prevent initial lock-on problems, some embodiments of the sync slicer 220 average the back porch level and the sync tip level of the noise-rejected signal 215 to capture luma values just before and after a 50% slice point. The output 225 of the sync slicer 220 may be further filtered to remove glitches, e.g., with an up/down counter (not shown), insuring rejection of the low frequency undershoots typical of, e.g., video cassette recorders (VCRs). The sync slicer 220 provides the output 225 to a switching device 230. The switching device 230 selects an output 235 from one of the output 225 of the sync slicer 220 or a signal 222 provided from a source external to the synchronization processing system 200. The external source may be another sync slicer, e.g., located within an analog-to-digital converter (ADC) core and/or provide a Sync On Green (SOG) signal or other horizontal synchronization signals to the switching device 230. The switching device 230 provides a sliced output 235 to the synchronization processing unit 400.
The synchronization processing unit 400 generates the synchronization signals 401, 403, and 405 according to sliced output 235. The controller 150 may use the synchronization signals 401, 403, and 405 to appropriately lock onto the digital video signal 109 for further processing and display. The synchronization processing unit 400 may also receive the line rejection signal 304 from the noise estimator 300 for use in generating the synchronization signals 401, 403, and 405. Embodiments of the synchronization processing unit 400 will be shown and described in greater below with reference to
At block 314, the noise estimator 300 estimates the noise corresponding to pixel sets within the horizontal line of image data. Each pixel set may correspond to two cycles of the color sub-carrier frequency, or approximately 16 pixels within a horizontal line of image data, although other pixel set sizes may be programmed. In some embodiments, the noise estimator 300 may estimate the noise associated with a current pixel set by determining the difference between an average pixel level from another pixel set and each pixel within a current pixel set (block 315A). The magnitudes of the differences may then be averaged to estimate the noise corresponding to the current pixel set (block 315B). The averaged differences for a current pixel set may additionally be averaged with the averaged differences of one or more other pixel sets to reduce potential for fluctuation between pixel set estimates. The noise estimator 300 need not perform noise estimates on all pixel sets within a horizontal line. For instance, the noise estimator 300 may require the average pixel level of a pixel set to fall within a predetermined range of values, thus allowing the exclusion of undesirable pixel sets from the line noise estimation.
At block 316, the noise estimator 300 determines a noise estimate 302 according to the pixel set noise estimates. In some embodiments, the noise estimate 302 may be the lowest estimate of pixel set noise for a horizontal line. The noise estimator 300 may also adaptively filter the noise estimate 302 prior to providing it the adaptive low pass filter 214 (
At block 318, the noise estimator 300 determines the line rejection signal 304 according to the noise estimate 302 and an average line noise. The line rejection signal 304 may indicate that the detection of synchronization signaling for a corresponding horizontal line is particularly unreliable due to excessive noise within the digital video signal 109. In some embodiments, the line rejection signal 304 may be generated when the noise estimate 302 for a horizontal line is substantially greater than the average line noise, e.g., more than four times, where the average line noise may be an average of the noise estimate 302 over a programmable number of horizontal lines of the digital video signal 109.
The horizontal sync processor 402 generates the horizontal synchronization signal 401 by adapting between multiple horizontal synchronization signal 401 locking techniques according to the stability of the digital video signal 109. For instance, when the digital video signal 109 is considered stable, the horizontal sync processor 402 rapidly realigns the horizontal synchronization signal 401 to compensate for time-based errors. When the digital video signal 109 is determined to be unstable, however, the horizontal sync processor 402 minimizes phase adjustments made to the horizontal synchronization signal 401.
The horizontal sync processor 402 includes a stability identifier 410 to estimate a relative stability of the digital video signal 109 according to the sliced output 235. The stability identifier 410 may determine the stability of the digital video signal 109 by comparing the position of each horizontal sync pulse within the sliced output 235 to an expected window. For instance, when the position of a horizontal sync pulse falls within the expected window, the stability identifier 410 identifies the horizontal sync pulse as stable. The stability identifier 410 may also identify horizontal sync pulses that fall outside of the expected window as stable by comparing their position to one or more previous horizontal sync pulses. For instance, when two consecutive horizontal sync pulses fall on the same side of the expected window, the stability identifier 410 may identify the subsequent horizontal sync pulse as stable. The expected window is preferably wide enough to accommodate most synchronization variations from video cassette recorders, although other expected window configurations may be programmed.
The horizontal sync processor 402 may aggregate these stability determinations to generate a synchronization mode 415. The horizontal sync processor 402 may include a counter (not shown) which is decremented a programmable amount by the stability identifier 410 upon identification of each stable horizontal sync pulse, and incremented a programmable amount responsive to each unstable horizontal sync pulse. The programmable amount for increments and decrements may each vary according to the synchronization mode 415, or a current counter value. The stability identifier 410 provides the synchronization mode 415 to the sync window generator 420. In some embodiments, the stability identifier 410 may provide the stability determinations directly to the sync window generator 420 for use by the sync window generator 420 in determining the synchronization mode 415. In other embodiments, the stability determinations may be the synchronization mode 415.
The synchronization mode 415 may include two settings, e.g., stable and unstable, while other embodiments may include one or more additional settings, e.g., one or more stability settings between the stable and unstable settings. In some embodiments, the synchronization mode 415 includes a continuous range of settings implemented by multiple stable/unstable fuzzy logic sets. The stability identifier 410 may set the synchronization mode 415 according to a counter value, or may provide the counter value to the sync window generator 420 directly as the synchronization mode 415. The counter may have predetermined maximum value and minimum value levels to ensure changes in the setting of the synchronization mode 415 coincide with variations in the stability of the digital video signal 109.
The sync window generator 420 generates a sync window 425 responsive to the synchronization mode 415 and provides the sync window 425 to a horizontal synthesizer 430. The horizontal synthesizer 430 generates the horizontal synchronization signal 401 responsive to the sync window 425. The horizontal synthesizer 430 may generate the horizontal synchronization signal 401 by phase adjusting a signal generating source (not shown separately from the horizontal synthesizer 430) according to the sync window 425 and the detected horizontal sync pulses. In some embodiments, the signal generating source may be a stable crystal clock source providing pulses at a frequency substantially similar to horizontal sync pulse signaling within a typical video signal. The sync window 425 may identify the maximum allowable phase adjustment that may be made to the signal generating source. For instance, when the synchronization mode 415 is set to a stable setting, the sync window 425 may be large allowing the horizontal synthesizer 430 to rapidly realign the horizontal synchronization signal 401 according to the detected horizontal sync pulse position. Conversely, when the synchronization mode 415 is set to an unstable setting, the sync window 425 may be small, thus the horizontal synthesizer 430 minimally adjusts the horizontal synchronization signal 401 according to the position of the detected horizontal sync pulse. The sync window generator 420 may dynamically vary the sync window 425 to include one or more intermediate sizes between a maximum and minimum sync window size according to the synchronization mode 415.
The horizontal sync processor 402 may also receive the line rejection signal 304 from the noise estimator 300. The line rejection signal 304 may indicate to the horizontal sync processor 402 that the presence of a detectable horizontal sync pulse within sliced output 235 is highly unlikely due to elevated noise associated with digital video signal 109. The horizontal sync processor 402 may generate the horizontal synchronization signal 401 according to one or more previous horizontal sync pulse detections or the expected location of the horizontal sync pulse responsive to the line rejection signal 304.
The horizontal sync processor 402 may generate the horizontal synchronization signal 401 from an asynchronous signal, such as SOG signals or externally sliced output 235. Since the horizontal sync 401 preserves the horizontal synchronization pulse timing of the sliced output 235, while eliminating the other pulses, i.e., equalization/serration pulses within the vertical blanking period and/or Macrovision pulses, the controller 150 may use the horizontal synchronization signal 401 to directly drive other modules within display system 100. For instance, the horizontal sync processor 402 may provide the horizontal synchronization signal 401 to a line-locked phase locked loop within an analog-to-digital converter (not shown) as a reference signal. Since the horizontal synchronization signal 401 includes only horizontal synchronization signaling, system designers may simplify the design of other modules within the display system 100, such as the line-locked phase locked loop, as they would no longer be required to ignore non-horizontal sync pulse signaling within the drive signals.
The vertical sync processor 404 generates the field detection signal 403 and the vertical synchronization signal 405 responsive to the sliced output 235. The vertical sync processor 404 includes a vertical sync detector 450 to generate the vertical synchronization signal 405 by detecting vertical sync pulses within the sliced output 235. In some embodiments, the vertical sync detector 450 may include an up/down counter (not shown separately from the vertical sync detector 450) to remove horizontal sync pulses and other pulses within digital video signal 109, e.g., equalization pulses within the vertical blanking period, prior to detecting the vertical sync pulses. The up/down counter may have a maximum count, or integration period, equal to ¼ an expected horizontal line length. The vertical sync detector 450 provides the vertical synchronization signal 405 to a sync signal generator 460.
The vertical sync detector 450 may also receive detection verification signals (not shown) from the signal processing system 200. The detection verification signals may verify to the vertical sync detector 450 that the detection of the vertical sync pulses is accurate. In some embodiments, the signal processing system 200 includes another BR filter and up/down counter (not shown), e.g., within the sync slicer 220, to directly filter the digital video signal 109 producing the detection verification signals.
The sync signal generator 460 generates and internal processing signal 465 responsive to the vertical synchronization signal 405. The internal processing signal 465 may be in-phase with the vertical synchronization signal 405, but have a pulse frequency that is substantially similar to the horizontal synchronization signaling within a typical digital video signal 109. In other words, the internal processing signal 465 may be an internally generated horizontal synchronization signal that is phase-aligned with the vertical synchronization signal 405. The sync signal generator 460 provides the internal processing signal 465 to a field detector 470. In some embodiments, the sync signal generator 460 also provides the internal processing signal 465 to the horizontal synthesizer 430 within the horizontal sync processor 402, where the horizontal synthesizer 430 may generate the horizontal synchronization signal 401 according to the internal processing signal 465. For instance, the horizontal synthesizer 430 may selectively provide the internal processing signal 465 as the horizontal synchronization signal 401 when the horizontal sync processor 402 is attempting to lock-on to the horizontal synchronization signaling of sliced output 235.
The field detector 470 generates the field detection signal 403 according to the internal processing signal 465 and the horizontal synchronization signal 401 from the horizontal sync processor 402. The field detection signal 403 may identify the polarity of interlaced fields of image data, e.g., either even or odd, according to the phase difference between the internal processing signal 465 and the horizontal synchronization signal 401.
Since the frequency of the internal processing signal 465 is substantially similar to the horizontal synchronization signaling within a typical digital video signal 109, the field detector 470 may delay the identification of the interlace field polarity until the horizontal synchronization signal 401 is stable. The field detector 470 may identify the field polarity after the horizontal synchronization signal 401 has locked-on to the digital video signal 109, thus ensuring a reasonably stable phase relationship with the internal processing signal 465. The field detector 470 may delay the identification of the field polarity until after a programmable number of horizontal signal periods, thus allowing the horizontal sync processor 402 a programmable time period after the detection of a vertical sync pulse to stabilize the horizontal synchronization signal 401.
In some embodiments, the field detector 470 may include a default setting for the field detection signal 403, e.g., set to an even field or based upon one or more previous settings, when the polarity of the field could not be determined, e.g., when the horizontal synchronization signal 401 could not lock-on to the digital video signal 109 or upon initial start-up. The field detector 470 may also be programmed to resist changing the field detection signal 403 unless a predetermine threshold of phase difference is measured between the internal processing signal 465 and the horizontal synchronization signal 401, e.g., a quarter of a horizontal line. This may be especially useful during VCR pause modes were the typical VCRs provide the same field multiple times in succession.
Although
This application is a continuation-in-part of application Ser. No. 10/851,521, filed May 20, 2004, now U.S. Pat. No. 7,365,796 which claims priority from U.S. Provisional Application Nos. 60/472,314; 60/472,312; 60/472,280; and 60/472,311, all filed May 20, 2003. We incorporate all of these applications here by reference.
Number | Name | Date | Kind |
---|---|---|---|
3860952 | Tallent et al. | Jan 1975 | A |
4196445 | Okada et al. | Apr 1980 | A |
4303939 | Stephens et al. | Dec 1981 | A |
4443821 | Kato | Apr 1984 | A |
4524389 | Isobe et al. | Jun 1985 | A |
4531154 | Hallock | Jul 1985 | A |
4555734 | Fukui | Nov 1985 | A |
4641180 | Richter | Feb 1987 | A |
4675724 | Wagner | Jun 1987 | A |
4814875 | Oldershaw | Mar 1989 | A |
4827341 | Akimoto et al. | May 1989 | A |
4855815 | Yasuki et al. | Aug 1989 | A |
4873574 | Darby | Oct 1989 | A |
4945413 | Merval et al. | Jul 1990 | A |
4987491 | Kaite et al. | Jan 1991 | A |
5097321 | Stern et al. | Mar 1992 | A |
5115454 | Kucar | May 1992 | A |
5121203 | Citta | Jun 1992 | A |
5121207 | Herrmann | Jun 1992 | A |
5134467 | Kim | Jul 1992 | A |
5142377 | Moriyama et al. | Aug 1992 | A |
5231478 | Fairhurst | Jul 1993 | A |
5260839 | Matsuta et al. | Nov 1993 | A |
5294979 | Patel et al. | Mar 1994 | A |
5345276 | Hong | Sep 1994 | A |
5355176 | Inagaki et al. | Oct 1994 | A |
5359366 | Ubukata et al. | Oct 1994 | A |
5367338 | Rothermel et al. | Nov 1994 | A |
5394193 | Kim | Feb 1995 | A |
5418818 | Marchetto et al. | May 1995 | A |
5451999 | Wesolowski | Sep 1995 | A |
5452288 | Rahuel et al. | Sep 1995 | A |
5506932 | Holmes et al. | Apr 1996 | A |
5525984 | Bunker | Jun 1996 | A |
5526129 | Ko | Jun 1996 | A |
5600379 | Wagner | Feb 1997 | A |
5619275 | Tults | Apr 1997 | A |
5686972 | Kim | Nov 1997 | A |
5710729 | Feste et al. | Jan 1998 | A |
5748842 | Holmes et al. | May 1998 | A |
5886999 | Kojima et al. | Mar 1999 | A |
5909255 | Hatano | Jun 1999 | A |
5940138 | Lowe | Aug 1999 | A |
5953071 | Van Zon | Sep 1999 | A |
5963268 | Ko | Oct 1999 | A |
5990978 | Kim et al. | Nov 1999 | A |
6052748 | Suominen et al. | Apr 2000 | A |
6173003 | Whikehart et al. | Jan 2001 | B1 |
6175389 | Felts, III et al. | Jan 2001 | B1 |
6208671 | Paulos et al. | Mar 2001 | B1 |
6297849 | Stessen et al. | Oct 2001 | B1 |
6300985 | Lowe | Oct 2001 | B1 |
6462790 | Lowe et al. | Oct 2002 | B1 |
6473134 | Nohara et al. | Oct 2002 | B1 |
6484316 | Lindberg | Nov 2002 | B1 |
6529248 | Tsyrganovich | Mar 2003 | B1 |
6581164 | Felts, III et al. | Jun 2003 | B1 |
6597404 | Moribe et al. | Jul 2003 | B1 |
6614474 | Malkin et al. | Sep 2003 | B1 |
6714717 | Lowe et al. | Mar 2004 | B1 |
6744472 | MacInnis et al. | Jun 2004 | B1 |
6774954 | Lee | Aug 2004 | B1 |
6791623 | Masuda et al. | Sep 2004 | B1 |
6795001 | Roza | Sep 2004 | B2 |
6795126 | Lee | Sep 2004 | B1 |
6804697 | Bugeja et al. | Oct 2004 | B2 |
6882360 | Zeidler | Apr 2005 | B2 |
6956620 | Na | Oct 2005 | B2 |
6958771 | Takeuchi et al. | Oct 2005 | B2 |
6985174 | Thompson et al. | Jan 2006 | B1 |
7023489 | Coste et al. | Apr 2006 | B2 |
7102692 | Carisgaard et al. | Sep 2006 | B1 |
7327399 | O'Connell | Feb 2008 | B2 |
7489338 | Huang et al. | Feb 2009 | B2 |
20010028409 | Watanabe et al. | Oct 2001 | A1 |
20030052997 | Renner et al. | Mar 2003 | A1 |
20050052576 | Johnson | Mar 2005 | A1 |
20060103760 | Johnson et al. | May 2006 | A1 |
Number | Date | Country |
---|---|---|
0449501 | Oct 1991 | EP |
0549375 | Jun 1993 | EP |
Number | Date | Country | |
---|---|---|---|
60472314 | May 2003 | US | |
60472312 | May 2003 | US | |
60472280 | May 2003 | US | |
60472311 | May 2003 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10851521 | May 2004 | US |
Child | 11361812 | US |