using Microsoft.KernelMemory; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using LLama; using LLama.Common; using Microsoft.KernelMemory.AI; using Microsoft.SemanticKernel.AI.Embeddings; using LLama.Native; namespace LLamaSharp.KernelMemory { /// /// Provides extension methods for the KernelMemoryBuilder class. /// public static class BuilderExtensions { /// /// Adds LLamaSharpTextEmbeddingGeneration to the KernelMemoryBuilder. /// /// The KernelMemoryBuilder instance. /// The LLamaSharpConfig instance. /// The KernelMemoryBuilder instance with LLamaSharpTextEmbeddingGeneration added. public static IKernelMemoryBuilder WithLLamaSharpTextEmbeddingGeneration(this IKernelMemoryBuilder builder, LLamaSharpConfig config) { var generator = new LLamaSharpTextEmbeddingGenerator(config); builder.AddSingleton(generator); builder.AddIngestionEmbeddingGenerator(generator); return builder; } /// /// Adds LLamaSharpTextEmbeddingGeneration to the KernelMemoryBuilder. /// /// The KernelMemoryBuilder instance. /// The LLamaSharpTextEmbeddingGeneration instance. /// The KernelMemoryBuilder instance with LLamaSharpTextEmbeddingGeneration added. public static IKernelMemoryBuilder WithLLamaSharpTextEmbeddingGeneration(this IKernelMemoryBuilder builder, LLamaSharpTextEmbeddingGenerator textEmbeddingGenerator) { builder.AddSingleton(textEmbeddingGenerator); builder.AddIngestionEmbeddingGenerator(textEmbeddingGenerator); return builder; } /// /// Adds LLamaSharpTextGeneration to the KernelMemoryBuilder. /// /// The KernelMemoryBuilder instance. /// The LLamaSharpConfig instance. /// The KernelMemoryBuilder instance with LLamaSharpTextGeneration added. public static IKernelMemoryBuilder WithLLamaSharpTextGeneration(this IKernelMemoryBuilder builder, LLamaSharpConfig config) { builder.AddSingleton(new LlamaSharpTextGenerator(config)); return builder; } /// /// Adds LLamaSharpTextGeneration to the KernelMemoryBuilder. /// /// The KernelMemoryBuilder instance. /// The LlamaSharpTextGeneration instance. /// The KernelMemoryBuilder instance with LLamaSharpTextGeneration added. public static IKernelMemoryBuilder WithLLamaSharpTextGeneration(this IKernelMemoryBuilder builder, LlamaSharpTextGenerator textGenerator) { builder.AddSingleton(textGenerator); return builder; } /// /// Adds LLamaSharpTextEmbeddingGeneration and LLamaSharpTextGeneration to the KernelMemoryBuilder. /// /// The KernelMemoryBuilder instance. /// The LLamaSharpConfig instance. /// /// /// The KernelMemoryBuilder instance with LLamaSharpTextEmbeddingGeneration and LLamaSharpTextGeneration added. public static IKernelMemoryBuilder WithLLamaSharpDefaults(this IKernelMemoryBuilder builder, LLamaSharpConfig config, LLamaWeights? weights=null, LLamaContext? context=null) { var parameters = new ModelParams(config.ModelPath) { ContextSize = config?.ContextSize ?? 2048, Seed = config?.Seed ?? 0, GpuLayerCount = config?.GpuLayerCount ?? 20, EmbeddingMode = true, MainGpu = config?.MainGpu ?? 0, SplitMode = config?.SplitMode ?? GPUSplitMode.None, }; if (weights == null) { weights = LLamaWeights.LoadFromFile(parameters); context = weights.CreateContext(parameters); } var executor = new StatelessExecutor(weights, parameters); var embedder = new LLamaEmbedder(weights, parameters); builder.WithLLamaSharpTextEmbeddingGeneration(new LLamaSharpTextEmbeddingGenerator(embedder)); builder.WithLLamaSharpTextGeneration(new LlamaSharpTextGenerator(weights, context, executor, config?.DefaultInferenceParams)); return builder; } } }