Alkampfer.KernelMemory.ElasticSearch 0.9.1

There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Alkampfer.KernelMemory.ElasticSearch --version 0.9.1                
NuGet\Install-Package Alkampfer.KernelMemory.ElasticSearch -Version 0.9.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Alkampfer.KernelMemory.ElasticSearch" Version="0.9.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Alkampfer.KernelMemory.ElasticSearch --version 0.9.1                
#r "nuget: Alkampfer.KernelMemory.ElasticSearch, 0.9.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Alkampfer.KernelMemory.ElasticSearch as a Cake Addin
#addin nuget:?package=Alkampfer.KernelMemory.ElasticSearch&version=0.9.1

// Install Alkampfer.KernelMemory.ElasticSearch as a Cake Tool
#tool nuget:?package=Alkampfer.KernelMemory.ElasticSearch&version=0.9.1                

Use ElasticSeach with Kernel Memory

In this project there is an opinionated implementation of IMemoryDb for Microsoft Kernel Memory based on the latest version of ElasticSearch >=8.13. This implementation was tested only on the latest version of ES 8, and it is not meant to work with older version.

This library implements only the Memory DB part, so you still need to configure a different database for Binary Storage in Kernel Memory.

Nuget

Package is published in Nuget Alkampfer.KernelMemory.ElasticSearch

NuGet Version NuGet Downloads

Details of implementation

This implementation uses dynamic template mapping so we do not need to do nested object mapping, this was done to have a better schema of the object and a real simple way to query the data.

Search in payload

Kernel memory uses only tags to filter results, and the MemoryRecord has payload dictionary that contains non searchable fields. Actually this implementation was created to allow mixing vector search and BM25 search, so you have a special property called IndexablePayloadProperties in the configuration that allows you to specify which payload you want to be indexed and searchable.

You can use that kind of functionality with custom code like that one in Kernel Memory Extensions

Developing with ElasticSearch

You can run on local machine, run with docker or use an instance on the cloud. Check documentation at https://www.elastic.co/

Elasticsearch Version used to develop this driver

At the date of today the latest version that you can download is used, no work has been done to check compatibility with previous versions.

A ui to elastic

If you need an UI to manage your elastic search, you can use elasticsearch ui running in docker

docker run -d -p 5000:5000 elastichq/elasticsearch-hq

Then connect to the local instance of elastic at http://host.docker.internal:9200

You can also use kibana or other UI of your choice.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.10.0-alpha0009 92 7/22/2024
0.10.0-alpha0005 83 7/22/2024
0.9.1 169 7/22/2024
0.9.0 106 7/22/2024
0.9.0-not-filter0006 101 7/8/2024
0.9.0-alpha0006 83 7/16/2024
0.9.0-alpha0005 103 7/5/2024
0.9.0-alpha0004 64 6/4/2024
0.8.0 109 6/4/2024
0.8.0-alpha0013 66 6/3/2024
0.8.0-alpha0012 69 6/1/2024
0.7.0 81 6/1/2024
0.7.0-bulkoperations0025 103 5/16/2024
0.7.0-beta0010 68 6/1/2024
0.7.0-beta0001 120 5/27/2024
0.7.0-beta0000 84 5/18/2024
0.7.0-alpha0025 76 5/17/2024
0.7.0-alpha0024 67 5/11/2024
0.7.0-alpha0020 95 5/8/2024
0.7.0-alpha0017 100 5/8/2024
0.7.0-alpha0014 80 4/26/2024
0.7.0-alpha0010 98 4/25/2024
0.7.0-alpha0009 90 4/25/2024
0.7.0-alpha0008 103 4/23/2024
0.6.4 82 5/11/2024
0.6.4-beta0001 67 5/11/2024
0.6.3 111 5/8/2024
0.6.3-beta0002 101 5/8/2024
0.6.3-beta0001 83 5/8/2024
0.6.2 85 5/8/2024
0.6.2-beta0001 82 5/8/2024
0.6.1 213 4/26/2024
0.6.1-beta0009 89 4/26/2024
0.6.1-beta0008 100 4/26/2024
0.6.0 139 4/23/2024
0.6.0-alpha0015 96 4/23/2024
0.6.0-alpha0014 101 4/20/2024
0.6.0-alpha0013 121 4/19/2024
0.6.0-alpha0012 85 4/17/2024
0.6.0-alpha0011 88 4/17/2024
0.6.0-alpha0010 97 4/17/2024
0.5.0 125 4/17/2024
0.5.0-nuget0017 147 4/17/2024
0.5.0-nuget0016 109 4/17/2024
0.5.0-nuget0015 138 4/17/2024
0.5.0-nuget0014 102 4/17/2024
0.5.0-nuget0013 105 4/17/2024
0.5.0-nuget0009 99 4/17/2024
0.5.0-beta0002 110 4/17/2024
0.5.0-beta0001 91 4/17/2024
0.5.0-beta0000 102 4/17/2024
0.5.0-alpha0006 103 4/17/2024