ALSAPulseAudio

= Working with ALSA and Pulse Audio =

General

 * Sound cards don't support arbitrary sampling rates. If your audio is choppy, check the rate of your audio sink or source: 44100 Hz works under all audio cards known, 48000 Hz on many, 32000 usually does not work.
 * Don't clip: The maximum amplitude in your signal must not exceed 1.0.

Audience
Linux users wanting to get Audio in and/or out of their GNU Radio application, but are having problems.

Problem
The GNU Radio Audio sink and source use ALSA (unless ALSA support was disabled during build time). ALSA has been the standard sound API under Linux for a decade or so, so basically all programs that produce Audio know how to deal with it, or use a sound server like PulseAudio that takes care of dealing with all the low-level details for the application.

PulseAudio itself also provides a &quot;fake&quot; ALSA device, so to make ALSA applications talk to PulseAudio instead of directly with the hardware driver, allowing one central volume control etc.

However, PulseAudio's device isn't always perfect. PulseAudio is internally capable of resampling, but the results aren't always predictable. For GNU Radio applications, it's often desirable to know the raw device.

Solution
You can figure out the playback devices using the  program, that usually ships with modern linux distributions:

aplay -L yields something like

null Discard all samples (playback) or generate zero samples (capture) pulse PulseAudio Sound Server default Default ALSA Output (currently PulseAudio Sound Server) hdmi:CARD=HDMI_1,DEV=0 HDA Intel HDMI, HDMI 0 HDMI Audio Output hdmi:CARD=HDMI_1,DEV=1 HDA Intel HDMI, HDMI 1 HDMI Audio Output hdmi:CARD=HDMI_1,DEV=2 HDA Intel HDMI, HDMI 2 HDMI Audio Output sysdefault:CARD=PCH HDA Intel PCH, ALC887-VD Analog Default Audio Device front:CARD=PCH,DEV=0 HDA Intel PCH, ALC887-VD Analog Front speakers ... here, using somethig like  or   in the Audio Sink's &quot;Device&quot; property makes a lot of sense.

In analogy

arecord -L lists all recording devices.

Audience
Users wanting to process what the Sound system currently is producing

Problem
ALSA is badly documented, and PulseAudio is mainly documented through fragmented Wiki Entries, mainly done by the ArchLinux community.

Find PulseAudio monitors
PulseAudio has its own monitor &quot;ports&quot;; you can list all PulseAudio endpoints by running

pactl list We want to find monitors. Because we're too lazy to read through the nautic mile of output that  produces:

pactl list|grep &quot;Monitor Source&quot;|sed 's/^space:*Monitor Source: //g' Will give you one or more lines containing something like

alsa_output.pci-0000_00_03.0.hdmi-stereo.monitor alsa_output.pci-0000_00_1b.0.analog-stereo.monitor alsa_output.pci-0000_06_00.1.hdmi-stereo.monitor Select the right name; assuming we use the analog output, the second line would be the right.

Add ALSA Pseudodevice for monitor
Now, we need to edit (and create, if it doesn't already exist).

Add

pcm.pulse_monitor { type pulse device alsa_output.pci-0000_00_1b.0.analog-stereo.monitor }

ctl.pulse_monitor { type pulse device alsa_output.pci-0000_00_1b.0.analog-stereo.monitor } of course, replacing the  name with the correct one from the last step.

Using the newly created device
In the Audio Source block, use  as the device name: