Skip to content

Commit

Permalink
Make the Song::analyze public
Browse files Browse the repository at this point in the history
  • Loading branch information
Paul Arzelier committed Dec 2, 2023
1 parent 87559b9 commit 708201e
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 2 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
#Changelog

## bliss 0.6.10
* Make the `analyze` function public, for people who don't want to use
ffmpeg

## bliss 0.6.9
* Add a feature flag for compilation on raspberry pis.

Expand Down
21 changes: 19 additions & 2 deletions src/song.rs
Original file line number Diff line number Diff line change
Expand Up @@ -315,7 +315,11 @@ impl Song {
}

/**
* Analyze a song decoded in `sample_array`, with one channel @ 22050 Hz.
* Analyze a song decoded in `sample_array`. This function should NOT
* be used manually, unless you want to explore analyzing a sample array you
* already decoded yourself. Most people will want to use
* [Song::from_path](Song::from_path) instead to just analyze a file from
* its path.
*
* The current implementation doesn't make use of it,
* but the song can also be streamed wrt.
Expand All @@ -324,8 +328,21 @@ impl Song {
*
* Useful in the rare cases where the full song is not
* completely available.
*
* If you *do* want to use this with a song already decoded by yourself,
* the sample format of `sample_array` should be f32le, one channel, and
* the sampling rate 22050 Hz. Anything other thant that will yield aberrant
* results.
* To double-check that your sample array has the right format, you could run
* `ffmpeg -i path_to_your_song.flac -ar 22050 -ac 1 -c:a pcm_f32le -f hash -hash ripemd160 -`,
* which will give you the ripemd160 hash of the sample array if the song
* has been decoded properly. You can then compute the ripemd160 hash of your sample
* array (see `_test_decode` in the tests) and make sure both hashes are the same.
*
* (Running `ffmpeg -i path_to_your_song.flac -ar 22050 -ac 1 -c:a pcm_f32le` will simply give
* you the raw sample array as it should look like, if you're not into computing hashes)
**/
pub(crate) fn analyze(sample_array: &[f32]) -> BlissResult<Analysis> {
pub fn analyze(sample_array: &[f32]) -> BlissResult<Analysis> {
let largest_window = vec![
BPMDesc::WINDOW_SIZE,
ChromaDesc::WINDOW_SIZE,
Expand Down

0 comments on commit 708201e

Please sign in to comment.