the Chromium logo

The Chromium Projects

Chamelium audio streaming

Introduction

Chamelium provides capturing and streaming feature so user can monitor audio playing from ChromeOS for a long time.

This document provides the steps to demo this feature.

Prepare a Chromebook with tick noise

Install an image on ChromeOS such that there will be tick noise caused by underrun.

Kevin image R57-9178.0.0 is a good example.

Play sine tone on Chromebook

Play a sine tone video on youtube, e.g. 1HR 528Hz sine tone Listen to it using headphone and find there is tick noise.

Connect the audio path

Connect the Chromebook to Chamelium audio board using 4 ring audio cable.

Connect Chamelium blue port (LineIn) to audio board blue port using 3 ring audio cable.

image image image

Find Chamelium's IP

Connect the USB serial port to workstation.

Refer to network setup to get the IP address of Chamelium.

Connect to Chamelium server

Assume the IP address of Chamelium is 192.168.100.4

In Chromium OS chroot, use test_server script to connect to Chamelium server.

$ cd ~/trunk/src/platform/chameleon/

$ ./client/test_server.py --chameleon_host=192.168.100.4

2017-03-07 17:36:47,219:INFO:Connected to http://192.168.100.4:9992 with MAC address 94:eb:2c:00:01:41

2017-03-07 17:36:47,219:INFO:In interactive shell, p is the proxy to chameleond server

2017-03-07 17:36:47,287:INFO:

Port 1 is DP.

Port 2 is DP.

Port 3 is HDMI.

Port 4 is VGA.

Port 5 is Mic.

Port 6 is LineIn.

Port 7 is LineOut.

Port 8 is USBIn.

Port 9 is USBOut.

Port 10 is USBKeyboard.

Port 11 is USBTouch.

Port 14 is ClassicBluetoothMouse.

Port 17 is Unknown.

E.g.

p.StartCapturingAudio(6) to capture from LineIn.

p.StopCapturingAudio(6) to stop capturing from LineIn.

p.Plug(3) to plug HDMI.

p.Unplug(3) to unplug HDMI.

Python 2.7.10 (default, Oct 23 2016, 07:38:19)

[GCC 4.9.x 20150123 (prerelease)] on linux2

Type "help", "copyright", "credits" or "license" for more information.

(InteractiveConsole)

>>>

>>> ConnectCrosToLineIn()

>>> p.StartCapturingAudio(6, False)

>>> DetectAudioValue0()

2017-03-07 17:46:27,219:INFO:connecting to 192.168.100.4:9994

2017-03-07 17:46:27,222:DEBUG:Major 1, minor 0

2017-03-07 17:46:27,222:INFO:dump realtime audio page mode Best effort

2017-03-07 17:46:27,224:INFO:Start to detect continuous 0s.

2017-03-07 17:46:27,224:INFO:Channels=[0, 1], margin=0.010000, continuous_samples=5, duration=3600 seconds, dump_frames=48000.

2017-03-07 17:46:27,224:WARNING:Receive error code 7, 'Drop realtime audio page 52183'

2017-03-07 17:46:27,225:INFO:Value of channel 0 is 0.125715

2017-03-07 17:46:27,225:INFO:Value of channel 1 is 0.123948

2017-03-07 17:46:27,225:INFO:Value of channel 0 is 0.134183

2017-03-07 17:46:27,225:INFO:Value of channel 1 is 0.132190

2017-03-07 17:46:27,225:INFO:Value of channel 0 is 0.142132

2017-03-07 17:46:27,226:INFO:Value of channel 1 is 0.140410

2017-03-07 17:46:27,226:INFO:Value of channel 0 is 0.149582

2017-03-07 17:46:27,226:INFO:Value of channel 1 is 0.147740

2017-03-07 17:46:27,226:INFO:Value of channel 0 is 0.156259

2017-03-07 17:46:27,226:INFO:Value of channel 1 is 0.154545

2017-03-07 17:46:27,226:INFO:Value of channel 0 is 0.162134

2017-03-07 17:46:27,226:INFO:Value of channel 1 is 0.160298

2017-03-07 17:46:27,226:INFO:Value of channel 0 is 0.167443

2017-03-07 17:46:27,226:INFO:Value of channel 1 is 0.165158

2017-03-07 17:46:27,226:INFO:Value of channel 0 is 0.171803

2017-03-07 17:46:27,227:INFO:Value of channel 1 is 0.169648

2017-03-07 17:46:27,227:INFO:Value of channel 0 is 0.175156

2017-03-07 17:46:27,227:INFO:Value of channel 1 is 0.173238

2017-03-07 17:46:27,227:INFO:Value of channel 0 is 0.178005

2017-03-07 17:46:27,227:INFO:Value of channel 1 is 0.175745

2017-03-07 17:46:28,102:WARNING:Detected continuous 5 0s of channel 0

2017-03-07 17:46:28,102:WARNING:Detected continuous 5 0s of channel 1

2017-03-07 17:46:28,103:WARNING:Save to detect0_20170307174627/audio_52511.wav

2017-03-07 17:46:28,105:WARNING:Continuous 139 0s of channel 0

2017-03-07 17:46:28,106:WARNING:Continuous 140 0s of channel 1

2017-03-07 17:46:28,106:WARNING:Save to detect0_20170307174627/audio_52512.wav

...

The monitoring will keep running.

Adjust volume on Chromebook, or adjust the parameter of detector

If there is false alarm, adjust the volume on Chromebook to make it louder, or use a smaller value for margin passed to DetectAudioValue0.

Use help function to get the docstrings of DetectAudioValue0:

>>>help(DetectAudioValue0)

Help on function DetectAudioValue0 in module main:

DetectAudioValue0(channels=None, margin=0.01, continuous_samples=5, duration=3600, dump_samples=48000)

Detects if Chameleon captures continuous audio data close to 0.

This function will get the audio streaming data from stream server and will

check if the audio data is close to 0 by the margin parameter.

-margin < value < margin will be considered to be close to 0.

If there are continuous audio samples close to 0 in the streamed data,

test_server will log it and save the audio data to a wav file.

E.g.

>>> ConnectCrosToLineIn()

>>> p.StartCapturingAudio(6, False)

>>> DetectAudioValue0(duration=24*3600, margin=0.001)

Args:

channels: Array of audio channels we want to check.

E.g. [0, 1] means we only care about channel 0 and channel 1.

margin: Used to decide if the value is closed to 0. Maximum value is 1.

continuous_samples: When continuous_samples samples are closed to 0, trigger

event.

duration: The duration of monitoring in seconds.

dump_samples: When event happens, how many audio samples we want to

save to file.

Check the recorded defect waveform

Use audacity to view the wav file.

The first wav file is where underrun is detected.

Press the black arrow on the left of a channel and select Spectrogram so the part where waveform dropped to zero is obvious.

The second wav file is where normal playback is resumed.