While the song is playing it is beneficial to sound quality to reduce other system activity that would normally occur: reading song bytes from storage or network.
The best way to do this is to preload the whole song to RAM before playing. Euphony tries to do that whenever possible but the exact functionality and extent of buffering depend on several factors:
I will try to cover all possible combinations and explain what exactly happens in terms of buffering a song to RAM.
Stylus player will preload local songs to RAM before playing only if the 'Buffer before play = 100%' option is enabled.
Online songs will be always buffered to RAM (regardless of 100% buffer option) but if a new song is added to the queue and the play starts immediately then the buffering will happen during playback. Buffering happens at max network speed so this network activity will go in parallel to playback for at least 5-10 seconds of playback - depending on your network speed, song quality and song length.
However, if you just add the song to the queue and you wait until it is downloaded in full and only then you start the playback, the song will play without any additional network activity - it will be fully played from RAM from the start to end.
This is also valid for the next song if you add at least two songs. Second song will be also downloaded in the background at the same time so if you add at least 2 songs to the queue from online sources you will have to wait until both are fully buffered to have a chance at 'clean' 100% buffered playback.
Note that if you add more than 2 songs to queue and you wait until first two are fully buffered before playback in the moment when first finishes and second starts playing the download of the third song will start in the background and you will not have a clean playback of the second or any of the following songs in the queue except the last one.
Stylus also has 'Buffer albums added to queue' setting and 'Buffer queue' command. This setting only has an effect on local songs.
These will both do the same thing - buffer all songs present in the queue to RAM. However, if you add the album with Add & Play the playback of the first song will start without waiting for the whole album to be buffered so your first song will not play in a clean way (but all others will). Of course, it is possible that the whole queue or the whole album added to the queue will not fit in available free RAM. In that case buffering will stop when there is not enough space. Songs that were not buffered will be buffered at the moment when they are next to play (remember that Stylus always buffer current and the next song).
While it would be easy to implement the buffering of the whole online album we are just not allowed to do that with the API we are using.
When HQPe is enabled in Stylus and the source is Qobuz the file will be downloaded fully to RAM before actual playback (this is because we noticed that HQPe sometimes won't play Qobuz song urls). Tidal songs played through HQPe will not be buffered at all.
When Stylus output device is UPnP Renderer endpoint Euphony will fully buffer an online song before offering playback url to the UPnP Renderer. Playback URL offered is local url pointing to the song location in RAM drive, This means there is still network traffic between Euphony and Renderer but there is no other internet traffic during UPnP playback, Stylus always serves local URLs because some UPnP renderers require special UPnP-specific header fields that online music services don't provide so playback fails (and there is no way to detect if Renderer will play an URL until this is actually tried.)
Option 'Use cache' is a convenience option which will make copy of any song added to queue from external resources (mounted USB drives or network shares) and put it in special /data/Music/E_CACHE folder. Next time you need those songs they will be accessed from that cache. This can help in several ways:
To clarify the last point: while album buffering will stop when there is no space left in RAM (rest of the songs will not be buffered), buffering of individual songs at the time of playback will expunge already played buffered songs from RAM to make space for current one.
On the same note - once the cache is filled (there is no more space on Euphony /data partition) 'oldest' songs (those that were first added to cache) will be removed in order to make space for new ones.
We don't know that much about Roon's internal workings but we do know that Roon will never serve an online URL directly to its endpoint (whichever endpoint is in use). Roon maintains a http server on which it serves the URL of its music stream. This stream can contain one song (endpoint will get another url for next song when first finishes) or it can contain many songs which are all served on the same URL as one continuous stream (much like ordinary online radio streams). It does not matter if the original song is a local song or an online song - Roon behaves in the same way,
All this points to some kind of preloading happening on the Roon side but from what we were able to gather while testing our StylusEP endpoint as Roon endpoint, and from monitoring network activity, we concluded that Roon does not actually preload the whole song. It does have some sort of memory buffer but it does not encompass the whole song to be played. This severely limits our options for buffering on the endpoint side but we cannot do anything about it.
StylusEP can serve as an endpoint to Roon (on the same machine or on the endpoint machine). Unfortunately, since Roon does not provide the whole song on its streaming URL, StylusEP can only buffer the amount of data available. As endpoint reports to Roon its playback position Roon decides when to provide more data based on that position (we did not investigate when this exactly happens, does it depend on percentages, on amount of data played or something else).
This all means that songs served from Roon cannot be played in full without intermediate network traffic somewhere during the playback time (probably happening multiple times). StylusEP will always try to read as much data as is available on Roon stream as fast as possible but there is no way to avoid network traffic during playback of a song.
Stylus and SylusEP can be employed in two machine setup. When StylusEP plays a song served by Stylus then StylusEP will preload the whole song before playback. Stylus itself will respect 100% buffer and Buffer album added to queue flags itself and will keep songs in server RAM but StylusEP will pre-download those songs from Stylus server only one at a time, before playback.
Squeezelite or HQPe as Roon endpoints cannot do any better than StylusEP in terms of buffering - there will always be network traffic but for how long and in what intervals depends, in addition to Roon's buffering dynamic, to the buffer sizes in these applications.
Article ID: 18
Category: Euphony Web Application
Date added: 23.04.2020 15:47
Views : 219
Rating (Votes): (4)