SoundFingerprinting.Extensions.LMDB
7.4.7
See the version list below for details.
dotnet add package SoundFingerprinting.Extensions.LMDB --version 7.4.7
NuGet\Install-Package SoundFingerprinting.Extensions.LMDB -Version 7.4.7
<PackageReference Include="SoundFingerprinting.Extensions.LMDB" Version="7.4.7" />
paket add SoundFingerprinting.Extensions.LMDB --version 7.4.7
#r "nuget: SoundFingerprinting.Extensions.LMDB, 7.4.7"
// Install SoundFingerprinting.Extensions.LMDB as a Cake Addin #addin nuget:?package=SoundFingerprinting.Extensions.LMDB&version=7.4.7 // Install SoundFingerprinting.Extensions.LMDB as a Cake Tool #tool nuget:?package=SoundFingerprinting.Extensions.LMDB&version=7.4.7
SoundFingerprinting.LMDB
Database adapter for SoundFingerprinting algorithm using LMDB database. It's fast, it's persistent and safe from data violation.
Usage
To get library simply install it from Nuget:
Install-Package SoundFingerprinting.Extensions.LMDB
or using dotnet cli
dotnet add package SoundFingerprinting.Extensions.LMDB
As a requirement from dependent library Spreads.LMDB
you have to provide native lmdb library yourself (considering your application architecture target). Take proper native library from here and make sure it always get copied to your compiled application folder (the simplest way is to attach this file to project and mark it as "Copy on Build").
To use LMDB database with SoundFingerprinting create LMDBModelService
object and use it in algorithm, like this:
var audioService = new SoundFingerprintingAudioService();
using(var modelService = new LMDBModelService("db")){
var track = new TrackData("GBBKS1200164", "Adele", "Skyfall", "Skyfall", 2012, 290);
// store track metadata in the datasource
var trackReference = modelService.InsertTrack(track);
// create hashed fingerprints
var hashedFingerprints = FingerprintCommandBuilder.Instance
.BuildFingerprintCommand()
.From(pathToAudioFile)
.UsingServices(audioService)
.Hash()
.Result;
// store hashes in the database for later retrieval
modelService.InsertHashDataForTrack(hashedFingerprints, trackReference);
}
Parameter of LMDBModelService
constructor is path to directory. LMDB will create its files in this directory.
You need to build your application targeting x64 architecture, since LMDB supports only that. On x32 you will encounter runtime errors!
It's VERY important to dispose modelService after usage (although it's best to keep instance for whole application life and dispose it on application closing). Not doing it might cause memory dump, which tries to dump whole VirtualMemory of process. Memory Mapped File is part of VirtualMemory, so it will be dumped as well. That might result in system getting unresponsive for even a couple of minutes!
Technical details
LMDB itself is very fast key-value database based on B+Tree and Memory Mapped File.
This storage is slow to write (because inserts and deletes are single threaded - locks are already in code) but very fast to random reads (very efficent reading in highly concurrent environments).
LMDB is file-based database, so there is no network protocol used for communication. As a downside to this we can't use this database between machines (due to how Memory Mapped File works it's forbidden to use LMDB database file by network shares - more on this in LMDB documentation).
Third party dependencies
Huge thanks to all library creators for making this all possible.
- SoundFingerprinting
- LMDB
- Spreads.LMDB (.NET wrapper over LMDB)
- MessagePack (extremly fast binary serializer)
Performance
Benchmark (source is in repo) is made using 10 sample tracks. LMDBModelService
is around 10-20% slower than InMemoryService
which is decent enough. I'm still working on optimizations in allocation count and overall performace.
I'm using this adapter in production with 4000 tracks in database. As far as i can tell - 10-20% performance difference still apply on such dataset. I'd love if somebody could test this out on bigger dataset and share his experience.
As you can see in the benchmark - .NET Core is much more optimized to work with this adapter. Scaled performance is better, but not so much. But allocations can get crazy low - from 250MB on .NET Framework to 1.4KB on .NET Core. This is because .NET Core can take advantage of Span
and Memory
constructs leading to zero-copy reads from LMDB database. So i strongly recommend using .NET Core to get the best performance and allocation count.
Whole benchmark results available Here
Contribute
All are welcome to open Issues and Pull Requests. You can contact me on email jakub.nekro@gmail.com if you have further questions, opinions and feature ideas.
License
The framework is provided under MIT license agreement.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- MessagePack (>= 2.1.152)
- SoundFingerprinting (>= 7.4.7)
- Spreads.LMDB (>= 2020.0.114)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on SoundFingerprinting.Extensions.LMDB:
Repository | Stars |
---|---|
cjmanca/plex-credits-detect
Augments plex's built in intro detection, additionally detecting credits.
|
Version | Downloads | Last updated |
---|---|---|
8.7.0 | 2,214 | 4/11/2022 |
7.9.9 | 976 | 5/27/2021 |
7.4.7 | 1,085 | 7/23/2020 |
7.3.2 | 1,074 | 5/10/2020 |
7.1.0.1 | 1,072 | 2/26/2020 |
7.1.0 | 1,033 | 2/26/2020 |
7.0.0 | 1,163 | 10/14/2019 |
6.2.2.1 | 1,138 | 5/12/2019 |
6.2.2 | 1,140 | 5/11/2019 |
6.2.0 | 1,162 | 4/2/2019 |
6.0.0 | 1,287 | 11/8/2018 |
5.2.3.1 | 1,412 | 10/18/2018 |
5.2.3.1-rc2 | 1,156 | 10/15/2018 |
5.2.3.1-rc1 | 1,230 | 10/8/2018 |
5.2.3.1-beta2 | 1,177 | 9/26/2018 |
5.2.3.1-beta1 | 1,176 | 9/24/2018 |
5.2.2.3-beta2 | 1,210 | 9/18/2018 |
5.2.2.3-beta1 | 1,234 | 9/17/2018 |
5.2.2.2 | 1,441 | 9/13/2018 |
Version 7.4.7.0 brings integration with new version of SoundFingerprinting.