Introduction
A while ago, I released the .NET version of the Peak Meter control but one thing I quickly discovered is that many developers would not know how to use it in their own application. This is the reason for this update. I will present the various components that are involved in order to show audio meter in real-time.
Description
Real-time Peak Meter processing is composed of three blocks.
- The source: Source of audio data, this can be a microphone, a digital sound file (CD audio) or even a video if you consider grabbing the audio part of it. Whatever your source the principle is the same, you will have to convert the data to a format that is suitable for Signal Processing.
- DSP Processing: What I'm calling DSP processing block here is the component that is responsible to convert the audio data to peak amplitude format.
- Peak Meter rendering: This is basically the rendering control (just like the Peak Meter control of this article). The rendering engine doesn't have to be all fancy like this control. A progress control can be used to show Peak audio. In fact, if you look around Windows control panel, this is exactly what is being used.
Audio Source
The microphone is the most basic audio source that you can think of.
Basically the previous figure illustrates how your computer receives digital samples of the sound that is produced from the microphone. The way the whole process works is that you specify the format that you wish to receive the data, mostly PCM data (Pulse Code Modulation) and the audio capture device will collect the samples based on sampling frequency. PCM data and WAVE chunks are common terms to describe the data that is obtained from the ADC (Analog to Digital Converter).
For example to digitize audio samples from a microphone at 22050 Hz single channel audio (mono) and 16 bits resolution; and let's say you want to receive samples every 100 ms, you will have to provide a buffer of 4410 bytes (22050*(16/8)*0.1).
I mentioned previously about file source. A file source is simply an audio data storage that gives you quick access to your samples. Audio formats like: MP3, WMA and Ogg Vorbis; all they do is compressing the data while trying to maintain the audio quality.
DSP Processing
DSP processing is a very interesting subject to learn and work with. This block receives digital samples from the source. It approximates the original waveform and finds its peak magnitudes.
Since I would not be able to go in details about how FFT (Fast Fourier Transform) works in this article, I recommend the interested reader to visit some of the links in the reference section to increase his/her knowledge about this process.
FFT plays an important role in signal processing and is probably one of the most written subjects in software engineering. When dealing with digital system, the ADC (Analog to Digital Converter) gives us a set of digital audio samples (discrete signal). The theory behind it tells us that when we perform a DFT (Discrete Fourier Transform) on a discrete signal, we find its composant frequencies including their phase and amplitude. I would like to direct the advanced reader that I'm not talking only about pure sine wave where only the fundamental is visible but performing a DFT (or FFT) on audio signal generally produces some amplitudes on nearby bin frequencies.
Now all we have left to do is find the range of frequencies for our analysis. According to the sampling theorem we can approximate the maximum audio frequency in our signal. The Nyquist theorem states that the baseband Fs > 2B, which means the sampling frequency (digital) must be at least twice any frequency in the range of B frequencies (analog) in order to reconstruct the original signal and prevent aliasing. Aliasing is the effect that causes a different signal to be indistinguishable (or aliases of one another) when sampled. Thus, if we sample at 44.1KHz (audio CD quality), we could capture the entire range of sound (roughly 20KHz).
Note that the sampling frequency needs to be at least twice our max frequency, using 44.1KHz to digitize a 20KHz sine waves improves our spectrum analysis by getting a few more samples than necessary.
Peak Meter Rendering
Peak Meter is just a "piece of cake" since the DSP block takes all the burden of what has to be done. What we do next is that we select a group of frequencies and display the amplitude of their closest bin frequencies. Peak Meter control can be as simple as using a progress control. But I guess we like to be fancy from time to time! The PeakMeter control presented here does just that.
It is best to choose frequencies in the range below because they are typically found in normal conversation and music.
Using PeakMeter in .NET
You can use the .NET version of this control in WinForms applications. Just add it to your toolbox and drag and drop it to your WinForm canvas. Here's a summary of the properties for this control:
PeakMeterControl Properties
Property | Description |
MeterStyle | Show Meter bands in Horizontal (PMS_Horizontal ) or Vertical (PMS_Vertical ) |
ShowGrid | Show meter background grid |
ColoredGrid | Show meter background grid using color schemes |
GridColor | Background grid color (when ColoredGrid property is false ) |
ColorNormal | Low range color |
ColorNormalBack | Low range color Background (ColoredGrid=1 ) |
ColorMedium | Medium range color |
ColorMediumBack | Medium range color Background (ColoredGrid=1 ) |
ColorHigh | High range color |
ColorHighBack | High range color Background (ColoredGrid=1 ) |
BandsCount | Number of bands |
LEDCount | Number of LED per bands (when 1, band is smooth) |
FalloffSpeed | Falloff effect speed (1=fast, 10=normal, 100=slow) |
FalloffEffect | Enable falloff effect, call Start() to run |
FalloffColor | Falloff line color |
PeakMeterControl Methods
Name | Description |
bool Start(int delay) | Start animation (delay in ms). Can be called from non-UI thread. |
bool Stop() | Stop animation. Can be called from non-UI thread. |
void SetMeterBands(int bands, int led) | Set meter bands properties and number of LED in one call. |
void SetRange(int min, int med, int max) | Change meter control default range. |
bool SetData(int[] values, int offset, int size) | Set peak meter data. Can be called from non-UI thread. |
Using the PeakMeter
Using this control is very straightforward, add it to your toolbox and drop it to your form. You can use the Start
method to animate the falloff effect. The demo fills the data with random numbers.
private void FillMeterData()
{
int[] meters1 = new int[NumLEDS];
Random rand = new Random();
for (int i = 0; i < meters1.Length; i++)
{
meters1[i] = rand.Next(0, 100);
}
this.peakMeterCtrl1.SetData(meters1, 0, meters1.Length);
}
SoundStudio Demo
SoundStudio Application is a simple sound player application capable of playing various audio files (.wav, .mp3, and .wma). It uses the WindowsMedia .NET library to parse the audio.
SoundStudioCS (C# version) can be built using the unmanaged DLL (FFTLib.dll). Simply add USE_FFTLIB to your project build settings (Build->General tab).
Some of the features of WindowsMedia .NET (Release) are:
- Microsoft WAVE device support (
waveInOpen
, waveOutOpen
) - DirectShow Filters, including sample grabber filter
- Microsoft Multimedia Streaming Interfaces
References
History
- 09/04/2008: Updated all samples (+WindowsMedia release)
- 08/13/2008: SoundStudio Release (include WindowsMedia pre-release)
- 05/24/2008: First revision for .NET