bliss-analyser/README.md
2025-03-17 18:16:39 +00:00

3.5 KiB

Bliss Analyser

Simple rust app to analyse songs with bliss-rs. The output of this is a SQLite database containing song metadata and bliss analysis. This is then intended to be used by Bliss Mixer

Building

This application can be built in 4 variants:

  1. Using libavcodec, etc, to decode files.
  2. Using libavcodec, etc, to decode files, but statically linked to libavcodec, etc.
  3. Using symphonia to decode files.
  4. Using command-line ffmpeg to decode files.

libavcodec is the fastest (~15% faster than symphonia, ~50% faster than ffmpeg commandline), but might have issues with library, versioning, etc., unless these libraries are statically linked in. libavcodec statically linked may reduce supported file formats, but is more portable.

symphonia also produces a more portable application, is only slightly slower to decode files, but has more limited codec support, and does not produce identical analysis results. Therefore, it is not advisable to mix files analysed with ffmpeg (any variant) and symphonia.

Command-line ffmpeg whilst being the slowest, produces a more portable application, and supports a wider range of codecs.

Build for 'libavcodec' library usage

clang, pkg-config, and ffmpeg are required to build, as well as Rust

To install dependencies on a Debian system:

apt install -y clang libavcodec-dev libavformat-dev libavutil-dev libavfilter-dev libavdevice-dev pkg-config

To install dependencies on a Fedora system:

dnf install ffmpeg-devel clang pkg-config

Build with cargo build --release --features=libav

If building on a Raspberry Pi, then rpi also needs to be passed to --features, e.g. cargo build --release --features=libav,rpi

The resultant application will be less portable, due to dependencies on libavcodec libraries (and their dependencies).

Build for 'libavcodec' library usage, statically linked

clang, pkg-config, and ffmpeg are required to build, as well as Rust

To install dependencies on a Debian system:

apt install -y clang libavcodec-dev libavformat-dev libavutil-dev libavfilter-dev libavdevice-dev pkg-config

To install dependencies on a Fedora system:

dnf install ffmpeg-devel clang pkg-config

Build with cargo build --release --features=libav,libavstatic

If building on a Raspberry Pi, then rpi also needs to be passed to --features, e.g. cargo build --release --features=libav,libavstatic,rpi

Build for 'symphonia'

clang, and pkg-config are required to build, as well as Rust

To install dependencies on a Debian system:

apt install -y clang pkg-config

To install dependencies on a Fedora system:

dnf install clang pkg-config

Build with cargo build --release --features=symphonia

Build for 'ffmpeg' command-line usage

clang and pkg-config are required to build, as well as Rust

To install dependencies on a Debian system:

apt install -y clang pkg-config

To install dependencies on a Fedora system:

dnf install clang pkg-config

Build with cargo build --release --features=ffmpeg

ffmpeg is then a run-time dependency, and should be installed on any system where this application is to be run - it should also be in the users $PATH

Usage

Please refer to UserGuide.md for details of how this tool may be used.