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 96 7/22/2024
0.10.0-alpha0005 86 7/22/2024
0.9.1 220 7/22/2024
0.9.0 109 7/22/2024
0.9.0-not-filter0006 104 7/8/2024
0.9.0-alpha0006 86 7/16/2024
0.9.0-alpha0005 106 7/5/2024
0.9.0-alpha0004 69 6/4/2024
0.8.0 112 6/4/2024
0.8.0-alpha0013 69 6/3/2024
0.8.0-alpha0012 72 6/1/2024
0.7.0 84 6/1/2024
0.7.0-bulkoperations0025 108 5/16/2024
0.7.0-beta0010 71 6/1/2024
0.7.0-beta0001 123 5/27/2024
0.7.0-beta0000 89 5/18/2024
0.7.0-alpha0025 81 5/17/2024
0.7.0-alpha0024 70 5/11/2024
0.7.0-alpha0020 100 5/8/2024
0.7.0-alpha0017 103 5/8/2024
0.7.0-alpha0014 85 4/26/2024
0.7.0-alpha0010 101 4/25/2024
0.7.0-alpha0009 93 4/25/2024
0.7.0-alpha0008 106 4/23/2024
0.6.4 85 5/11/2024
0.6.4-beta0001 70 5/11/2024
0.6.3 114 5/8/2024
0.6.3-beta0002 106 5/8/2024
0.6.3-beta0001 88 5/8/2024
0.6.2 88 5/8/2024
0.6.2-beta0001 85 5/8/2024
0.6.1 216 4/26/2024
0.6.1-beta0009 92 4/26/2024
0.6.1-beta0008 103 4/26/2024
0.6.0 142 4/23/2024
0.6.0-alpha0015 99 4/23/2024
0.6.0-alpha0014 104 4/20/2024
0.6.0-alpha0013 126 4/19/2024
0.6.0-alpha0012 88 4/17/2024
0.6.0-alpha0011 93 4/17/2024
0.6.0-alpha0010 100 4/17/2024
0.5.0 128 4/17/2024
0.5.0-nuget0017 150 4/17/2024
0.5.0-nuget0016 112 4/17/2024
0.5.0-nuget0015 141 4/17/2024
0.5.0-nuget0014 105 4/17/2024
0.5.0-nuget0013 110 4/17/2024
0.5.0-nuget0009 104 4/17/2024
0.5.0-beta0002 115 4/17/2024
0.5.0-beta0001 96 4/17/2024
0.5.0-beta0000 105 4/17/2024
0.5.0-alpha0006 106 4/17/2024