Noise suppression for audio devices is important to allow the purest form of the audio to be heard without the addition of unwanted noise, For example, some forms of noise reduction reduce the gain on specific frequencies without regard to whether there is actually noise in the audio. This can result in less than optimum audio reproduction since some of the actual audio is lost by trying to reduce the noise in the audio.
Some embodiments of the invention are described with respect to the following figures:
A system can determine when a noise would have been recorded by a microphone and only look at that time to determine if the gain for a frequency or band of frequencies should be reduced or some other way to reduce the noise on the recording. Knowing the time of the noise can increase the audio quality by not blindly reducing all audio at a particular frequency. Noise can be unwanted sound captured by a microphone.
Some systems have attempted to remove the noise by using multiple microphones where a process was applied to the recorded data comparing them and removing noise from the recording. However, if there is not a combination of two forms of the audio, the process may take out audio that was intended. If a system knows when an event occurs, the type of event, and the sound of an event, the noise generated when the event occurs can be reduced without removing other intended audio from the input. An event can be an electrical signal that relates to a function of a component and not the resulting noise from the component.
For example, if a computing system is recording an audio input with a microphone and a hard disk drive is accessed, the system knows that the hard disk drive has been accessed and that event is known to generate noise. The noise can be the arm moving to seek the correct disk track. The noise created by the hard disk drive can be known by the computer by storing a sound profile. The system can monitor the system for an event which results in noise and use the sound profile of the event to remove the noise at the point in the input recording that the event was known to have occurred to create an input recording that has reduced noise but also retains substantially all of the intended audio.
In one embodiment a computing system can include a connection to a component to perform a function and generates a noise. A microphone can receive an input including the noise. A controller in the system can monitor the component for an event related to the function that produces the noise and track the time of the event in the input.
In another embodiment, a method can remove noise from a sound input by monitoring a component for an event that produces a noise. A microphone can receive an input including the noise. A stored sound profile related to the event can be retrieved from memory. The noise can be reduced from the input using the stored sound profile.
The connection 105 may be wired such as by electrically conductive wires optical wires, or another technology. The connection 105 may be wireless such as Bluetooth, wireless fidelity (wifi) or another wireless technology.
A microphone 115 can receive an input including the noise. The input is the audio that is intended to be received by the computing system 100 though the microphone and the noise is the unintentional sounds generated by components of the system captured by the microphone 115 while receiving the intended audio. A controller 120 in the computing system 100 can monitor the component for an event related to the function that produces the noise. The controller may be a general purpose processor, an application specific processor (ASIC) or another type of controller. A monitor 125 can receive information from the component or may snoop a bus such as a Peripheral Component Interconnect express (PCIe) bus for instructions to components that result in the component performing a noise generating event. The computing system 100 can include a timer 130 to track time. The controller 120 can track the time of the event in the input. The tracked time may be relative time to the input recording or an absolute time. For example, the relative tracked time may be 2 seconds from the beginning of the input. If the tracked time is an absolute time it may be Jan. 1, 2012 at 2:00:02 GMT, the absolute time of the input would have to be tracked as vs well such beginning at Jan. 1, 2012 at 2:00:00 GMT.
The tracked time 135 may be adjusted based on variables; for example, if the monitor intercepts an instruction from a bus that has not been received by the component, the controller may apply an offset to the tracked time to account for the time that it takes for controller receiving the instruction and performing the function that results in the noise. In the case where the monitor receives from a component information of an event related to a function of the component an offset may be applied to account for the function having already be performed. The offset on the tracked time may be for example, a tenth of a millisecond plus or minus.
A memory 240 stores data 245. The memory may be volatile such as Random access memory (RAM) or non-volatile memory such as a hard disk drive, flash memory. While depicted as two components the component 210 may be the memory 240, for example, if the component 240 is a hard disk drive, it may be both the memory 240 and the component 210. The data 245 on the memory 240 may be, for example, the input, a sound profile of the noise related to an event, the tracked time of an event, the type of event.
The controller can track the type of event. For example, the type of event may be a hard disk access, the ejection of an optical disk, the plugging in of a peripheral to a port such as a USB port, the activation of a key on the keyboard, the activation of a button on a mouse, or another noise producing event that can be received by a microphone. The type of event may be related to a sound profile. The sound profile for an event may, for example, reduce the gain of the microphone for the input, apply a graphic equalizer to reduce the gain for a particular frequency band, include a time length for the noise related to the event, include a recording including a time dimension for noises that change over time such as a disk drive for fan spinning up, include an inverse of the noise used to subtracted out the noise from the input, or differences in multichannel recordings such as when a keys on a keyboard are closer to or further from the multiple microphones. The differences in multichannel recordings may account, for example, for the “a” being on one end of a keyboard and the “p” being on the opposite end of a keyboard. The sound profile may be generated by recording sounds in a controlled environment. To create a sound profile the computing system may cause a component to complete a function that generates an event while suppressing other components from performing a noise producing function and record the sound through the microphone in a controlled environment that is quiet, for example. The data can be generated about the noise such as the length of the noise, any changes in the noise over time, the frequency of the noise, or differences between multiple channels or different sound profiles each of the multiple channels, or the inverse of the noise that can be used to subtract the noise from the input. In some cases the sound profiles may be loaded on a system by a manufacturer but in other cases the sound profiles may be generated by an end user. Allowing the sound profiles to be generated by the end user can allow noise generated by a component connected to the computing system at a later time or components that were changed or sound different after age. The computing system may suggest that new sound profiles be recorded as the system ages. For example, if it is known that the hard disk drive likely will sound different after a year of use, the computing system can suggest a new sound profile for the hard disk drive be generated.
The controller 220 can use the tracked time 235 to locate the event in the input 250 and with the type of event can locate a corresponding sound profile for the event to remove the noise from the input 250 generating a noise-reduced input 255. The noise reduced input may be played back through the speaker 260 with a substantially less level of noise that was generated by the component 210.
The computing system can include transceiver 265 to transmit the input and the tracked time to a second computing system 270 for output by the second computing system 270, for example, in a teleconference system. The second computing system 270 outputs one of the input and a noise-reduced input generated from the tracked time. The second computing system 270 may include a second transceiver 275 to receive data from the computing system. The second computing system may also include a speaker 280 to output the recording input. The computing system and the second computing system may be set up to teleconference. The second computing system 270 may include a controller 285 to output one of the input and the noise-reduced input. The controller 285 may receive the noise-reduced input 265 created by the controller 220 or may receive the input and the time and type of events tracked by the controller 220. By receiving the input, tracked time of the event and the type of event can allow the second computing system to determine whether the output is of the input or the noise-reduced input. The sound profile may be sent to the second computing system 270 from the computing system 200, and may only be sent once for each type of event.
The memory 240 can store the noise-reduced input and the time tracked, wherein the input can be generated from the noise-reduced input, the time tracked and the sound profile. To reduce the amount of memory the input and the noise-reduced input may not both be stored on the memory 240. If the noise-reduced input is stored on the memory 240 the input which includes the noise may be able to be recreated from the noise-reduced input. the tracked time of an event, the type of event and the sound profile by reversing the effects of the sound profile.
The techniques described above may be embodied in a non-transitory computer-readable medium for configuring a computing system to execute the method. The computer readable media may include, for example and without limitation, any number of the following: magnetic storage media including disk and tape storage media; optical storage media such as compact disk media (e.g., CD-ROM, CD-R, etc.) and digital video disk storage media; holographic memory; nonvolatile memory storage media including semiconductor-based memory units such as FLASH memory, EEPROM, EPROM, ROM; ferromagnetic digital memories; volatile storage media including registers, buffers or caches, main memory, RAM, etc.; and the Internet, just to name a few. Other new and various types of computer-readable media may be used to store the software modules discussed herein. Computing systems may be found in many forms including but not limited to mainframes, minicomputers, servers, workstations, personal computers, notepads, personal digital assistants, various wireless devices and embedded systems, just to name a few.
In the foregoing description, numerous details are set forth to provide an understanding of the present invention. However, it will be understood by those skilled in the art that the present invention may be practiced without these details. While the invention has been disclosed with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover such modifications and variations as fall within the true spirit and scope of the invention.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2012/023117 | 1/30/2012 | WO | 00 | 5/13/2014 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2013/115768 | 8/8/2013 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7613532 | Anderson et al. | Nov 2009 | B2 |
7697699 | Ozawa | Apr 2010 | B2 |
20030187527 | Delchar et al. | Oct 2003 | A1 |
20040243405 | Casparian et al. | Dec 2004 | A1 |
20060133621 | Chen et al. | Jun 2006 | A1 |
20110125489 | Shin | May 2011 | A1 |
20110300806 | Lindahl et al. | Dec 2011 | A1 |
20150091712 | Poornachandran et al. | Apr 2015 | A1 |
Number | Date | Country |
---|---|---|
10-2003-011423 | Feb 2003 | KR |
Entry |
---|
Evaluation of IPAQTM Recordings, Aug. 28, 2002, http://www.usenix.org/event/sec02/full—papers/monrose/monrose—html/node10.html. |
International Search Report and Written Opinion received in PCT Application No. PCT/US2012/023117, mailed Oct. 24, 2012, 10 pages. |
Number | Date | Country | |
---|---|---|---|
20140307880 A1 | Oct 2014 | US |