Aspects of the disclosure relate to audio signal processing and more particularly to audio signal enhancement and restoration.
Compressed audio signals are signals which have undergone some form of data compression by a perceptual audio codec. Perceptual audio codecs reduce the amount of data used to store, transfer, or transmit an audio signal by discarding components of the audio signal that are perceived to be less audible or less perceptually important. The data compression process often introduces undesirable audible differences between the original (uncompressed) audio signal and the compressed audio signal. Different perceptual audio codecs may employ different strategies for discarding portions of the original audio signal, but the perceived characteristics of the audible differences are typically similar.
A sampler module divides an audio signal into a series of sequential samples. A signal quality detector module identifies, over a plurality of samples at an outset of the audio signal, a spectral variance of a first range of frequencies of the audio signal below a predetermined threshold frequency as being consistently greater than a spectral variance of a second range of frequencies of the audio signal above the predetermined threshold frequency. The signal quality detector module also determines a signal treatment indication responsive to the identification. A signal enhancer module sequentially receives and analyzes one or more sample components of the audio signal to identify lost parts of the audio signal in the one or more sample components of respective sequential samples. In accordance with the signal treatment indication, the signal enhancer module generates a corresponding signal treatment for each of the one or more sample components of respective sequential samples having a corresponding identified lost part.
The system may be better understood with reference to the following drawings and description. The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention. Moreover, in the figures, like referenced numerals designate corresponding parts throughout the different views.
As required, detailed embodiments of the present invention are disclosed herein; however, it is to be understood that the disclosed embodiments are merely exemplary of the invention that may be embodied in various and alternative forms. The figures are not necessarily to scale; some features may be exaggerated or minimized to show details of particular components. Therefore, specific structural and functional details disclosed herein are not to be interpreted as limiting, but merely as a representative basis for teaching one skilled in the art to variously employ the present invention.
Compressed audio signals are signals containing audio content, which have undergone some form of data compression, such as by a perceptual audio codec. Common types of perceptual audio codecs include MP3, AAC, Dolby Digital, and DTS. These perceptual audio codecs reduce the size of an audio signal by discarding a significant portion of the audio signal. Perceptual audio codecs can be used to reduce the amount of space (memory) required to store an audio signal, or to reduce the amount of bandwidth required to transmit or transfer audio signals. It is not uncommon to compress an audio signal by 90% or more. Perceptual audio codecs can employ a model of how the human auditory system perceives sounds. In this way a perceptual audio codec can discard those portions of the audio signal which are deemed to be either inaudible or least relevant to perception of the sound by a listener. As a result, perceptual audio codecs are able to reduce the size of an audio signal while still maintaining relatively good perceived audio quality with the remaining signal. In general, the perceived quality of a compressed audio signal can be dependent on the bitrate of the compressed signal. Lower bitrates can indicate that a larger portion of the original audio signal was discarded and therefore, in general, the perceived quality of the compressed audio signal can be poorer.
There are numerous types of perceptual audio codecs and each type can use a different set of criteria in determining which portions of the original audio signal will be discarded in the compression process. Perceptual audio codecs can include an encoding and decoding process. The encoder receives the original audio signal and can determine which portions of the signal will be discarded. The encoder can then place the remaining signal in a format that is suitable for compressed storage and/or transmission. The decoder can receive the compressed audio signal, decode it, and can then convert the decoded audio signal to a format that is suitable for audio playback. In most perceptual audio codecs the encoding process, which can include use of a perceptual model, can determine the resulting quality of the compressed audio signal. In these cases the decoder can serve as a format converter that converts the signal from the compressed format (usually some form of frequency-domain representation) to a format suitable for audio playback. In one approach, perceptual audio codecs discard higher frequencies of an original audio signal (e.g., above 10 or 12 kHz) since many listeners are less sensitive to higher frequencies. Spectral Band Replication (SBR) is a technology that strives to preserve these higher frequencies, despite using a perceptual audio codec that discards such frequencies. Thus, SBR operates as an add-on to traditional perceptual audio codecs. At the time of perceptual audio codec encoding, the SBR process examines the higher frequency content of the original signal. It then creates side-chain data that is included along with the perceptual audio codec data. At the decoding end, the SBR decoder uses both the perceptual audio codec data and the side-chain data to generate an estimate of the higher frequency content of the original signal.
The Signal Enhancer system is a system that can modify a compressed audio signal that has been processed by a perceptual audio codec, such that signal components and characteristics which may have been discarded or altered in the compression process are perceived to be restored in the processed output signal. As used herein, the term audio signal may refer to either an electrical signal representative of audio content, or an audible sound, unless described otherwise.
When audio signals are compressed using a perceptual audio codec, it is impossible to retrieve the discarded signal components. However, the Signal Enhancer system can analyze the remaining signal components in a compressed audio signal, and generate new signal components to perceptually replace the discarded components.
In some cases, a quality of a source of compressed audio signals may be explicitly specified by the audio source or may be inferred based on the audio source. In an example, Satellite radio content may be known to be encoded at a particular quality and rate. In another example metadata such as the current bitrate and codec information for the audio source may be specified via a bus message or via header information of an audio file being decoded. In such cases, the Signal Enhancer may be configured to apply a treatment level based on the quality specified by the audio source. In other cases, a source quality may be unknown or not readily predictable. Some examples of such audio sources may include a music player such as an iPod, a USB drive, audio received over a Bluetooth connection, audio received via an auxiliary connection, or audio streaming from an unknown music streaming application. In such cases, the Signal Enhancer may be configured to automatically detect a treatment level that is suitable for the audio source based on characteristics of the content of the incoming audio itself.
The automatic detection may be configured to apply a proportional amount of treatment based on a measured quality of the outset of the input signal. For example, if a brickwall slope is detected (e.g., a hard cutoff of frequencies above 12 kHz), then the audio source may be considered to be compressed, and treatment may be applied. The particular amount of treatment to be applied may be based on the frequency cutoff point of the brickwall. For example, a lower cutoff frequency may indicate a relatively more compressed audio stream requiring a greater amount of treatment, while a higher cutoff frequency may indicate a relatively less compressed audio stream requiring a lesser amount of treatment. In some cases, if the cutoff frequency is below a minimum threshold, then the Signal Enhancer may determine that the audio source is too low quality to be processed and no treatment may be applied. As another possibility, if the cutoff frequency is above a maximum threshold, then the Signal Enhancer may determine that the audio source is of sufficient quality not to require treatment.
When initialized, or when a gap (e.g. mute or track change) is detected, the Signal Enhancer may reset a latch and set a detected treatment level to none. When audio initiates or resumes, the automatic detection mechanism may look for compression (e.g., by performing brickwall cutoff frequency detection). When a track is identified as compressed, the treatment level may be set (i.e., latched) such that the treatment level may remain within a narrow range until the next track. This latching may accordingly prevent pumping, variable sound, or other audible artifacts of changing treatment rates.
Additionally or alternately, after detection of a gap, a timer may begin counting. If no compression is detected within a predetermined period of time or number of samples (e.g., five seconds), then the Signal Enhancer may elect not to apply treatment until the next gap is detected. This may avoid unexpected spectral changes in the middle of a track due to sudden appearance of high frequencies and subsequent treatment level adjustment.
However, when the audio signal has been compressed with a perceptual audio codec that includes SBR, the brickwall detection approach may no longer be sufficient. This is because the SBR processing will effectively remove the brickwall rolloff of the high frequencies.
A common feature of compressed audio signals is that they exhibit many sharp (and deep) dips in their magnitude spectra. The locations (frequency) of these dips vary from one audio frame to the next. Furthermore, the severity (number and depth) of these dips tends to increase for more highly compressed audio signals. Conversely, the high frequency spectra that result from the SBR processing do not exhibit the same spectral dips. Therefore, one way to detect whether a signal has been encoded using SBR is to look for spectral dips in the lower part of the spectrum (e.g., below a threshold frequency of 10-12 kHz) versus a lack of spectral dips in the upper part of the spectrum (e.g., above the threshold frequency).
In the Signal Enhancer processing, a stereo decoded signal may be converted to the frequency domain using an FFT. As a result, the spectrum of each audio frame (e.g., 512, 1024, or 2048 samples) can be analyzed. More specifically, the magnitude spectra of the left and right input signals are computed. The SBR detector in the Signal Enhancer uses the variance of the spectrum as an objective measure of the severity of the spectral dips. The severity of the dips may be referred to herein as spectral variance. The SBR detector computes the spectral variance of the lower frequencies (e.g., a range of frequencies below a threshold of 10-12 kHz), as well as the spectral variance of the upper frequencies (e.g., a range of frequencies above the threshold of 10-12 kHz). The spectral variances of the two frequency regions are then compared. If the lower frequencies exhibit a significantly larger spectral variance (e.g., more spectral dips or more pronounced spectral dips) than the higher frequencies, then the compressed audio signal is identified as having been encoded using SBR. Otherwise, it is deemed not to have been encoded using SBR. Thus, when a track is identified as compressed using SBR, a treatment level may be set despite the lack of appearance of a brickwall.
In
The Signal Treatment Module 300 may include one or more treatment modules (301, 302, 303, 304, 305, 306, and 307), which operate on individual sample components of sequential samples of the input signal (X) to produce the Signal Treatments (310) sequentially on a sample-by-sample basis for each of the respective components. The individual sample component of the sequential samples may relate to different characteristics of the audio signal. Alternatively, or in addition, the Signal Treatment Module 300 may include additional or fewer treatment modules 300. The illustrated modules may be independent, or may be sub modules that are formed in any of various combinations to create modules.
In
In
In
With regard to the characteristic of bandwidth being a missing part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, is that they may limit the bandwidth of a compressed signal by discarding signal components above some predetermined threshold. For example, a perceptual audio codec may consider all frequency components above a predetermined frequency, such as above 12 kHz, to be less perceptually important and thus discard them. The Bandwidth Extension module 301 may operate on the input signal (X) to generate signal components, or signal treatments (ST1), above such a predetermined cut-off frequency (Fx). The Bandwidth Extension module 301 may analyze the input signal (X) to determine the cut-off frequency (Fx) of the input signal, if one exists. Knowledge of the cut-off frequency (Fx) may be used to guide the generation of a Signal Treatment stream (ST1) with new signal components above the predetermined cut-off frequency (Fx) to compensate for the absence of this characteristic in the corresponding sample components of the audio signal.
Alternatively, or in addition, in cases where side-chain information 106 is available from the perceptual audio decoder 103, as shown in
With regard to the characteristic of harmonics being a missing or lost part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, may discard certain “middle harmonics” within the compressed signal at a given point in time within the signal. For example, at some point in time, a perceptual audio codec may retain the fundamental frequency component of a particular sound source along with several lower order harmonics. The perceptual audio codec may also preserve some or all of the highest order harmonics of the signal, while discarding one or more of the middle harmonics of the sound source. The Inband Harmonic Fill module 302 may analyze the input signal (X) 104 to search for events where the perceptual audio codec has discarded one or more middle harmonics characteristics of the audio signal. The Inband Harmonic Fill module 302 may operate to generate a Signal Treatment stream (ST2) with new middle harmonics to apply to the audio signal in response to this characteristic missing from the sample components of the audio signal.
With regard to the characteristic of transients being a missing part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, may cause a “smearing” of transient signals. This type of coding artifact can be described as “pre-echo” and can most readily be heard when the transient signal has a sharp attack and is relatively loud in relation to the other signal components at the time of the transient event. Pre-echo tends to cause a perceived dulling of the transient signal components. The Transient Enhancement module 303 may seek to identify this characteristic as missing from component samples of the audio signal, and derive a signal treatment to restore the perceived sharp attack of transient signal components. The Transient Enhancement module 303 may analyze the input signal (X) and may identify transient events and transient signal components to identify the missing characteristic. The Transient Enhancement module 303 may operate to generate a Signal Treatment stream (ST3) containing new transient signal components for application to the audio signal in order to enhance the perception of the onsets of existing transient signal components.
An example method for detecting transients in an audio signal may include the following activities. The magnitudes of the FFT bins for the current block of time-domain input signal samples are computed and are stored in a history buffer. The magnitudes of the current set of FFT bins are compared to the magnitudes of a past set of FFT bins on a bin-by-bin basis, where the current set and the past set represent a series of sample components of a respective series of samples. The magnitudes of the past set of FFT bins were previously stored in the history buffer and are retrieved for this comparison. The number of bins for which the magnitude of the current FFT bin exceeds the magnitude of the past FFT bin by a predetermined threshold, such as a Magnitude Threshold, is counted. If the count exceeds a determined Count Threshold, then it is determined that the current block of time-domain samples contains a transient event. A predetermined value, such as 20 dB, may be suitable for the Magnitude Threshold for detecting transients. The past FFT bins can be taken from one or two blocks behind the current block of samples. That is, the history buffer can represent a delay of one or two processing blocks in sequential processing of sample components of a sample.
With regard to the characteristic of expansion being a missing or lost part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, may cause a perceived narrowing of the stereo soundstage perceived by a listener when the audio signal is produced as an audible sound. That is, sounds which are perceived to be located to the extreme left or right in the original uncompressed audio signal may be attenuated relative to other sounds during the compression process. As a result, the resulting audio signal may be perceived to be more “monophonic” and less “stereophonic”. The Soundstage Enhancement module 304 may identify missing or lost parts of the audio signal related to this characteristic in a series of sample components, and amplify signal components which are perceived to be located to the extreme left or right in the input signal (X) as generated signal treatments. For example, the Soundstage Enhancement module 304 may operate to extract extreme left or right signal components and generate a Signal Treatment stream (ST4) containing amplified versions of these signal components. One possible method for extracting extreme left or right signal components is described U.S. patent application Ser. No. 12/897,709 entitled “SYSTEM FOR SPATIAL EXTRACTION OF AUDIO SIGNALS”, which is herein incorporated by reference in its entirety. With regard to the characteristic of reverberation being a missing or lost part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, is that they may cause a perceived reduction in the “ambience” or “reverberation” characteristics in the audio signal. This reduction of reverberation characteristic may result in a perceived “dulling” of the overall sound, as well as a perceived loss of detail in the sound due to the lost part of the audio signal. The reduction of reverberation may also reduce the perceived size and width of the overall sound field. The Reverb Fill module 305 may operate to decompose the input signal (X) into dry and reverberant signal components. The Reverb Fill module 305 may then operate to identify the missing part of the audio signal in a corresponding sample component, increase the perceived level of the reverberation in the sample component, and generate a Signal Treatment stream (ST5) that may contain new reverberant signal components, and may contain amplified reverberant signal components for application to only those sample components of a sequence of samples in which the part of the audio signal is determined to be missing.
A possible method for decomposing the input signal (X) into dry and reverberant signal components is described in U.S. Pat. No. 8,180,067 entitled “SYSTEM FOR SELECTIVELY EXTRACTING COMPONENTS OF AN AUDIO INPUT SIGNAL,” and U.S. Pat. No. 8,036,767 entitled “SYSTEM FOR EXTRACTING AND CHANGING THE REVERBERANT CONTENT OF AN AUDIO INPUT SIGNAL,” both of which are herein incorporated by reference in their entirety.
With regard to the characteristic of mask signals being a missing or lost part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, may cause a perceived reduction in the clarity and low-level details in the signal. This may be caused by the perceptual audio codec discarding signal components which, according to, for example, a perceptual model, are believed to be inaudible to most listeners. Typically the perceptual model will identify certain first signal components as inaudible if there are other dominant signal components that may mask the first signal components. That is, due to the masking properties of the human auditory system, the dominant signal components may (mask) render the first signal components inaudible. However, each listener's masking properties are somewhat different, and the perceptual model in the perceptual audio codec can only approximate the masking properties of one listener. As a result, the perceptual audio codec may discard certain signal components which are audible to some listeners.
The Masked Signal Fill module 306 may operate to identify the missing parts of the corresponding sample components of an audio signal, and amplify low-level signal components so that they are just at the threshold of being masked. The Masked Signal Fill module 306 may receive the input signal (X) and apply a perceptual model to determine the “simultaneous masking threshold” for each frequency. The simultaneous masking threshold indicates the level at which the perceptual model determines that the signal component at a certain frequency is masked by the signal components at other frequencies. For example, a signal component at 1100 Hz may be inaudible if there is a sufficiently loud signal component at 1000 Hz. In this example, the simultaneous masking threshold indicates the level at which signal components at other frequencies (such as 1100 Hz) will be masked by the signal component at 1000 Hz. Therefore, if the level of the signal component at 1100 Hz falls below the simultaneous masking threshold, then the perceptual model determines that this signal component will be masked (inaudible).
Continuing with this example, if the Masked Signal Fill module 306 determines that the signal component at 1100 Hz falls below the simultaneous masking threshold and thereby identify lost parts of the corresponding sample components of audio signal, the Masked Signal Fill module 306 may generate a Signal Treatment stream (ST6) that may contain an amplified version of the signal component at 1100 Hz such that the signal component at 1100 Hz reaches the simultaneous masking threshold. Similarly, the Masked Signal Fill module 306 may perform this operation for signal components at all frequencies to identify missing parts of corresponding sample components, such that it may generate a Signal Treatment stream (ST6) containing amplified signal components at various frequencies so the signal components at all frequencies may reach the simultaneous masking threshold.
An example of a perceptual model for determining the simultaneous masking threshold is described in U.S. Pat. No. 8,180,067 entitled ‘SYSTEM FOR SELECTIVELY EXTRACTING COMPONENTS OF AN AUDIO INPUT SIGNAL,’ and U.S. Pat. No. 8,036,767 entitled “SYSTEM FOR EXTRACTING AND CHANGING THE REVERBERANT CONTENT OF AN AUDIO INPUT SIGNAL,” both of which are herein incorporated by reference in their entirety. In general, the perceptual model may perform smoothing based on at least one of temporal-based auditory masking estimates, and frequency-based auditory masking estimates during generation of component samples over time (such as over a number of snapshots of a component sample for a series of samples).
The phases of the fundamental and harmonic components of a harmonically rich signal can tend to track each other over time. That is the fundamental and harmonic components of a harmonically rich signal can tend to be aligned in some way. With regard to the characteristic of harmonics phase alignment being a missing or lost part of an audio signal, some perceptual audio codecs, including those operating at relatively low bitrates, may cause the phases of the harmonics of a given sound source to lose their alignment with respect to phase. This loss of phase alignment as a missing part of sample components can occur on at least the higher-order harmonics of a signal. This loss of phase alignment may be perceived by the listener in different ways. One common result of a loss of phase alignment is “swooshing” sound which is typically audible in the higher frequencies. The Harmonic Phase Alignment module 307 may operate to force harmonically related signal components to be phase-aligned over time. The Harmonic Phase Alignment module 307 may analyze the input signal (X) and look for tonal signal components (as opposed to transient or noise-like signal components) and determine if the tonal components are harmonically related. In addition, the Harmonic Phase Alignment module 307 may determine if the phases of any harmonically related tonal components are aligned over time. Where the characteristics in the corresponding sample components are identified as missing part of the audio signal, namely phase alignment of harmonically related tonal components, the phases of any harmonics which are not in alignment may be adjusted. The Harmonic Phase Alignment module 307 may generate a Signal Treatment stream (ST7) that may contain a phase-aligned version of these unaligned tonal components. Alternatively, or in addition, the Harmonic Phase Alignment module 307 may provide some other form of alignment of the tonal components.
If the input signal (X) 104 is stereo or multichannel, then it may be decomposed into spatial slices 501 prior to being processed by the Signal Enhancer 110 as described with reference to
Once the appropriate treatments have been applied to each of the spatial slices, the enhanced output streams (YSS1, YSS2, YSS3, . . . , YSSn) 502 from each of the spatial slices may be combined at a summing module 503 to produce the composite output signal (Y) on the output line 105.
The various treatments applied to the signal components in a given spatial slice may vary over time as the content of the input signal (X) changes. Using the above example, the Transient Enhancement treatment 303 may only be applied to some of the sample components in a given spatial slice during times when a transient signal component has been detected in that spatial slice.
Audio signals such as music or speech typically contain some amount of reverberation. This reverberation may be due to the room (e.g. a concert hall) in which the audio signal was recorded, or it may be added electronically. The source of the reverberation is referred to as a reverberant system. The characteristics of the reverberation are determined by the impulse response of the reverberant system. The impulse response of the reverberant system can be divided into a set of blocks. The Impulse Response Estimator 710 operates on the input signal to produce a perceptually relevant estimate of the frequency domain representation of the impulse response. Generally, the impulse response estimator may operate on the input signal to produce a block-based estimate of the impulse response. The block-based estimate of the impulse response consists of a plurality of block estimates which correspond to frequency domain estimates of the impulse response.
The so-called early reflections 606 arrive soon after the direct sound component 602 and have a different perceptual effect than the reverberant tail. These early reflections provide perceptual cues regarding the size of the acoustic space and the distance between the source of the audio signal and the microphone. The early reflections 606 are also important in that they can provide improved clarity and intelligibility to a sound. The reverberant tail also provides perceptual cues regarding the acoustic space.
An impulse response can also be viewed in the frequency domain by calculating its Fourier transform (or some other transform), and so a reverberant system can be described completely in terms of its frequency domain representation H(ω). The variable w indicates frequency. The Fourier representation of the impulse response provides both a magnitude response and a phase response. Generally speaking the magnitude response provides information regarding the relative levels of the different frequency components in the impulse response, while the phase response provides information regarding the temporal aspects of the frequency components.
The Reverb Fill Module 305 may produce a frequency domain estimate of the estimate of the magnitude of the reverberant energy in the input signal. This estimate of the magnitude of the reverberant energy is subtracted from the input signal, thus providing an estimate of the magnitude of the dry audio signal component of the input signal. The phase of the reverberant input signal is used to approximate the phase of an original dry signal. As used herein, the term “dry signal,” “dry signal component,” “dry audio signal component,” or “direct signal component” refers to an audio signal or a portion of an audio signal having almost no reverberant energy present in the audio signal. Thus the original dry signal may have almost no reverberant energy since it consists almost entirely of the direct sound impulse 602. As used herein, the terms “reverberant energy,” “reverberant input signal,” “reverberant component,” “reverberant signal component,” “reverberation component,” or “reverberation signal component” refer to the early reflections, and the reverberant tail of an audio signal. In addition, with respect to audio signals, as used herein, the term “component” or “components” refer to one or more components.
If the phase of the reverberant input signal is used to approximate the phase of an original dry signal using the entire impulse response as a whole, then it is likely that severe time-domain artifacts would be audible in the processed signal. Therefore, the Reverb Fill Module 305 can divide the estimate of the overall impulse response into blocks 608, and processing can be performed in a block-based manner. The pre-determined length of the blocks 608 can be short enough that the human ear does not perceive any time-domain artifacts due to errors in the phase of the processed output signals.
Two factors combine to determine the rate at which a reverberant input signal decays at a given frequency. The first factor is the rate of decay of the dry (i.e. non-reverberant) sound source, and the second is the rate of decay of the reverberant system. While the rate of decay of the reverberant system at a given frequency is relatively constant over time, the rate of decay of the dry sound source varies continuously. The fastest rate of decay that is possible for the input signal (X) occurs when the dry sound source stops at a given frequency, and the decay of the signal is due entirely to the decay of the reverberant system. In the example of
The Impulse Response Estimator 710 may be used to derive an estimate of the impulse response of the reverberant system of the input signal (X). One possible method for estimating the impulse response of a reverberant system of an input signal (X) is described in U.S. Pat. No. 8,180,067 entitled “SYSTEM FOR SELECTIVELY EXTRACTING COMPONENTS OF AN AUDIO INPUT SIGNAL,” and U.S. Pat. No. 8,036,767 entitled “SYSTEM FOR EXTRACTING AND CHANGING THE REVERBERANT CONTENT OF AN AUDIO INPUT SIGNAL,” both of which are herein incorporated by reference in their entirety.
Referring to
As one example of a possible Treatment Requirement Indicator, the Bandwidth Extension module 301 (
As another example, the Inband Harmonic Fill module 302 (
As another example, the Reverb Fill module 305 may provide a measure of the reverberant energy in the input signal (X), as well as an estimate of the lost reverberant energy that was discarded by the Perceptual Audio Encoder 101. Greater levels of missing reverberant energy may indicate that the input signal (X) has poorer perceived quality by a listener if the audio signal were played back.
As yet another example, the Soundstage Expansion module 304 (
As another example, the Transient Enhancement module 303 may provide an indication of missing parts of the audio signal by indicating how frequently transients occur in the input signal (X) 104. As another example, the Masked Signal Fill 306 module may examine the input signal (X) and provide an indication of how frequently signal components that fell below the simultaneous masking threshold were discarded and are therefore missing from the audio signal. If signal components are frequently missing (discarded) then this may indicate that the input signal (X) may have poorer perceived quality by a listener if the audio signal were played back.
As another example, the Harmonic Phase Alignment module 307 (
The Signal Quality Analyzer 902 may receive the Treatment Requirement Indicators and derive Signal Quality Indicators. Alternatively, or in addition, the Signal Quality Analyzer 902 may receive Meta-data from a meta-data buffer 905. The Meta-data may provide a direct indication of the perceived quality of the input signal (X). The Meta-data included in the meta-data buffer 905 may be provided by the Perceptual Audio Decoder 103, the audio signal, or some other source. Alternatively, the meta-data may be provided directly to the Signal Quality Analyzer 902, and the meta-data buffer 905 may omitted. The Meta-data may provide information regarding the origin and characteristics of the input signal including but not limited to the cut-off frequency (Fx), the length of the current processing block used by the Perceptual Audio Encoder 101, the bitrate of the input signal (X), and/or the sampling rate of the input signal (X).
Using one or more of the received Treatment Requirement Indicators and/or the Meta-data, the Signal Quality Analyzer 902 may derive an estimate of the perceived overall quality of the input signal (X). Alternatively, or in addition, Signal Quality Analyzer 902 may derive estimates of the perceived quality of the input signal with respect to the individual signal treatments.
The relative energy levels of the Signal Treatments 310 that the Signal Enhancer module 110 applies to the input signal (X) may be varied depending on the relative quality of the input signal and/or the sample components of the input signal. For example, in situations where the quality of the input signal (X) is relatively good, then the relative energy levels of the Signal Treatments 310 may be reduced. Similarly, in situations where the quality of the input signal (X) is relatively poor, then the relative energy levels of the Signal Treatments 310 may be correspondingly increased. The Treatment Level Adjuster 901 may independently alter the relative energy levels of the Signal Treatments 310 by increasing or decreasing one or more of the treatment gains (g1, g2, g3, g4, g5, g6, and g7) 315. Alternatively, or in addition, the Treatment Level Adjuster 901 may alter the total relative energy level of the Signal Treatments 310 by increasing or decreasing the total treatment gain (gT) 320.
The Treatment Level Adjuster 901 may receive as parameters one or more Signal Quality Indicators 903 from the Signal Quality Analyzer 902. The Treatment Level Adjuster 901 may use one or more of the available Signal Quality Indicators 903 to independently determine the appropriate values for each of the individual treatment gains (g1, g2, g3, g4, g5, g6, and g7) 315, as well as the appropriate value for the total treatment gain (gT) 320. Alternatively, or in addition, the Signal Quality Analyzer 902 may use Meta-data that may provide a direct indication of the perceived quality of the input signal (X) to determine the appropriate values for each of the individual treatment gains (g1, g2, g3, g4, g5, g6, and g7) 315, as well as the appropriate value for the total treatment gain (gT) 320. In this way, the levels of the various Signal Treatments 310 may be automatically adjusted to match the requirements of the input signal (X).
In some cases, Meta-data regarding the input signal (X) may be unavailable. Accordingly, the Signal Quality Analyzer 902 may utilize a compression detection and treatment algorithm that automatically readjusts the treatment levels per stream or per track. The treatment algorithm may include a Gap Detector 908, a Latch 907, an Auto Timer 909, a SBR Timer 911, and a SBR Counter 913. The Gap Detector 908 may be configured to identify gaps of silence between tracks, as well as the outset of new tracks or audio signals. The Latch 907 may be configured to selectively lock the individual treatment gains (g1, g2, g3, g4, g5, g6, and g7) 315 and the total treatment gain (gT) 320 when certain conditions are met. When a track is identified as “compressed”, the levels of the various Signal Treatments 310 are set (i.e., latched) and remain within a narrow range until the next track. This prevents pumping or variable sound. If the Gap Detector 908 detects a gap (e.g., mute or track change), the Signal Quality Analyzer 902 will reset the Latch 907 and set the levels of the various Signal Treatments 310 to none. When audio resumes within the input signal (X), the compression detection mechanism will again look for compression (brickwall, SBR, etc.).
The Auto Timer 909 may be configured to reset when a new stream or track is detected by the Gap Detector 908, and count down a predetermined amount of time at the beginning of the audio during which treatment gains may be adjusted. Accordingly, the Auto Timer 909 may be configured to avoid audible changes in a level of applied treatment in the middle of an audio stream or track. In some examples, when no compression is detected within a predetermined amount of time (e.g., 5 seconds), the levels of the various Signal Treatments 310 may remain at none until the next gap is detected. This avoids unexpected spectral change in the middle of a track due to sudden appearance of high frequencies.
Similar to the Auto Timer 909, the SBR Timer 911 may be configured to reset when a new stream or track is detected by the Gap Detector 908, and count down a predetermined amount of time or frames at the beginning of the audio during which the signal may be analyzed for SBR encoding when a brickwall is not detected. Accordingly, the SBR Timer 911 may similarly be configured to avoid audible changes in a level of applied treatment in the middle of an audio stream or track. In some examples, when no SBR treatment is detected within a predetermined amount of time (e.g., 5 seconds, a number of frames consistent with 5 seconds of audio, etc.), the levels of the various Signal Treatments 310 may remain at none until the next gap is detected.
The SBR Counter 913 may be configured to reset when a new stream or track is detected by the Gap Detector 908, and may be used to track a probability across signal frames that the signal is encoded using a SBR technique. For instance, the SBR Counter 913 may be computed as an average SBR score across previous signal frames, where each SBR score measures severity of markers of SBR encoding in a corresponding frame. In an example, to compute the SBR Counter 913, the Signal Quality Analyzer 902 may employ a decay constant such that SBR scores for more recent frames are given a greater weighting in computation of the SBR Counter 913. The SBR Counter 913 may be updated from one from to the next to provide a running measure of probability that the signal is encoded using SBR.
The Treatment Level Adjuster module 901 may also consider other parameters when determining the individual treatment gains and the total treatment gain. Thus, for example, certain of the individual treatment gains may be decreased and certain other of the individual treatment gains may be increased by the Treatment Level Adjuster module 901 based on the parameters. Such parameters may include metadata of the input signal, such as a genre of the audio signal be produced, such that, for example, for a rock music genre the transient treatment level gain may be increased to emphasize drums, and classical music genre, the reverberation treatment level gain may be increased to emphasize the music hall effect. In another example, treatment gains may be adjusted when the input signal is talk versus music. Any number of treatment level gains and parameters may be used in other examples. The gain adjustments by the Treatment Level Adjuster module 901 may also be rules based, such as when there is treatment of the characteristic of reverberation above a predetermined threshold, gain for the characteristic of transient enhancement may be correspondingly reduced based on, for example a ratio. User settings may also be applied to the Treatment Level Adjuster module 901 to effect the amount of treatment gains that are selectively applied under certain conditions or modes of operation.
Generally, the process 950 may sample a wide collection of arbitrary bins from the direct FFT input so that the monitored information is fast and up-to-date, and may compare this information to a constant gap threshold. If the average energy is less than the predetermined threshold, the process 950 may determine the input signal (X) to a mute or track change. Otherwise, process 950 proceeds to looking backwards from the Nyquist frequency at the bin energy to see if there is a significant rise in energy at a candidate frequency. The process 950 may attempt to pinpoint the top of the rise and use this point for several measurements. Above this point is considered the Noise Floor and below is the Signal Floor. The process 950 may perform several checks on the candidate cutoff frequency to determine if the candidate cutoff frequency looks similar to a brickwall, there is not significant information happening above the candidate frequency, and that candidate frequency is not just a random fluke harmonic or spike in the high frequencies. If the candidate cutoff frequency survives all the tests, it must pass them all for at least a predetermined number of frames in a row (e.g., 20 consecutive frames in an example).
Additionally, if no brickwall is detected, the process 950 performs an alternate test to determine whether the input signal (X) includes sharp, deep dips in magnitude spectra indicative of SBR processing in frequencies in a range below a SBR threshold frequency, combined with a lack of such spectral dips in frequencies in a range above the SBR threshold frequency. If the input signal displays this spectral variance in dips for at least a predetermined confidence level built up over multiple frames, then the input signal (X) is deemed to be compressed using SBR processing that effectively removes the telltale brickwall rolloff of the high frequencies.
At this point, if the input signal (X) is determined to be compressed based on either detection of the brickwall frequency or detection of spectral variance, treatment of the input signal (X) may begin ramping up. For input signals for which a brickwall cutoff is detected, the treatment may be proportional to the cutoff frequency, such that a lower cutoff means more treatment is applied to the input signal (X). Or, for input signals displaying spectral variance, the treatment may be either a constant level applied to all SBR-encoded signals, or proportional to the difference in quantity or severity of spectral dips located in the range of frequencies below the SBR threshold frequency, such that greater spectral variance results in more treatment being applied to the input signal (X). The level of treatment may persist until the track ends (or is muted). In some cases, a new cutoff frequency may supersede a previously determined cutoff frequency under various conditions, such as if the new cutoff frequency is determined to be greater than a predetermined percentage different (e.g., at least 5 percent different) and with a greater brickwall height. These conditions may accordingly prevent undesirable artifacts from constantly varying treatment levels.
More specifically, at operation 952, the Signal Quality Analyzer 902 determines whether a gap is detected in the input signal (X). In an example, the Signal Quality Analyzer 902 may wait for a Frame of valid audio. This monitoring may be performed, for example, by looking at the instantaneous value of a set of arbitrary bins in the 200 Hz-4 kHz region of the input signal (X). The Signal Quality Analyzer 902 may confirm whether a smoothed sum of these bins exceeds a pre-determined constant level of energy to determine that a new track or stream has begun. Similarly, when the bins do not or no longer exceed the pre-determined constant level of energy, the Signal Quality Analyzer 902 may identify or detect a gap. Thus, the detection of sufficient energy may be performed to ensure that the overall signal energy is above a pre-determined threshold sufficient for the brickwall and/or SBR detection to be meaningful. If a gap is detected, control passes to operation 954. If audio is begun or continuing, control passes to operation 958.
At operation 954, the Signal Quality Analyzer 902 initializes the compression detection and treatment algorithm. For example, the Signal Quality Analyzer 902 may reset the Latch 907, may set the individual treatment gains 315 and total treatment gain 320 to no gain, and may also reset the Auto Timer 909, SBR Timer 911, and SBR Counter 913.
At operation 956, the Signal Quality Analyzer 902 increments the Auto Timer 909. In an example, the Auto Timer 909 may specify an amount of time at the beginning of the track or audio during which automatic adjustments to the treatment gains 315, 320 may be performed. When the Auto Timer 909 expires, no further automatic adjustments may be performed until the next detected gap. The Signal Quality Analyzer 902 may increment the Auto Timer 909 (if enabled) at operation 954 for each frame of valid audio after the detected gap. After operation 956, control returns to operation 952.
At operation 958, the Signal Quality Analyzer 902 determines whether the Latch 907 is set. If the Latch 907 has not yet been set, control passes to operation 960. If the Latch 907 has been set (e.g., as discussed below with respect to operation 970), control passes to operation 956.
At operation 960, the Signal Quality Analyzer 902 determines whether the Auto Timer 909 has expired and no further automatic adjustments may be performed. If the Auto Timer 909 has not expired, control passes to operation 962. If the Auto Timer 909 has expired, control passes to operation 956.
At operation 962, the Signal Quality Analyzer 902 determines whether a brickwall was detected. In an example, the Signal Quality Analyzer 902 detects a candidate cutoff frequency for the input signal (X). For instance, the Signal Quality Analyzer 902 may scan frequency bins downwards from 19 kHz to 8 kHz to locate a significant rise in signal energy (e.g., at least a 4× rise in energy in the space of 1 FFT frequency bin). If a rise in signal energy is found, the Signal Quality Analyzer 902 may further locate the bin at which energy stops rising (e.g., where the energy stops rising at a rate of greater than 10% per bin). This bin where the energy stops rising may be referred to as the candidate BinX or the cutoff frequency. If the candidate passes, control passes to operation 964 to continue to evaluate the candidate brickwall frequency. If the candidate fails, control passes to operation 974 to consider spectral variance for SBR-encoded audio.
At operation 964, the Signal Quality Analyzer 902 determines whether the signal-to-noise ratio of the candidate cutoff frequency confirms the brickwall. In an example, the Signal Quality Analyzer 902 may further determine whether the frequencies of the input signal (X) above the cutoff frequency confirm the cutoff. For instance, using a 1024 point FFT, the Signal Quality Analyzer 902 may scan the frequency bins starting at 11 bins above the BinX cutoff frequency up to 19 kHz to determine if the noise floor holds any information. If the noise floor holds information, then that may indicate that the cutoff is not a true compression-induced brickwall. As a more specific example, if the noise floor rises more than 5% within 2 consecutive bins, the BinX cutoff frequency candidate may fail. If the candidate passes, control passes to operation 966 to continue to evaluate the candidate brickwall frequency. If the candidate fails, control passes to operation 956.
Additionally or alternately, in another example at operation 964, the Signal Quality Analyzer 902 determines whether the height and steepness of the candidate brickwall is above a pre-determined threshold. For instance, the Signal Quality Analyzer 902 may confirm steepness by ensuring that the candidate brickwall has at least 2.5× as much energy as the next bin. The Signal Quality Analyzer 902 may confirm height by ensuring that the current candidate brickwall is at least as high as any previously confirmed candidate brickwalls for the same audio track. If the candidate passes, control passes to operation 966. If the candidate fails, control passes to operation 956.
At operation 966, the Signal Quality Analyzer 902 determines whether the candidate brickwall is a spike or a true brickwall. In an example, Signal Quality Analyzer 902 determines whether the frequencies of the input signal (X) below the cutoff frequency confirm the cutoff. As an example, using a 1024 point FFT, the Signal Quality Analyzer 902 scans frequency bins starting at BinX-1 down to BinX-100 to locate an energy drop of more than five times. If such an energy drop is located found, then the candidate BinX may likely only be a narrow harmonic spike and not a true brickwall, and the candidate fails. If the candidate passes without detection of the energy drop below the candidate frequency, control passes to operation 968. If the candidate fails, control passes to operation 956.
At operation 968, the Signal Quality Analyzer 902 determines whether the candidate brickwall is at a persistent frequency. In an example, the Signal Quality Analyzer 902 may determine whether the current candidate BinX matches the candidate BinX. If so, the Signal Quality Analyzer 902 increments the matching frame count. If not, the Signal Quality Analyzer 902 resets the matching frame count. The matching frame count may accordingly indicate the number of frames that have successfully met all the criteria for the current candidate brickwall at BinX. The Signal Quality Analyzer 902 further determines whether the matching frame count has reached a predetermined threshold count. In an example, the predetermined threshold count may be 20 consecutive frames. If the matching frame count has reached the predetermined threshold count, then the candidate is considered to be persistent, and control passes to operation 970 to set the latch. Otherwise, control passes to operation 956.
At operation 970, the Signal Quality Analyzer 902 sets the Latch 907. At operation 972, the Signal Quality Analyzer 902 sets the treatment gains 315 and total treatment gain 320. In an example, the treatment level is set in accordance with the frequency of the brickwall BinX as a percentage based on the brickwall frequency (i.e., where a lower cutoff frequency provides for a higher level of treatment). The treatment gains 315 may set such that the treatment may be mixed in with the original audio stream at a strength equal the this percentage, and the total treatment gain 320 for the combined output may be scaled relative to treatment level; i.e., higher treatment values receive more scaling than lower treatment values, and audio which is not compressed is not scaled. Accordingly, when the Latch 907 is set, the treatment gains 315, 320 are fixed at levels determined according to the brickwall frequency. In another example, if SBR is detected (discussed in more detail below) the treatment level may be set to a predefined fixed treatment level used for SBR-encoded audio or set to a level of treatment proportional to a difference in severity of spectral dips located in the range of frequencies below the threshold frequency, such that greater spectral variance results in more treatment being applied. After operation 972, control passes to operation 956.
At operation 974, as no brickwall candidate is detected, the Signal Quality Analyzer 902 determines whether spectral variance for the Input Signal (X) exceeds a predefined threshold value. A common feature of compressed audio signals is that they exhibit many sharp (and deep) dips in their magnitude spectra.
Referring back to
More specifically, the Signal Quality Analyzer 902 scans the FFT frequency bins of the current frame in the range of frequencies below the SBR threshold frequency to locate spectral dips 982. In an example, the Signal Quality Analyzer 902 calculates mean reference levels for the bins of the Input Signal (X). In some examples, the mean reference level may be computed over the entire range of spectrum, while, in other examples, the mean reference level may be computed over the range of frequencies being analyzed. For instance, mean reference levels may be computed for each of a low-frequency range (e.g., from 20 hz to 4 kHz), a mid-frequency range (e.g., from 4 kHz to about 10-12 kHz), and high-frequency range (e.g., from about 10-12 kHz to 20 kHz). With respect to the channels for which the means reference levels are computed, the mean frequency levels may be computed for a sum of left and right channels of the Input Signal (X) (sometimes referred to as the mid channel) and also for a difference of the left and right channels of the Input Signal (X) (sometimes referred to as the side channel).
For each frequency range and channel, the Signal Quality Analyzer 902 further searches bin-by-bin to tally up how many bins fall below the expected mean level. Using the tally, the Signal Quality Analyzer 902 computes a SBR score, such that the more bins in the range of frequencies being scanned below the expected mean, the greater the SBR score. Accordingly, the Signal Quality Analyzer 902 may generate scores for each of the frequency ranges and channels being analyzed. For instance, scores may be generated for each of the low-frequency range, mid-frequency range, and high-frequency range for which mean reference levels are computed. Also similar to the mean reference level computation, the scores may be computed for mid and side channels of the Input Signal (X).
If spectral dips 982 are identified in the lower frequencies (e.g., those frequencies below the SBR threshold frequency), but are relatively absent in the higher frequencies (e.g., those frequencies above the SBR threshold frequency), then the Input Signal (X) displays spectral variance indicative of encoding of the Input Signal (X) using SBR. This is because the high frequency spectra that result from the SBR processing typically do not exhibit spectral dips 982.
A measure of the variation in frequency spectra, i.e., spectral variance, may be determined by the Signal Quality Analyzer 902 to aid in the identification of SBR encoding. For example, the Signal Quality Analyzer 902 may compare the SBR scores for the range(s) of frequencies below the SBR threshold frequency to the SBR scores for the range(s) of frequencies above the SBR threshold frequency.
As a more specific example, the scores computed for the different frequency ranges and channels are combined into a single score based on how different the scores are from one another. To do so, the scores for the mid and side channels may be averaged for each frequency range. Then, a measure of the difference of the scores from the range of frequencies below the SBR threshold frequency (e.g., the low and mid frequencies) as compared to the score for the range of frequencies above the SBR threshold frequency is computed. This measure may be referred to as the spectral variance of the Input Signal (X). As one possibility, the spectral variance may be computed as a probability from zero to one that the Input Signal (X) is encoded using SBR, such that if the computed spectral variance exceeds a predetermined threshold level, then the sample may indicate spectral variance indicative of SBR encoding. Accordingly, if spectral dips 982 are identified in the lower frequencies, but not the higher frequencies, control passes to operation 976. Otherwise, Input Signal (X) is deemed not to have been encoded using SBR, and control passes to operation 956.
At operation 976, the Signal Quality Analyzer 902 determines whether a SBR timeout counter has been exceeded. For instance, the SBR Timer 911 may specify a maximum amount of frames or time at the beginning of the track of audio during which, if no brickwall is detected, automatic determination of whether the Input Signal (X) was encoded using a SBR process is performed. In an example, the Signal Quality Analyzer 902 increments the SBR Timer 911 for each frame of valid audio after the detected gap during which no brickwall is detected and the SBR score indicates a potential for SBR encoding. The Signal Quality Analyzer 902 additionally determines at 976 whether the SBR Timer 911 has expired. When the SBR Timer 911 expires, no further determinations of SBR may be performed until the next detected gap without brickwall detection. If the SBR Timer 911 has not expired, control passes to operation 978. If the SBR Timer 911 has expired, control passes to operation 956. (It should be noted that in other examples, the SBR timer 911 and the Auto Timer 909 may be combined, and a single timeout may be used for both brickwall detection and SBR detection.)
At operation 978, the Signal Quality Analyzer 902 determines whether SBR persists in the Input Signal (X). To do so, the Signal Quality Analyzer 902 determines whether the SBR Counter 913 has exceeded a threshold spectral variance score value indicative of encoding of the Input Signal (X) using the SBR process. In an example, the SBR Counter 913 may be used to maintain a cumulative score indicative of a probability whether the Input Signal (X) was encoded using a SBR process. The SBR Counter 913 may be computed as an average of the spectral variance for the previous frames. For each frame, the Signal Quality Analyzer 902 updates the SBR Counter 913 according to the current SBR Counter 913 and the current frame spectral variance.
To compute the SBR Counter 913, the Signal Quality Analyzer 902 may employ a decay constant such that spectral variance scores for more recent frames are given a greater weighting in computation of the SBR Counter 913. Once updated, the Signal Quality Analyzer 902 compares the updated SBR Counter 913 to a threshold spectral variance score value. The threshold spectral variance score value may be set such that multiple frames indicative of SBR are required in order to meet the threshold (e.g., a few frames with high spectral variance scores, many frames with lower spectral variance scores but within the timeout period, etc.) In any event, when the SBR Counter 913 exceeds the threshold spectral variance score value, the Signal Quality Analyzer 902 determines that the Input Signal (X) was encoded using SBR. If the SBR Counter 913 exceeds the threshold spectral variance score value, the SBR encoding is considered to be persistent, and control passes to operation 978. Otherwise, control passes to operation 956.
Variations on the process 950 are possible. As an example, rather than transitioning from operation 958 to operation 956 when the Latch 907 is set, the compression detection may continue to operation 960, and the processing of operation 958 may be altered by the set Latch 907 to further cause the Signal Quality Analyzer 902 to determine whether the candidate brickwall is of a greater height than a previously established cutoff frequency for the track, or also if the candidate brickwall is within a predetermined threshold frequency of the previously established cutoff frequency. In an example, the process 950 continues so long as the Auto Timer 909 has not expired, so that if a better brickwall is detected before the Auto Timer 909 expires, that better brickwall may instead be used for latching of the treatment gains 315, 320. In an example, the better brickwall may be required to be of a brickwall height higher than the previous cutoff frequency, and be more than 5% different in frequency to supplant the previous cutoff frequency.
Notably, in the process 950, the SBR detection begins processing by looking for a brickwall roll-off in the spectrum of the compressed signal. If a brickwall is detected, then there is no need to perform SBR processing. If, however, no brickwall is detected, then the SBR detection performs the spectral variance analysis described above.
Moreover, while the process 950 is described in terms of an Input Signal (X) generally, it should be understood that the process 950 may be performed using one or more channels of the Input Signal (X). In an example, the SBR detection is performed on both left and right input channels and computes spectral variances for both channels. In an example, to satisfy the SBR detection, the Signal Quality Analyzer 902 may confirm that separate SBR Counter 913 values for each of the left and right channels each individually exceed the threshold SBR score value indicative of encoding of the Input Signal (X) using the SBR process. In another example, the Signal Quality Analyzer 902 may consider all channels to be encoded using SBR if one channel passes the threshold SBR score test. In yet another example, the Signal Quality Analyzer 902 may average a combined SBR score value using both the left and right channels, and may compare that value to the threshold SBR score to determine whether the Input Signal (X) is encoded using a SBR process. As a further example, the Signal Quality Analyzer 902 may separately determine SBR encoding of each channel individually, and may apply treatment to each channel independently.
As some other possibilities, given how many audio signals are recorded (e.g., pop music), some perceptual audio codecs may encode audio signals as mid and side channel signals instead of as left and right. Therefore, the process 950 performed by the Signal Quality Analyzer 902 may perform the spectral variance analysis and SBR detection on the mid and side channels of the Input Signal (X). In some cases, the mid and side channels (particularly the side channel) may exhibit relatively severe spectral dips 982 (and therefore large spectral variance), even though the left and right signals exhibit significantly less spectral variance. In some examples, the SBR detection is therefore performed on the left, right, mid and side signals to determine whether the compressed signal was encoded with SBR. Accordingly, if the left and/or right signals or the mid and/or side signals indicate SBR, then the Input Signal (X) may be considered to be compressed and eligible for treatment as encoded using a SBR process.
Referring back to
In a networked deployment, the computer system 1300 may operate in the capacity of a server or as a client user computer in a server-client user network environment, as a peer computer system in a peer-to-peer (or distributed) network environment, or in various other ways. The computer system 1300 can also be implemented as or incorporated into various devices, such as a telematics system, for example, in a vehicle. In other examples, any other machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine may be used. The computer system 1300 may be implemented using electronic devices that provide voice, audio, video or data communication. While a single computer system 1300 is illustrated, the term “system” may include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions.
The computer system 1300 may include a processor 1302, such as a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), or some combination of different or the same processors. The processor 1302 may be a component in a variety of systems. For example, the processor 1302 may be part of a head unit or amplifier in a vehicle. The processor 1302 may be one or more general processors, digital signal processors, application specific integrated circuits, field programmable gate arrays, digital circuits, analog circuits, combinations thereof, or other now known or later developed devices for analyzing and processing data. The processor 1302 may implement a software program, such as code generated manually or programmed.
The processor 1302 may operate and control at least a portion of the system. The term “module” may be defined to include one or more executable modules. The modules may include software, hardware, firmware, or some combination thereof executable by a processor, such as processor 1302. Software modules may include instructions stored in memory, such as memory 1304, or another memory device, that may be executable by the processor 1302 or other processor. Hardware modules may include various devices, components, circuits, gates, circuit boards, and the like that are executable, directed, or controlled for performance by the processor 1302.
The computer system 1300 may include a memory 1304, such as a memory 1304 that can communicate via a bus 1308. The memory 1304 may be a main memory, a static memory, or a dynamic memory. The memory 1304 may include, but is not limited to computer readable storage media such as various types of volatile and non-volatile storage media, including but not limited to random access memory, read-only memory, programmable read-only memory, electrically programmable read-only memory, electrically erasable read-only memory, flash memory, magnetic tape or disk, optical media and the like. In one example, the memory 1304 includes a cache or random access memory for the processor 1302. In alternative examples, the memory 1304 may be separate from the processor 1302, such as a cache memory of a processor, the system memory, or other memory. The memory 1304 may include an external storage device or database for storing data. Examples include a hard drive, compact disc (“CD”), digital video disc (“DVD”), memory card, memory stick, floppy disc, universal serial bus (“USB”) memory device, or any other device operative to store data.
The computer system 1300 may or may not further include a display unit 1310, such as a liquid crystal display (LCD), an organic light emitting diode (OLED), a flat panel display, a solid state display, a cathode ray tube (CRT), a projector, or other now known or later developed display device for outputting determined information. The display 1310 may act as an interface for the user to control the functioning of the processor 1302, or specifically as an interface with the software stored in the memory 1304.
The computer system 1300 may include an input device 1312 configured to allow a user to interact with any of the components of computer system. The input device 1312 may be a microphone to receive voice commands, a keypad, a keyboard, or a cursor control device, such as a mouse, or a joystick, touch screen display, remote control or any other device operative to interact with the computer system 1300. A user of the system may, for example, input criteria or conditions to be considered by the system and/or the telematics system.
The computer system 1300 may include computer-readable medium that includes instructions or receives and executes instructions responsive to a propagated signal so that a device connected to a network 1326 can communicate voice, video, audio, images or any other data over the network 1326. The instructions may be transmitted or received over the network 1326 via a communication port or interface 1320, or using a bus 1308. The communication port or interface 1320 may be a part of the processor 1302 or may be a separate component. The communication port 1320 may be created in software or may be a physical connection in hardware. The communication port 1320 may be configured to connect with a network 1326, external media, the display 1310, or any other components in the computer system 1300, or combinations thereof. The connection with the network 1326 may be a physical connection, such as a wired Ethernet connection or may be established wirelessly. The additional connections with other components of the computer system 1300 may be physical connections or may be established wirelessly. The network 1326 may alternatively be directly connected to the bus 1308.
The network 1326 may include wired networks, wireless networks, Ethernet AVB networks, or combinations thereof. The wireless network may be a cellular telephone network, an 802.11, 802.16, 802.20, 802.1Q or WiMax network. Further, the network 1326 may be a public network, such as the Internet, a private network, such as an intranet, or combinations thereof, and may utilize a variety of networking protocols now available or later developed including, but not limited to TCP/IP based networking protocols. One or more components of the system may communicate with each other by or through the network 1326.
While exemplary embodiments are described above, it is not intended that these embodiments describe all possible forms of the invention. Rather, the words used in the specification are words of description rather than limitation, and it is understood that various changes may be made without departing from the spirit and scope of the invention. Additionally, the features of various implementing embodiments may be combined to form further embodiments of the invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2016/024047 | 3/24/2016 | WO | 00 |