On 16/03/21 09:14, Lorenzo Sutton wrote:
Dear all,
Thank you so much for all the interesting insight and suggestions :-)
Sorry if I can't answer individually for now, but I did real all the
emails, greatly appreciated. This mailing list rocks as usual ;-)
I'll try and test some of the proposed solutions trying to factor in all
of the elements and the fact that I need to try and not to
overcomplicate things for my teacher who - I imagine - is having to
set-up all of the lessons, re-schedule etc. (I'm the student here...).
I'll report back after my first remote lesson ;)
For anyone interested, it is a bit long, but hopefully interesting /
useful for other :)
For our first lesson yesterday we used Zoom for the sake of simplicity
(especially for my teacher and to facilitate their schedule). Audio
quality was decent on both ends), playing together was out of question
(but expected with any similar platform due to latency). My teacher did
point out that 'original audio' feature could improve audio quality even
more... Unfortunately, as said, it doesn't seem to be available on
Linux... Which is weird as you'd think that all of the funky 'noise
reduction' / 'echo cancellation' stuff should be 'additions' and easy
to
'turn off', not the reverse... I tried contacting Zoom but I assume they
will never answer.
In the meantime I did some tests (alone, using two laptops, see some
specs at the end) with:
- Discord [1]: sound quality was pretty good, especially after removing
all of the noise reduction, and 'auto' features and lowering to the
minimum 'voice activation' - and it does use Opus. It was not stereo
(which for bass is ok, but would be nice to have e.g. if playing a
backing track etc.). The nice thing was that video is included. I think
that in order to have more fine-grained control over audio you need to
download the client (so not using the web one), which does exist for
Linux. Both parties need to have a registered account to use this, which
might be a bit of a hassle for the other party who have to a) register
and create yet another account b) install yet another application. Also
log-in seems to require captcha and device verification (I guess due to
abuse); but this makes the sign-up process and first star quite
cumbersome. Audio is pulseaudio of course, which means pulseaudio sink
for jack. A 'mobile App' exists.
- Jami [2]: This is a P2P calling system and uses Opus. A bonus is that
it supports Jack directly. It worked ok and included video, but I did
notice a few dropouts and high CPU usage, and one end did crash at an
instance. All in all, it didn't seem the quality was much higher than
Discord. Also mono-only. But I think that's expected as this is probably
and evolution of SIP 'softphone0' clients (e.g. like Egika?). Account
creation is easy as you really just enter a name and username (no
central email registration etc. needed). It does require both parties
having an installed client. Again this last point might prove a bit of
an additional hassle. A 'mobile App' exists.
- Cleanfeed [3]: audio-only, web-only, freemium. Primarily aimed at
online broadcasting / podcasting / news. Considering that this works out
of the browser (Chrom* ones (including -ium) only officially supported
but they try to make it work also on Firefox), I was quite impressed by
the audio quality of the 'Music' setting available with the free account
(they offer even higher bitrates with the paid ones. As a bonus 'music'
is in stereo. I contacted support with a couple of questions and they
were very friendly and helpful and seem also quite knowledgeable about
Linux. The interesting feature here is that you just provide a link to
the other party who join through a browser. This being browser-based
also means you need pulseaudio and the sink if using jack (like in all
my tests). No video means setting up some other (muted) video service
for that. The browser-only link thing could make this relatively easy to
propose by just sending the link to my teacher once we start the zoom
call and having them use it for audio and mute their zoom, we shall see.
They are also quite straightforward in saying that this is not primarily
intended for online 'jamming'.
- Jamulus [4]: audio-only, realtime online jamming-oriented with public
'servers', jack-native. This was actually real fun to test and play
with. I tried some close-by servers and jammed a bit in the central one.
With 128 frames set in JACK and using Jamulus' own direct monitoring
latency was definitely acceptable and the audio quality pretty good.
Audio-quality and music-friendliness wise this is probably the nicest to
use. Only thing for a teaching setting is the public-only servers (the
documentation mentions 'private' ones, but I haven't looked into if this
is possible without actually 'hosting' a server), there is a workaround
via soloing or muting others, but I don't think most teachers (nor
students) would feel comfortable with anyone possibly coming in and
listening to the lesson. Also video should be provided via some other
tool and, of course, all parties need to have the software installed.
That said this software is really well made and fun to use.
(aside note there were a couple of 'troll' events in one of the public
servers, and although they say don't feed the trolls 'audio trolling'
can hurt your ears... Not sure how this could be solved, maybe some
'reputation' system like on Stack overflow or similar.. but that does
have its flaws.. and it's another topic :-)
In all tests my set-up was the following:
Hardware:
- Bass -> cheap Bass DI [balanced out] -> ZOOM H5 in | [H5 also
providing microphone input via the included X/Y mics (so in 4-track mode]
In all cases the Laptop I hooked the ZOOM H5 to was connected via
network cable to the router. I'm also using (since about 1 week) an FTTH
connection. With the exception of Jamulus, I also tried connecting the
other test laptop via thetering 4G just to test what the other user
would potentially hear, and the results were always pretty good (I did
not however test the reverse).
Software:
- Jack
- Zoom H5 shows 4 inputs in jack: the L/R mics and the inputs 1 and 2
- Where Jack was natively supported mic1+2 and input 3 were sent to the
application
- Where Jack was not supported I added the pulseaudio sink (I always
start that manually via a script I have since ages), with similar routing.
- All of the software (with the exception of Cleanfeed which is
web-based), I was able to find packaged for Manjaro either in the
official repositories or in AUR.
Things I'd like to try but din't have the chance to, yet:
- SonoBus [5]
- SoundJack [6]
- JackTrip [7]
[1]:
https://discord.com/
[2]:
https://jami.net/
[3]:
https://cleanfeed.net/
[4]:
https://jamulus.io/
[5]:
https://sonobus.net/
[6]:
https://www.soundjack.eu/
[7]:
https://ccrma.stanford.edu/groups/soundwire/software/jacktrip/