Minimize echo and noise
Echo and noise problems are common in VoIP systems. Speech comes from the far-end speaker and echoes back with a time delay, causing perception problems. Echo cancellation decreases the echo from the far-end speaker during communication. Noise suppression decreases the noise from the microphone channel. The Fluence echo cancellation and noise suppression (ECNS) algorithm provides stationary and nonstationary noise suppression and echo cancellation. Acoustic echo is when echoes occur due to the acoustic path (acoustic coupling) between the loudspeaker and microphone of a device. It is important for hands-free and teleconferencing applications. The following figure shows the acoustic echo path and how acoustic echo occurs between loudspeakers and microphones.Noise and acoustic echo
- Echo Canceller – An adaptive filter that self-adjusts coefficients to cancel out echo. Every echo has an echo path, and is characterized by an impulse response. The echo canceller adapts to the network echo path such that it cancels out the echo.
- Noise Suppression – Single mic echo canceller and noise suppressor (SMECNS) helps to suppress the surrounding stationary noise when using devices in noisy locations.
Enable SMECNS for recording
When recording, Fluence keeps speech quality in the recording path by suppressing background noise captured by the microphone. For single-microphone recordings, only stationary noise suppression is possible. Stationary noise is where the frequency does not change over time, for example, road noise or white noise. The following figure shows how gains, SMECNS, and postprocessing modules are used to remove outside noise and echo to output clean speech.SMECNS software block for recording
- Use the
wpctl statuscommand to list available nodes. - Run
wpctl set-defaultto set the source node to the handset mic. - Run
pw-recordto start recording. The following example runs in verbose mode and saves the recording to/opt/test.wav.
Enable SMECNS for VoIP
Fluence reduces noise and eliminates echo in VoIP communication. It also suppresses noise and acoustic echo on the microphone signal. The SDK supports a PipeWire VoIP source and sink, which you can use when developing applications. The following figure shows the flow of input speech to output speech when gains, Fluence, and postprocessing modules are applied for VoIP communication.SMECNS software block for VoIP
| Set record source |
|---|
| Set playback sink |
|---|
Be sure to push a PCM file (
<FileName>.wav) to the /opt/ folder.Enable single stream multiple device playback
Configure the platform to render a single audio stream simultaneously on multiple output devices, such as a built-in speaker and a wired headset. In this mode, the audio is duplicated and the same decoded audio stream is routed to multiple active output devices concurrently, ensuring synchronized playback across all selected endpoints.- Set SELinux to permissive mode.
- Start the audio daemon.
- List available audio nodes.
- Set the default for the deep buffer node.
- Set the default for the low latency node.
- Start playback.
Enable multiple stream multiple device playback
Configure the platform to render multiple independent audio streams simultaneously on different output devices, such as a built-in speaker and a wired headset. In this mode, each audio stream is managed and routed independently, allowing distinct streams to be delivered concurrently to separate output devices without interference. This enables use cases such as parallel media playback and notification routing across multiple endpoints.- Start low latency playback.
- Start deep buffer playback.
Next steps
- Audio Addendum — Use QACT and QXDM for calibration and diagnostics
- Troubleshoot audio — Capture and analyze audio logs to resolve issues
- Customize audio graph — Modify audio graphs and PAL configuration

