| Age | Commit message (Collapse) | Author | 
|---|
|  | Using the date of the build makes it not-reproducible. This should be
avoided. Furthermore the date on the front page should anyway reflect
when the source of the document was created. Not when it was converted
into a PDF. | 
|  | The following changes are included in this commit:
- multicast to unicast
- UDP to TCP
- Matroska to ogg
- MP3 to FLAC
Switching to these protocols has several advantages. Avoiding multicast
makes it unnecessary to care about the available multicast addresses in
the local network. Unicast addresses are anyway assigned by DHCP. In a
multi-room setup this has of course the disadvantage that the same data
might be streamed via separate connections. The bandwidth requirement
would be multiplied by the number of soundbox devices. But since a
stream takes around 2 Mbit/s and we live in a world where 100 Mbit/s in
a local network should not be a problem the inefficiency can be
neglected.
Switching from UDP to TCP has the advantage that the stream is
transmitted reliably. Furthermore it avoids the situation that multiple
clients stream to the same soundbox simultaneously since a
single-connection TCP server is used.
The switch from Matroska to ogg is done because the ogg format is
recommended on the FLAC homepage. FLAC is used instead of MP3 because it
is a lossless audio compression format. This is obviously superior
compared to the lossy MP3 format regarding audio quality. | 
|  |  | 
|  | The y dimension of the shell connectors was assumed to be bolt_l. But
this ignores that their thickness is bolt_l-t because the bolt has to go
through the shell with thickness t before entering the shell connector. | 
|  | The default streaming guide is now far away from the original taken from
the FFmpeg streaming guide.
Since the command can handle a lot of inputs its also not useful to send
sine waves to soundbox devices. | 
|  |  | 
|  | This makes sure the audio-receiving software `ffplay` runs all the time. | 
|  |  | 
|  | This makes a soundbox device discoverable via the Link Layer Discovery
Protocol (LLDP). That way a client application can lookup the available
soundbox devices inside the network to display playback options. | 
|  | While transcoding to a lossy formate like MP3 is not recommended [1]
forquality reasons it has the advantage that alway UPD / Matroska / MP3
is used for soundbox. That way the stream can be stopped and started at
any time without re-launching ffplay on the soundbox device. This could
make the SSH connection to the soundbox not longer needed.
[1]: https://trac.ffmpeg.org/wiki/Encode/HighQualityAudio#WhenshouldItranscodeaudio | 
|  |  | 
|  | The Matroska format has to advantage that a stream can be stopped and
the restarted at any time without executing new commands on the soundbox
device.
Since Matroska and RTP have similar / redundant features [1] the
transport protocol is switched to plain UDP.
[1]: https://en.wikipedia.org/wiki/Comparison_of_video_container_formats#cite_note-22 | 
|  | The full soundbox-<version>- prefix was only used for the artifact tar
archive name so far. This has the advantage that the file names inside
that archive are shorter like 'documentation.pdf'.
But sometimes it is useful to pass only the documentation around as a
PDF file because it is easier for people to open it compared to a tar
file.
For this purpose a second artifact installation for the documentation
PDF is added including the soundbox-<version>- prefix. | 
|  |  | 
|  | This allows to stream to multiple devices at the same time. Nevertheless
it still works for a point to point stream. | 
|  | The soundbox software should be portable to other Raspberry Pis without
the HiFiBerry DAC too. | 
|  |  | 
|  | The music streaming documentation used to enforce re-encoding via ffmpeg
to save bandwidth. This led to pretty poor audio quality. This is not
the purpose of soundbox. It is assumed that the user wants the highest
possible audio quality as default. | 
|  | Configuring the Alpine Linux operating system correctly for soundbox is
not trivial. Since it is very important it has to be documented in
detail. | 
|  | The tar-based installation is more difficult to explain but has the
advantage that the partition size is maximized from the beginning. This
is way easier than resizing the partition after the installation. | 
|  | This is currently the recommended OS installation for soundbox. | 
|  | The positions of the connectors had to be adapted to the new PCB case
dimensions.
Furthermore the micro USB port which is built in to supply the device
with power is now the only visible micro USB port from the outside. The
other one is unused and could lead to confusion. User might plug in the
power cable into the wrong port.
Hiding this misleading USB port is an elegant way to avoid this problem.
Developers can still open the device to make use of that port if
required. | 
|  | The front panel has to be very close and thin so that USB and HDMI
cables can still be connected when only the ports are cut out of the
panel. | 
|  | Since a proper norm-based distance bolt was not found printing spacers
is the easiest way to make the case producable independent of part
availability. | 
|  | This makes sure that the bolts inside the connectors align with them.
Thus the bolts do not stick inside the case which might lead to PCB
collisions. | 
|  | The height should take into account that the shell is two instead of one
times the thickness high. This is relevant for the vertical spacing. | 
|  | There used to be no extra space between paragraphs which in combination
with no indentation was not useful. | 
|  | This flag makes sure the file is streamed in native frame rate and not
e.g. way faster. This is the expected behaviour. | 
|  | This port should be used in the future as soundbox standard port. | 
|  | This allows more testing than only streaming sine waves. | 
|  | This documents a basic FFmpeg streaming example so that soundbox devices
can be tested. | 
|  | This section is important to communicate how to interpret version
numbers in the context of this device repository. | 
|  | This is required to build the table of contents and similar parts of the
document correctly. | 
|  | Inside the artifacts folder aswell as inside the source folder adding a
'soundbox-' prefix to files is uncommon. In both cases only the root level
folder should contain the name 'soundbox' to remove redundancies. | 
|  | This target will skip generating the artifacts directory. This avoids a
bloated build directory while the default target 'all' still generates
the artifacts. | 
|  | All build files relevant for users (artifacts) should be provided in
build/artifacts. This folder has subdirectories for every revision and a
corresponding Zstandard-compressed Tar archive.
This archive contains the full result of the build of the current source
directory and can easily be shared. | 
|  | The CAD model of the full assembly might be useful to be included in
other projects or CAD files. | 
|  | Most users will not own the default printer and thus cannot work with
the built gcode files with the default slicer configuration.
It might be easier for those users to manually slice the STL instead of
modifying the soundbox source code. | 
|  |  | 
|  |  | 
|  | Providing a structural overview inside the README should help developers
new to the repository to get familiar with it. | 
|  | This document will be quite long. Thus the report document class is more
suitable. | 
|  | This draft should give an overview of the planned sections which is
useful to decide what should belong into the first sections and what
should be written in later ones. | 
|  | The build system should convert the documentation source files
automatically to a single PDF file to make documentation generation
trivial. | 
|  | This target removes the build directory and is thus repository-global. | 
|  | This LaTeX document should contain the full device documentation for
soundbox. It will not cover aspects about the source or how to build.
This should be covered inside the README of this repository. Everything
else will be part of the resulting documentation PDF file. | 
|  | This license should cover the documentation of soundbox because software
licenses like the AGPL or hardware licenses like OHL are not well
suited. | 
|  | The front panel needs holes for the HDMI, micro USB and cinch connectors
of the Raspberry Pi Zero W. | 
|  |  | 
|  | After switching the panel to PCB-based dimensions the shell follows with
this commit. |