Data storage device employing adaptive feed-forward control in timing loop to compensate for vibration

Information

  • Patent Grant
  • 9111575
  • Patent Number
    9,111,575
  • Date Filed
    Thursday, October 23, 2014
    10 years ago
  • Date Issued
    Tuesday, August 18, 2015
    9 years ago
Abstract
A data storage device is disclosed comprising a head actuated over a disk and a vibration detector configured to generate a vibration signal in response to a vibration affecting the data storage device. A timing loop is configured to generate a disk-locked clock substantially synchronized to a rotation frequency of the disk. An adaptation control signal is generated based on the vibration signal and an error signal of the timing loop. An adaptive filter is adapted based on the adaptation control signal, wherein the adaptive filter filters the vibration signal to generate feed-forward compensation values. The feed-forward compensation values are applied to the timing loop to compensate for the vibration.
Description
BACKGROUND

Disk drives comprise a disk and a head connected to a distal end of an actuator arm which is rotated about a pivot by a voice coil motor (VCM) to position the head radially over the disk. The disk comprises a plurality of radially spaced, concentric tracks for recording user data sectors and servo sectors. The servo sectors comprise head positioning information (e.g., a track address) which is read by the head and processed by a servo control system to control the actuator arm as it seeks from track to track.



FIG. 1 shows a prior art disk format 2 as comprising a number of servo tracks 4 defined by servo sectors 60-6N recorded around the circumference of each servo track. Each servo sector 6i comprises a preamble 8 for storing a periodic pattern, which allows proper gain adjustment and timing synchronization of the read signal, and a sync mark 10 for storing a special pattern used to symbol synchronize to a servo data field 12. The servo data field 12 stores coarse head positioning information, such as a servo track address, used to position the head over a target data track during a seek operation. Each servo sector 6i further comprises groups of servo bursts 14 (e.g., N and Q servo bursts), which are recorded with a predetermined phase relative to one another and relative to the servo track centerlines. The phase based servo bursts 14 provide fine head position information used for centerline tracking while accessing a data track during write/read operations. A position error signal (PES) is generated by reading the servo bursts 14, wherein the PES represents a measured position of the head relative to a centerline of a target servo track. A servo controller processes the PES to generate a control signal applied to a head actuator (e.g., a voice coil motor) in order to actuate the head radially over the disk in a direction that reduces the PES.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows a prior art disk format comprising a plurality of servo tracks defined by servo sectors.



FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a head actuated over a disk and a vibration detector configured to generate a vibration signal in response to a vibration affecting the data storage device.



FIG. 2B shows a timing loop according to an embodiment configured to generate a disk-locked clock substantially synchronized to a rotation frequency of the disk.



FIG. 2C is a flow diagram according to an embodiment wherein an adaptation control signal is generated based on the vibration signal and an error signal of the timing loop, an adaptive filter is adapted based on the adaptation control signal, wherein the adaptive filter filters the vibration signal to generate feed-forward compensation values, and the feed-forward compensation values are applied to the timing loop to compensate for the vibration.



FIG. 3 shows a timing loop according to an embodiment wherein a finite impulse response (FIR) filter is adapted according to a Filtered-X Least Mean Square (LMS) algorithm.



FIG. 4 shows a timing loop according to an embodiment wherein the vibration signal is filtered to generate a compensated vibration signal, and an adaptation control signal is generated based on the compensated vibration signal and the error signal.



FIG. 5 shows a timing loop according to an embodiment wherein the vibration detector comprises a vibration sensor configured to generate a sensor signal, and a pre-compensation filter (PCF) filters the sensor signal to generate the vibration signal, wherein the PCF compensates for a transfer function of the vibration sensor.



FIG. 6A shows a data storage device in the form of a disk drive according to an embodiment comprising a head having at least a first read element and a second read element.



FIG. 6B shows an embodiment wherein a first wedge-to-wedge time is generated based on the first read element, and a second wedge-to-wedge time is generated based on the second read element.



FIG. 6C is a flow diagram according to an embodiment wherein a nominal wedge-to-wedge time is generated based on the first wedge-to-wedge time and the second wedge-to-wedge time.



FIG. 7A shows an embodiment wherein a disk-locked clock is substantially synchronized to a rotation frequency of the disk based on the nominal wedge-to-wedge time.



FIG. 7B shows an embodiment wherein the nominal wedge-to-wedge time is generated by averaging the first and second wedge-to-wedge times.





DETAILED DESCRIPTION


FIG. 2A shows a data storage device in the form of a disk drive according to an embodiment comprising a head 16 actuated over a disk 18 and a vibration detector configured to generate a vibration signal in response to a vibration affecting the disk drive. The disk drive further comprises control circuitry 20 including a timing loop (FIG. 2B) configured to generate a disk-locked clock 22 substantially synchronized to a rotation frequency of the disk 18. The control circuitry 20 is configured to execute the flow diagram of FIG. 2C, wherein an adaptation control signal is generated based on the vibration signal and an error signal of the timing loop (block 24). An adaptive filter is adapted based on the adaptation control signal, wherein the adaptive filter filters the vibration signal to generate feed-forward compensation values (block 26). The feed-forward compensation values are applied to the timing loop to compensate for the vibration (block 28).


In the embodiment of FIG. 2B, the timing loop for generating the disk-locked clock 22 comprises a suitable compensator C 30 and a suitable plant P 32. The compensator C 30 may implement any suitable compensation algorithm, including non-linear algorithms. Similarly any suitable plant P 32 may be employed, wherein in the embodiment of FIG. 2B the plant P 32 comprises a frequency generator 34A for generating the disk-locked clock 22 and counter 34B that counts a number of cycles at a frequency fk of the disk-locked clock 22 over an interval tk between data recorded on the disk (e.g., servo data). The number of cycles 35 counted over the interval tk is subtracted from a target number of cycles 36 of a base frequency f0 counted over a target interval t0 to generate a timing error 38. The timing error 38 is filtered by the timing loop compensator C 30 to generate a timing control signal 40 used to adjust the frequency fk until the number of cycles at the frequency fk counted over the interval tk equals the target number of cycles of the base frequency f0 counted over the target interval t0. In one embodiment, a vibration affecting the disk drive may induce a delta in the rotation velocity of the disk 18 which may induce a timing jitter into the timing loop. Accordingly, in one embodiment feed-forward compensation values 42 are generated at block 44 which adjust the control signal 40 in order to compensate for the vibration.


The disk locked clock 22 may be employed in any suitable manner in the disk drive, such as to open a servo gate relative to servo data written on the disk, timing when to servo write a concentric servo sector, and/or servo write a concentric servo sector at the correct frequency. In another embodiment, the disk-locked clock 22 may be used to write/read data to data sectors in data tracks on the disk 18 during normal access operations, wherein during read operations the disk-locked clock 22 may be synchronized when reading a preamble at the beginning of each data sector as well as synchronized when reading user data from a data sector.



FIG. 3 shows an embodiment wherein a vibration 46 induces a disturbance d 48 into the timing loop, wherein the disturbance d 48 has an unknown transfer function G150A relative to the amplitude of the vibration 46. The vibration 46 also affects the vibration detector 52 relative to a transfer function G250B. The vibration detector 52 generates a vibration signal 54 in response to the vibration 46. Any suitable vibration detector 52 may be employed, such as a suitable piezoelectric transducer. In another embodiment, the vibration detector 52 may comprise a servo loop that servos the head 16 over the disk 18 based on servo data, wherein the vibration signal 54 may comprise, for example, a position error signal (PES) of the servo loop. Block 56 generates an adaptation control signal 58 based on the vibration signal 54 and the error signal 38 of the timing loop. An adaptive filter 60 is adapted based on the adaptation control signal 58, wherein the adaptive filter 60 filters the vibration signal 54 to generate the feed-forward compensation values 42.



FIG. 4 shows an embodiment wherein the vibration signal 54 is processed by a filter 62 representing a torque rejection curve of the timing loop to generate a compensated vibration signal 64. The adaptation control signal 58 is generated based on the compensated vibration signal 64 and the error signal 38. In the embodiment of FIG. 4, the adaptive filter 60A comprises a finite-impulse-response (FIR) filter comprising a plurality of coefficients Wk that are adapted using a Filtered-X Least Mean Square (LMS) algorithm 56A which attempts to minimize E(ek2) based on:

Wk+1=WkXkek

where μ represents a learning coefficient, Xk represents the compensated vibration signal 64 after being filtered by filter GTRC 62 (torque rejection curve of the timing loop), and ek represents the timing loop error signal 38.



FIG. 5 shows an embodiment wherein the vibration detector 52 comprises a vibration sensor 66 configured to generate a sensor signal 68, and a pre-compensation filter (PCF) 70 configured to filter the sensor signal 68 to generate the vibration signal 54, wherein the PCF 70 compensates for a transfer function of the vibration sensor 66. For example, in one embodiment the PCF 70 may compensate for a phase response of the vibration sensor 66 (e.g., a phase lag or lead) as well as the effect of G1 and G2 so that the vibration signal 54 better represents the actual vibration 46 affecting the disk drive. In one embodiment, the PCF 70 reduces the complexity of the adaptive filter 60A used to generate the feed-forward compensation values 42 in the timing loop. For example, in the embodiment of FIG. 5 the PCF 70 may reduce the number of coefficients Wk of the adaptive FIR filter 60A needed to compensate for the vibrations 46.



FIG. 6A shows a data storage device in the form of a disk drive according to an embodiment comprising a head 72 actuated over a disk 74 comprising a plurality of servo sectors 760-76N defining servo tracks 78, wherein the head 72 (FIG. 6B) comprises a first read element 80A and a second read element 80B. The disk drive further comprises control circuitry 82 configured to execute the flow diagram of FIG. 6C wherein a first wedge-to-wedge time is measured (block 84) representing a time between consecutive servo sectors passing under the first read element as the disk rotates. A second wedge-to-wedge time is measured (block 86) representing a time between consecutive servo sectors passing under the second read element as the disk rotates. A nominal wedge-to-wedge time is generated (block 88) based on the first wedge-to-wedge time and the second wedge-to-wedge time.


In the embodiment of FIG. 6A, the control circuitry 82 processes a read signal 90 emanating from the head 72 to demodulate the servo sectors 760-76N and generate a position error signal (PES) representing an error between the actual position of the head and a target position relative to a target track. The control circuitry 82 filters the PES using a suitable compensation filter to generate a control signal 92 applied to a voice coil motor (VCM) 94 which rotates an actuator arm 96 about a pivot in order to actuate the head 72 radially over the disk 74 in a direction that reduces the PES. The servo sectors 760-76N may comprise any suitable head position information, such as a track address for coarse positioning and servo bursts for fine positioning. The servo bursts may comprise any suitable pattern, such as an amplitude based servo pattern or a phase based servo pattern.


In one embodiment, the control circuitry 82 comprises a timing loop such as shown in FIG. 2B described above for generating a disk-locked clock 22 substantially synchronized to a rotation frequency of the disk 74. In one embodiment, the counter 34B shown in FIG. 2B counts a number of cycles at a frequency fk of the disk-locked clock 22 over an interval tk representing the wedge-to-wedge times. For example, in one embodiment the counter 34B counts the number of cycles at the frequency fk to measure the first wedge-to-wedge time (WTWT_1) shown in FIG. 6B, as well as counts the number of cycles at the frequency fk to measure the second wedge-to-wedge time (WTWT_2) shown in FIG. 6B.


In one embodiment shown in FIG. 7A, the counter 34B counts the number of cycles at the frequency fk between when a first sync mark is detected in a first servo sector and when a second sync mark is detected in a second, following servo sector. The corresponding wedge-to-wedge time is measured for each of the first and second read elements 80A and 80B, and the resulting wedge-to-wedge times are processed to generate a nominal wedge-to-wedge time 35 used to generate the error signal 38. In one embodiment shown in FIG. 7B, the wedge-to-wedge times measured for each read element are averaged in order to generate the nominal wedge-to-wedge time 35. FIG. 7B also illustrates that the head 72 may comprise any suitable number of read elements for generating a corresponding wedge-to-wedge time that are processed to generate the nominal wedge-to-wedge time. The wedge-to-wedge times may be processed using any suitable statistical analysis, such as by omitting outliers, so that the result of processing multiple wedge-to-wedge times provides a more accurate timing measurement for updating the timing loop.


Any suitable control circuitry may be employed to implement the flow diagrams in the above embodiments, such as any suitable integrated circuit or circuits. For example, the control circuitry may be implemented within a read channel integrated circuit, or in a component separate from the read channel, such as a disk controller, or certain operations described above may be performed by a read channel and others by a disk controller. In one embodiment, the read channel and disk controller are implemented as separate integrated circuits, and in an alternative embodiment they are fabricated into a single integrated circuit or system on a chip (SOC). In addition, the control circuitry may include a suitable preamp circuit implemented as a separate integrated circuit, integrated into the read channel or disk controller circuit, or integrated into a SOC.


In one embodiment, the control circuitry comprises a microprocessor executing instructions, the instructions being operable to cause the microprocessor to perform the flow diagrams described herein. The instructions may be stored in any computer-readable medium. In one embodiment, they may be stored on a non-volatile semiconductor memory external to the microprocessor, or integrated with the microprocessor in a SOC. In another embodiment, the instructions are stored on the disk and read into a volatile semiconductor memory when the disk drive is powered on. In yet another embodiment, the control circuitry comprises suitable logic circuitry, such as state machine circuitry.


In various embodiments, a disk drive may include a magnetic disk drive, an optical disk drive, etc. In addition, while the above examples concern a disk drive, the various embodiments are not limited to a disk drive and can be applied to other data storage devices and systems, such as magnetic tape drives, solid state drives, hybrid drives, etc. In addition, some embodiments may include electronic devices such as computing devices, data server devices, media content storage devices, etc. that comprise the storage media and/or control circuitry as described above.


The various features and processes described above may be used independently of one another, or may be combined in various ways. All possible combinations and subcombinations are intended to fall within the scope of this disclosure. In addition, certain method, event or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate. For example, described tasks or events may be performed in an order other than that specifically disclosed, or multiple may be combined in a single block or state. The example tasks or events may be performed in serial, in parallel, or in some other manner. Tasks or events may be added to or removed from the disclosed example embodiments. The example systems and components described herein may be configured differently than described. For example, elements may be added to, removed from, or rearranged compared to the disclosed example embodiments.


While certain example embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions disclosed herein. Thus, nothing in the foregoing description is intended to imply that any particular feature, characteristic, step, module, or block is necessary or indispensable. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the embodiments disclosed herein.

Claims
  • 1. A data storage device comprising: a disk;a head actuated over the disk;a vibration detector configured to generate a vibration signal in response to a vibration affecting the data storage device; andcontrol circuitry comprising a timing loop configured to generate a disk-locked clock substantially synchronized to a rotation frequency of the disk, the control circuitry configured to: generate an adaptation control signal based on the vibration signal and an error signal of the timing loop;adapt an adaptive filter based on the adaptation control signal, wherein the adaptive filter filters the vibration signal to generate feed-forward compensation values; andapply the feed-forward compensation values to the timing loop to compensate for the vibration.
  • 2. The data storage device as recited in claim 1, wherein the control circuitry is further configured to: filter the vibration signal to generate a compensated vibration signal; andgenerate the adaptation control signal based on the compensated vibration signal and the error signal.
  • 3. The data storage device as recited in claim 2, wherein filtering the vibration signal to generate the compensated vibration signal comprises filtering the vibration signal with a filter representing a torque rejection curve of the timing loop.
  • 4. The data storage device as recited in claim 2, wherein the control circuitry is operable to adapt the adaptive filter according to: Wk+1=Wk+μ∥ Xkek where:Wk represents coefficients of the adaptive filter;μ represents a learning coefficient;Xk represents the compensated vibration signal; andek represents the error signal.
  • 5. The data storage device as recited in claim 1, wherein the vibration detector comprises: a vibration sensor configured to generate a sensor signal; anda pre-compensation filter (PCF) configured to filter the sensor signal to generate the vibration signal, wherein the PCF compensates for a transfer function of the vibration sensor.
  • 6. A data storage device comprising: a disk comprising a plurality of servo sectors defining servo tracks;a head actuated over the disk, the head comprising a first read element and a second read element; andcontrol circuitry configured to: measure a first wedge-to-wedge time representing a time between consecutive servo sectors passing under the first read element as the disk rotates;measure a second wedge-to-wedge time representing a time between consecutive servo sectors passing under the second read element as the disk rotates; andgenerate a nominal wedge-to-wedge time based on the first wedge-to-wedge time and the second wedge-to-wedge time.
  • 7. The data storage device as recited in claim 6, wherein the control circuitry is further configured to generate the nominal wedge-to-wedge time based on an average of the first wedge-to-wedge time and the second wedge-to-wedge time.
  • 8. The data storage device as recited in claim 6, wherein the control circuitry is further configured to generate a disk-locked clock substantially synchronized to a rotation frequency of the disk based on the nominal wedge-to-wedge time.
  • 9. A method of operating a data storage device, the method comprising: using a timing loop to generate a disk-locked clock substantially synchronized to a rotation frequency of the disk;generating an adaptation control signal based on a vibration signal and an error signal of the timing loop;adapting an adaptive filter based on the adaptation control signal, wherein the adaptive filter filters the vibration signal to generate feed-forward compensation values; andapplying the feed-forward compensation values to the timing loop to compensate for the vibration.
  • 10. The method as recited in claim 9, further comprising: filtering the vibration signal to generate a compensated vibration signal; andgenerating the adaptation control signal based on the compensated vibration signal and the error signal.
  • 11. The method as recited in claim 10, wherein filtering the vibration signal to generate the compensated vibration signal comprises filtering the vibration signal with a filter representing a torque rejection curve of the timing loop.
  • 12. The method as recited in claim 10, further comprising adapting the adaptive filter according to: Wk+1=Wk+μ Xkek where:Wk represents coefficients of the adaptive filter;μ represents a learning coefficient;Xk represents the compensated vibration signal; andek represents the error signal.
  • 13. The method as recited in claim 9, further comprising filtering a sensor signal generated by a vibration sensor to generate the vibration signal, wherein the filtering compensates for a transfer function of the vibration sensor.
  • 14. A method of operating a data storage device, the method comprising: measuring a first wedge-to-wedge time representing a time between consecutive servo sectors passing under a first read element as a disk rotates;measuring a second wedge-to-wedge time representing a time between consecutive servo sectors passing under a second read element as the disk rotates; andgenerating a nominal wedge-to-wedge time based on the first wedge-to-wedge time and the second wedge-to-wedge time.
  • 15. The method as recited in claim 14, further comprising generating the nominal wedge-to-wedge time based on an average of the first wedge-to-wedge time and the second wedge-to-wedge time.
  • 16. The method as recited in claim 14, further comprising generating a disk-locked clock substantially synchronized to a rotation frequency of the disk based on the nominal wedge-to-wedge time.
US Referenced Citations (396)
Number Name Date Kind
5245599 Ishii et al. Sep 1993 A
5299075 Hanks Mar 1994 A
5333138 Richards et al. Jul 1994 A
5654840 Patton et al. Aug 1997 A
5663847 Abramovitch Sep 1997 A
5923487 Carlson et al. Jul 1999 A
5956307 Koudo et al. Sep 1999 A
6014283 Codilian et al. Jan 2000 A
6052076 Patton, III et al. Apr 2000 A
6052250 Golowka et al. Apr 2000 A
6067206 Hull et al. May 2000 A
6078453 Dziallo et al. Jun 2000 A
6091564 Codilian et al. Jul 2000 A
6094020 Goretzki et al. Jul 2000 A
6101065 Alfred et al. Aug 2000 A
6104153 Codilian et al. Aug 2000 A
6115200 Allen et al. Sep 2000 A
6122133 Nazarian et al. Sep 2000 A
6122135 Stich Sep 2000 A
6141175 Nazarian et al. Oct 2000 A
6160368 Plutowski Dec 2000 A
6181502 Hussein et al. Jan 2001 B1
6195222 Heminger et al. Feb 2001 B1
6198584 Codilian et al. Mar 2001 B1
6198590 Codilian et al. Mar 2001 B1
6204988 Codilian et al. Mar 2001 B1
6243223 Elliott et al. Jun 2001 B1
6275592 Vartiainen Aug 2001 B1
6281652 Ryan et al. Aug 2001 B1
6285521 Hussein Sep 2001 B1
6292320 Mason et al. Sep 2001 B1
6310742 Nazarian et al. Oct 2001 B1
6320718 Bouwkamp et al. Nov 2001 B1
6342984 Hussein et al. Jan 2002 B1
6347018 Kadlec et al. Feb 2002 B1
6369972 Codilian et al. Apr 2002 B1
6369974 Asgari et al. Apr 2002 B1
6414813 Cvancara Jul 2002 B2
6429990 Serrano et al. Aug 2002 B2
6460803 Kiss et al. Oct 2002 B1
6462896 Codilian et al. Oct 2002 B1
6476996 Ryan Nov 2002 B1
6484577 Bennett Nov 2002 B1
6493169 Ferris et al. Dec 2002 B1
6496324 Golowka et al. Dec 2002 B1
6498698 Golowka et al. Dec 2002 B1
6507450 Elliott Jan 2003 B1
6534936 Messenger et al. Mar 2003 B2
6538839 Ryan Mar 2003 B1
6545835 Codilian et al. Apr 2003 B1
6549359 Bennett et al. Apr 2003 B1
6549361 Bennett et al. Apr 2003 B1
6560056 Ryan May 2003 B1
6568268 Bennett May 2003 B1
6574062 Bennett et al. Jun 2003 B1
6577465 Bennett et al. Jun 2003 B1
6614615 Ju et al. Sep 2003 B1
6614618 Sheh et al. Sep 2003 B1
6636377 Yu et al. Oct 2003 B1
6674600 Codilian et al. Jan 2004 B1
6690536 Ryan Feb 2004 B1
6693764 Sheh et al. Feb 2004 B1
6707635 Codilian et al. Mar 2004 B1
6710953 Vallis et al. Mar 2004 B1
6710966 Codilian et al. Mar 2004 B1
6714371 Codilian Mar 2004 B1
6714372 Codilian et al. Mar 2004 B1
6724564 Codilian et al. Apr 2004 B1
6731450 Codilian et al. May 2004 B1
6735041 Codilian et al. May 2004 B1
6738220 Codilian May 2004 B1
6747837 Bennett Jun 2004 B1
6754021 Kisaka et al. Jun 2004 B2
6760186 Codilian et al. Jul 2004 B1
6788483 Ferris et al. Sep 2004 B1
6791785 Messenger et al. Sep 2004 B1
6795262 Codilian et al. Sep 2004 B1
6795268 Ryan Sep 2004 B1
6819518 Melkote et al. Nov 2004 B1
6826006 Melkote et al. Nov 2004 B1
6826007 Patton, III Nov 2004 B1
6847502 Codilian Jan 2005 B1
6850383 Bennett Feb 2005 B1
6850384 Bennett Feb 2005 B1
6853512 Ozawa Feb 2005 B2
6867944 Ryan Mar 2005 B1
6876508 Patton, III et al. Apr 2005 B1
6882496 Codilian et al. Apr 2005 B1
6885514 Codilian et al. Apr 2005 B1
6900958 Yi et al. May 2005 B1
6900959 Gardner et al. May 2005 B1
6903897 Wang et al. Jun 2005 B1
6909574 Aikawa et al. Jun 2005 B2
6914740 Tu et al. Jul 2005 B1
6914743 Narayana et al. Jul 2005 B1
6920004 Codilian et al. Jul 2005 B1
6924959 Melkote et al. Aug 2005 B1
6924960 Melkote et al. Aug 2005 B1
6924961 Melkote et al. Aug 2005 B1
6934114 Codilian et al. Aug 2005 B1
6934135 Ryan Aug 2005 B1
6937420 McNab et al. Aug 2005 B1
6937423 Ngo et al. Aug 2005 B1
6950271 Inaji et al. Sep 2005 B2
6950273 Nakagawa et al. Sep 2005 B2
6950274 Inaji et al. Sep 2005 B2
6952318 Ngo Oct 2005 B1
6952322 Codilian et al. Oct 2005 B1
6954324 Tu et al. Oct 2005 B1
6958881 Codilian et al. Oct 2005 B1
6958882 Kisaka Oct 2005 B2
6963465 Melkote et al. Nov 2005 B1
6965488 Bennett Nov 2005 B1
6967458 Bennett et al. Nov 2005 B1
6967804 Codilian Nov 2005 B1
6967811 Codilian et al. Nov 2005 B1
6970319 Bennett et al. Nov 2005 B1
6972539 Codilian et al. Dec 2005 B1
6972540 Wang et al. Dec 2005 B1
6972922 Subrahmanyam et al. Dec 2005 B1
6975480 Codilian et al. Dec 2005 B1
6977789 Cloke Dec 2005 B1
6980389 Kupferman Dec 2005 B1
6987636 Chue et al. Jan 2006 B1
6987639 Yu Jan 2006 B1
6989954 Lee et al. Jan 2006 B1
6992848 Agarwal et al. Jan 2006 B1
6992851 Cloke Jan 2006 B1
6992852 Ying et al. Jan 2006 B1
6995941 Miyamura et al. Feb 2006 B1
6999263 Melkote et al. Feb 2006 B1
6999267 Melkote et al. Feb 2006 B1
7006320 Bennett et al. Feb 2006 B1
7016134 Agarwal et al. Mar 2006 B1
7016141 Bahirat et al. Mar 2006 B2
7023637 Kupferman Apr 2006 B1
7023640 Codilian et al. Apr 2006 B1
7027256 Subrahmanyam et al. Apr 2006 B1
7027257 Kupferman Apr 2006 B1
7035026 Codilian et al. Apr 2006 B2
7046472 Melkote et al. May 2006 B1
7050249 Chue et al. May 2006 B1
7050254 Yu et al. May 2006 B1
7050258 Codilian May 2006 B1
7054094 Zhang et al. May 2006 B2
7054098 Yu et al. May 2006 B1
7061714 Yu Jun 2006 B1
7064918 Codilian et al. Jun 2006 B1
7068451 Wang et al. Jun 2006 B1
7068459 Cloke et al. Jun 2006 B1
7068461 Chue et al. Jun 2006 B1
7068463 Ji et al. Jun 2006 B1
7088547 Wang et al. Aug 2006 B1
7095579 Ryan et al. Aug 2006 B1
7110208 Miyamura et al. Sep 2006 B1
7110214 Tu et al. Sep 2006 B1
7113362 Lee et al. Sep 2006 B1
7113365 Ryan et al. Sep 2006 B1
7116505 Kupferman Oct 2006 B1
7126776 Warren et al. Oct 2006 B1
7126781 Bennett Oct 2006 B1
7139401 Culman et al. Nov 2006 B2
7141951 Hosono et al. Nov 2006 B2
7142385 Shimotono et al. Nov 2006 B2
7154690 Brunnett et al. Dec 2006 B1
7158329 Ryan Jan 2007 B1
7158334 Iwashiro Jan 2007 B2
7180703 Subrahmanyam et al. Feb 2007 B1
7184230 Chue et al. Feb 2007 B1
7196864 Yi et al. Mar 2007 B1
7199966 Tu et al. Apr 2007 B1
7203021 Ryan et al. Apr 2007 B1
7209321 Bennett Apr 2007 B1
7212364 Lee May 2007 B1
7212374 Wang et al May 2007 B1
7215504 Bennett May 2007 B1
7224546 Orakcilar et al. May 2007 B1
7248426 Weerasooriya et al. Jul 2007 B1
7251098 Wang et al. Jul 2007 B1
7253582 Ding et al. Aug 2007 B1
7253989 Lau et al. Aug 2007 B1
7265931 Ehrlich Sep 2007 B2
7265933 Phan et al. Sep 2007 B1
7265934 Takaishi Sep 2007 B2
7282346 Fruehauf Oct 2007 B2
7289288 Tu Oct 2007 B1
7298574 Melkote et al. Nov 2007 B1
7301717 Lee et al. Nov 2007 B1
7304819 Melkote et al. Dec 2007 B1
7319570 Jia et al. Jan 2008 B2
7330019 Bennett Feb 2008 B1
7330327 Chue et al. Feb 2008 B1
7333280 Lifchits et al. Feb 2008 B1
7333290 Kupferman Feb 2008 B1
7339761 Tu et al. Mar 2008 B1
7365932 Bennett Apr 2008 B1
7382563 Saitoh et al. Jun 2008 B2
7388728 Chen et al. Jun 2008 B1
7391583 Sheh et al. Jun 2008 B1
7391584 Sheh et al. Jun 2008 B1
7405898 Eleftheriou et al. Jul 2008 B2
7423833 Sutardja Sep 2008 B1
7433143 Ying et al. Oct 2008 B1
7440210 Lee Oct 2008 B1
7440225 Chen et al. Oct 2008 B1
7450334 Wang et al. Nov 2008 B1
7450336 Wang et al. Nov 2008 B1
7453661 Jang et al. Nov 2008 B1
7457071 Sheh Nov 2008 B1
7466509 Chen et al. Dec 2008 B1
7468855 Weerasooriya et al. Dec 2008 B1
7471483 Ferris et al. Dec 2008 B1
7477471 Nemshick et al. Jan 2009 B1
7480116 Bennett Jan 2009 B1
7486470 Semba Feb 2009 B1
7489464 McNab et al. Feb 2009 B1
7489472 Abrishamchian et al. Feb 2009 B2
7492546 Miyamura Feb 2009 B1
7495857 Bennett Feb 2009 B1
7499236 Lee et al. Mar 2009 B1
7502192 Wang et al. Mar 2009 B1
7502195 Wu et al. Mar 2009 B1
7502197 Chue Mar 2009 B1
7505223 McCornack Mar 2009 B1
7529057 Sutardja May 2009 B1
7542225 Ding et al. Jun 2009 B1
7548392 Desai et al. Jun 2009 B1
7551390 Wang et al. Jun 2009 B1
7558016 Le et al. Jul 2009 B1
7561365 Noguchi et al. Jul 2009 B2
7573670 Ryan et al. Aug 2009 B1
7576941 Chen et al. Aug 2009 B1
7580212 Li et al. Aug 2009 B1
7583470 Chen et al. Sep 2009 B1
7595953 Cerda et al. Sep 2009 B1
7595954 Chen et al. Sep 2009 B1
7596795 Ding et al. Sep 2009 B2
7599144 Suh et al. Oct 2009 B2
7602575 Lifchits et al. Oct 2009 B1
7616399 Chen et al. Nov 2009 B1
7619844 Bennett Nov 2009 B1
7626782 Yu et al. Dec 2009 B1
7630162 Zhao et al. Dec 2009 B2
7633704 Supino et al. Dec 2009 B2
7639447 Yu et al. Dec 2009 B1
7656604 Liang et al. Feb 2010 B1
7656607 Bennett Feb 2010 B1
7660067 Ji et al. Feb 2010 B1
7663835 Yu et al. Feb 2010 B1
7675707 Liu et al. Mar 2010 B1
7679854 Narayana et al. Mar 2010 B1
7688534 McCornack Mar 2010 B1
7688538 Chen et al. Mar 2010 B1
7688539 Bryant et al. Mar 2010 B1
7697233 Bennett et al. Apr 2010 B1
7697234 Higashino et al. Apr 2010 B2
7701661 Bennett Apr 2010 B1
7710676 Chue May 2010 B1
7715138 Kupferman May 2010 B1
7729079 Huber Jun 2010 B1
7733189 Bennett Jun 2010 B1
7746592 Liang et al. Jun 2010 B1
7746594 Guo et al. Jun 2010 B1
7746595 Guo et al. Jun 2010 B1
7760461 Bennett Jul 2010 B1
7777982 Kim et al. Aug 2010 B2
7796353 Schabes et al. Sep 2010 B2
7800853 Guo et al. Sep 2010 B1
7800856 Bennett et al. Sep 2010 B1
7800857 Calaway et al. Sep 2010 B1
7808739 Takasaki et al. Oct 2010 B2
7839591 Weerasooriya et al. Nov 2010 B1
7839595 Chue et al. Nov 2010 B1
7839600 Babinski et al. Nov 2010 B1
7843662 Weerasooriya et al. Nov 2010 B1
7852588 Ferris et al. Dec 2010 B1
7852592 Liang et al. Dec 2010 B1
7864481 Kon et al. Jan 2011 B1
7864482 Babinski et al. Jan 2011 B1
7869155 Wong Jan 2011 B1
7876522 Calaway et al. Jan 2011 B1
7876523 Panyavoravaj et al. Jan 2011 B1
7916415 Chue Mar 2011 B1
7916416 Guo et al. Mar 2011 B1
7916420 McFadyen et al. Mar 2011 B1
7916422 Guo et al. Mar 2011 B1
7929238 Vasquez Apr 2011 B1
7961422 Chen et al. Jun 2011 B1
8000053 Anderson Aug 2011 B1
8027119 Zhang Sep 2011 B2
8031423 Tsai et al. Oct 2011 B1
8054022 Ryan et al. Nov 2011 B1
8059357 Knigge et al. Nov 2011 B1
8059360 Melkote et al. Nov 2011 B1
8072703 Calaway et al. Dec 2011 B1
8077428 Chen et al. Dec 2011 B1
8078901 Meyer et al. Dec 2011 B1
8081395 Ferris Dec 2011 B1
8085020 Bennett Dec 2011 B1
8116023 Kupferman Feb 2012 B1
8145934 Ferris et al. Mar 2012 B1
8179626 Ryan et al. May 2012 B1
8189286 Chen et al. May 2012 B1
8213106 Guo et al. Jul 2012 B1
8254222 Tang Aug 2012 B1
8300348 Liu et al. Oct 2012 B1
8315005 Zou et al. Nov 2012 B1
8320069 Knigge et al. Nov 2012 B1
8351174 Gardner et al. Jan 2013 B1
8358114 Ferris et al. Jan 2013 B1
8358145 Ferris et al. Jan 2013 B1
8390367 Bennett Mar 2013 B1
8432031 Agness et al. Apr 2013 B1
8432629 Rigney et al. Apr 2013 B1
8451697 Rigney et al. May 2013 B1
8482873 Chue et al. Jul 2013 B1
8498076 Sheh et al. Jul 2013 B1
8498172 Patton, III et al. Jul 2013 B1
8508881 Babinski et al. Aug 2013 B1
8531798 Xi et al. Sep 2013 B1
8537486 Liang et al. Sep 2013 B2
8542455 Huang et al. Sep 2013 B2
8553351 Narayana et al. Oct 2013 B1
8564899 Lou et al. Oct 2013 B2
8576506 Wang et al. Nov 2013 B1
8605382 Mallary et al. Dec 2013 B1
8605384 Liu et al. Dec 2013 B1
8610391 Yang et al. Dec 2013 B1
8611040 Xi et al. Dec 2013 B1
8619385 Guo et al. Dec 2013 B1
8630054 Bennett et al. Jan 2014 B2
8630059 Chen et al. Jan 2014 B1
8634154 Rigney et al. Jan 2014 B1
8634283 Rigney et al. Jan 2014 B1
8643976 Wang et al. Feb 2014 B1
8649121 Smith et al. Feb 2014 B1
8654466 McFadyen Feb 2014 B1
8654467 Wong et al. Feb 2014 B1
8665546 Zhao et al. Mar 2014 B1
8665551 Rigney et al. Mar 2014 B1
8670206 Liang et al. Mar 2014 B1
8687312 Liang Apr 2014 B1
8693123 Guo et al. Apr 2014 B1
8693134 Xi et al. Apr 2014 B1
8699173 Kang et al. Apr 2014 B1
8711027 Bennett Apr 2014 B1
8717696 Ryan et al. May 2014 B1
8717699 Ferris May 2014 B1
8717704 Yu et al. May 2014 B1
8724245 Smith et al. May 2014 B1
8724253 Liang et al. May 2014 B1
8724524 Urabe et al. May 2014 B2
8737008 Watanabe et al. May 2014 B1
8737013 Zhou et al. May 2014 B2
8737014 Massarotti et al. May 2014 B2
8743495 Chen et al. Jun 2014 B1
8743503 Tang et al. Jun 2014 B1
8743504 Bryant et al. Jun 2014 B1
8749904 Liang et al. Jun 2014 B1
8760796 Lou et al. Jun 2014 B1
8767332 Chahwan et al. Jul 2014 B1
8767343 Helmick et al. Jul 2014 B1
8767354 Ferris et al. Jul 2014 B1
8773787 Beker Jul 2014 B1
8779574 Agness et al. Jul 2014 B1
8780473 Zhao et al. Jul 2014 B1
8780477 Guo et al. Jul 2014 B1
8780479 Helmick et al. Jul 2014 B1
8780489 Gayaka et al. Jul 2014 B1
8792202 Wan et al. Jul 2014 B1
8797664 Guo et al. Aug 2014 B1
8797673 Supino Aug 2014 B2
8804267 Huang et al. Aug 2014 B2
8824081 Guo et al. Sep 2014 B1
8824262 Liu et al. Sep 2014 B1
8896955 Chen et al. Nov 2014 B1
8922938 Chen et al. Dec 2014 B1
20020153451 Kiss et al. Oct 2002 A1
20040080860 Inaji et al. Apr 2004 A1
20040213100 Iwashiro Oct 2004 A1
20040240101 Inaji et al. Dec 2004 A1
20050088774 Bahirat et al. Apr 2005 A1
20050096793 Takeuchi May 2005 A1
20060291087 Suh et al. Dec 2006 A1
20060291101 Takaishi Dec 2006 A1
20070064334 Jia et al. Mar 2007 A1
20080174900 Abrishamchian et al. Jul 2008 A1
20090135516 Takasaki et al. May 2009 A1
20100035085 Jung et al. Feb 2010 A1
20100061007 Matsushita et al. Mar 2010 A1
20100079906 Wile et al. Apr 2010 A1
20100284546 DeBrunner et al. Nov 2010 A1
20120284493 Lou et al. Nov 2012 A1
20130120870 Zhou et al. May 2013 A1
20130141811 Hirano et al. Jun 2013 A1
20130148240 Ferris et al. Jun 2013 A1
Foreign Referenced Citations (1)
Number Date Country
2001-266466 Sep 2001 JP
Non-Patent Literature Citations (8)
Entry
Chi, H., et al., “Band-limited feedback cancellation with a modified filtered-XLMS algorithm for hearing aids,” Elsevier, Speech Communication 39, 2003, pp. 147-161.
L. Hakansson, “The Filtered-x LMS Alogrithm”, Department of Telecommunications and Signal Processing, University of Karlskrona/Rooneby, 372 25 Ronneby, Sweden, Jan. 15, 2004.
Widrow, B., et al., “Adaptive Noise Cancelling”: Principles and Applications, Proceedings of the IEEE, vol. 63 (12), 1975, pp. 1692-1716.
Widrow, B., et al., “On Adaptive Inverse Control,” Record of the Fifteenth Asilomar Conference on Circuits, Systems and Computers, Nov. 1981, pp. 185-189.
Young-Hoon Kim, et al., U.S. Appl. No. 13/862,320, filed Apr. 12, 2013, 20 pages.
Jifang Tian, et al., U.S. Appl. No. 13/458,863, filed Apr. 27, 2012, 23 pages.
Kuang-Yang Tu, et al., U.S. Appl. No. 13/927,096, filed Jun. 25, 2013, 18 pages.
Jianguo Zhou, et al., U.S. Appl. No. 14/099,886, filed Dec. 6, 2013, 22 pages.