Hi, has anyone gotten a PS3 Eye to work with Pi4 + Docker? I cannot seem to manage to set it up. Should this just work out of the box or do I need to edit .asoundrc or something inside the Docker container? Thanks
Hi @Sam
Have the same setup but with 3b+
By default ps3eye mic is a bit low, so yes, Iâve changed asoundrc to increase its volume
But it works out of the box
Try to run arecord command to check it
Thanks, arecord helped:
arecord -l
**** List of CAPTURE Hardware Devices ****
card 1: VOICE [USB Camera-B4.09.24.1], device 0: USB Audio [USB Audio]
Subdevices: 1/1
Subdevice #0: subdevice #0
I disabled the onboard audio in
/boot/config.txt
dtparam=audio=off
Now everything works fine.
Did you do anything special in mixing the four mics? This post talks about it:
Yes, Iâve changed my asoud.conf
You can try the one from your post, but Iâm using this one⌠found it a bit better. Maybe placebo effect though
pcm.jack {
type hw
card ALSA
}
pcm.array {
type hw
card CameraB409241
}
pcm.softvol {
type softvol
slave.pcm "jack"
control {
name Master
card 0
}
}
pcm.cap {
type plug
slave.pcm "array"
slave.channels 4
ttable {
0.0 15.0
1.1 15.0
}
}
pcm.!default {
type asym
playback.pcm "plug:softvol"
capture.pcm {
type plug
slave.pcm "cap"
}
}
Also note that changing asound.con on a host system doesnât affect docker. So you need to change it there too
In this article they compare it with respeaker and provide a configuration for RPI
Thanks for sharing your configs!
Could you please explain how to do that? Iâm absolutely new to docker
I switched from HassOs -> Hassio to Raspbian -> Docker - Hassios - Rhasspy still installed as Hassio addon.
Now do i shell into the Rhasspy container and edit the asound.conf - or do i copy the host asound over there?
Thanks
edit: I found your old Thread - testing now
you found a way to automate this by now ? =)
Hi @Sikk
Yes, my post is what I have now⌠unfortunately, i havenât yet work on it properly
So Iâm editing Dockerfile in rhasspy addon folder adding COPY command there, and rebuild addon
So I can reboot it at least
If you are interested in it, I will provide detailed instructions
Hey @frkos
I would really appreciate that
Right now iâm really happy with my asound.conf - snowboy seems to detect every wakeword now - without me running through the room and screaming âjarvisâ like a maniac
To keep all things together Iâve added instructions here
Hope you will find it useful
Hello!
I am trying to get PS3 Eye to get to work.
I am running x86-64 Open Media Vault and installed Rhasspy via docker.
The USB CAM is detected correctly, but when I click in test microphone, nothing happens.
It doesnât say working! as in the tutorials.
No error and no working.
Is this hardware supported? Because I read that is supported by reading the documentation, but I read posts that it isnât supported. Can someone help me out?
Should I use PyAudio as it is recommended, or because it is a PC should be arecord?
Thank you, I cannot pass this basic hurdle.
EDIT: I cannot access the console in portainer, that should help me out in basic troubleshooting.
I bought the PS3 eye used, so I also would like to test the microphone, it could not be working. The video is working because I tested it in VLC.
Ideas to test the audio? Like recording and playing the wav file also?
Thank you again.
Your running in a container that is contained and you have to declare what hardware your container should have.
Its prob not Rhasspy or Docker just how you have setup docker and rhasspy.
Sharing your snd hardware via --device /dev/snd:/dev/snd \ is usually needed but its going to be a struggle without access to the console though but give that a go, but sort of blind that way.
Hello,
Thank you for your feedback and thank you for the subject you highlighted.
I have some experience in this matter (docker/containersâŚ)
In Openmediavault host, running lsusb:
hp_admin@hpg1miniomv:~$ lsusb
Bus 003 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub
Bus 002 Device 011: ID 1415:2000 Nam Tai E&E Products Ltd. or OmniVision Technologies, Inc. Sony Playstation Eye
So it is detected
Docker compose of rhasspy:
version: â2â
services:
rhasspy:
image: ârhasspy/rhasspyâ
container_name: rhasspy
restart: unless-stopped
volumes:
- â/dev/âŚ:/profilesâ #hidden complete directory only
- â/etc/localtime:/etc/localtime:roâ
ports:
- â12101:12101â
devices:
- /dev/snd:/dev/snd
command: --user-profiles /profiles --profile en
In recording section of Rhasspy web UI:
USB Camera-B4.09.24.1: Audio (hw:0,0) (0)
So the camera is detected.
I also have a USB sound card mapped to OTHER container, streaming sound with logitech media server without any problem
LMS docker compose:
devices: - /dev/snd:/dev/snd
So I would say the question of docker and container shouldnât be a problem.
Can someone provide a next step to debug this?
EDIT: Is there a way oh enabling the console in the rhasspy docker container? To help debugging?
Usually with a running container docker exec âit nginx-test /bin/bash
as this example for nginx-test
container and you sort of âsshâ into the container usually as Root.
Likely there will be no /etc/asound.conf in the container also, but have no exp with portainer.
I tried your command without success
But thanks to your suggestion I got to know that it would be possible
so using google I found out this website
In the section Running an Interactive Shell in a Docker Container
I found this
docker exec -it container-name sh
which I adapted to
docker exec -it rhasspy sh
and now I have a âSSH likeâ access
Thank you for your idea/guidance, that I didnât now
I can confirm I donât have that file:
'# pwd
/etc
'# ls asound*
ls: cannot access âasound*â: No such file or directory
Should I create one?
In the meantime, I plugged it diretly to USB port of the PC without hub (I read somewhere this could create problems) and booting into Ubunto and using cheese I can see image of the camera.
In rhasspy usuing the test micrphones I get either timeout or nothing, no error.
Any more ideas?
Now you have console access âaplay -lâ âarecord -lâ have a look at what the containers ALSA thinks it has and share an external file as /etc/asound.conf if you need to set defaults or share a sound card if used on host or other instances
As I told before, I have a USB dongle with micrphone input and headphones output and the PS3 Eye Toy plugged in.
Both are connected to OMV (the host OS).
Just to explain the output below.
'# pwd
/
'# aplay -l
**** List of PLAYBACK Hardware Devices ****
card 1: Device [USB Audio Device], device 0: USB Audio [USB Audio]
Subdevices: 0/1
Subdevice #0: subdevice #0
This is the dongle I mentioned before.
'# arecord -l
**** List of CAPTURE Hardware Devices ****
card 0: CameraB409241 [USB Camera-B4.09.24.1], device 0: USB Audio [USB Audio]
Subdevices: 0/1
Subdevice #0: subdevice #0
card 1: Device [USB Audio Device], device 0: USB Audio [USB Audio]
Subdevices: 1/1
Subdevice #0: subdevice #0
So it detects two microphones, the USB dongle aswell the camera.
Other thing worth mentioning, when I plug the PS3 toy it appears the following file
/dev/video0
That disappears as soon as I unplug the USB.
It is video related, unrelated with the audio problem I am trying to solve, but another proof that the host OS is detecting the hardware.
Returning to you, what do you mean by this
(âŚ) and share an external file as /etc/asound.conf if you need to set defaults or share a sound card if used on host or other instances
I donât have this file at this location atm
'# pwd
/etc
'# ls asound*
ls: cannot access âasound*â: No such file or directory
Can you please explain what you were saying for me to do?
Thank you!
I was expecting there wouldnât be. With containers being ephemeral you can share a host file and mount in the container at /etc/asound.conf.
https://www.alsa-project.org/wiki/Asoundrc
You mean creating this file in the host and binding it to the container right?
You think this is the only thing the container misses to work???
I wouldnât say it doesnât work, but how you have your setup it is not working.
If you want to configure ALSA or your PS3eye then you will need a asound.conf.
Alsa is single use and blocking unless you setup dmix & dsnoop pcms via IPC.
One of your other containers could be blocking it, but now you have console access why not aplay test.wav
of an example wav you can download into the container or share as a file to test.
The added complexity of multiple containers and that alsa is blocking and non shareable unless defined in a asound.conf, its your setup.
So dunno as the PS3eye was always a pet hate of mine as the device Dev openly admits its a bad hack at reverse engineering it, that in use apps often just use the 1st mic avail.
The driver and the beamforming are algs in the PS3 not the PS3eye.
What you can do is sum all the mics in a asound.conf similar to asound-config-ps3EyeCamera/asound.conf at master ¡ straris/asound-config-ps3EyeCamera ¡ GitHub as that is a basic delay-sum beamformer and it will just be, static look ahead.
PS slightly tangental but I have the Anker C300 webcam and the NS doesnât seem to effect Whisper and its dual mic with the algs built in (dunno what is inside)
The PS3eye is bargain bin cheap nowadays and maybe should stay there, Anker do a PowerConf C200 which isnât bargain bin cheap, but on Amazon and elsewhere for ÂŁ59.99 which if the Mics work as good as the C300 (Much better than the orig Powerconf speakerphone) its actually good value.