SpongeEngine.KoboldSharp
1.2.0
See the version list below for details.
dotnet add package SpongeEngine.KoboldSharp --version 1.2.0
NuGet\Install-Package SpongeEngine.KoboldSharp -Version 1.2.0
<PackageReference Include="SpongeEngine.KoboldSharp" Version="1.2.0" />
paket add SpongeEngine.KoboldSharp --version 1.2.0
#r "nuget: SpongeEngine.KoboldSharp, 1.2.0"
// Install SpongeEngine.KoboldSharp as a Cake Addin #addin nuget:?package=SpongeEngine.KoboldSharp&version=1.2.0 // Install SpongeEngine.KoboldSharp as a Cake Tool #tool nuget:?package=SpongeEngine.KoboldSharp&version=1.2.0
KoboldSharp
C# client for interacting with KoboldCpp through its native and OpenAI-compatible endpoints.
Features
- Complete support for KoboldCpp's native API
- OpenAI-compatible API endpoint support
- Streaming text generation
- Comprehensive configuration options
- Built-in error handling and logging
- Cross-platform compatibility
- Full async/await support
Installation
Install via NuGet:
dotnet add package SpongeEngine.KoboldSharp
Quick Start
Using Native API
using SpongeEngine.KoboldSharp.Client;
using SpongeEngine.KoboldSharp.Models;
// Configure the client
var options = new KoboldSharpOptions
{
BaseUrl = "http://localhost:5001",
UseGpu = true,
ContextSize = 2048
};
// Create client instance
using var client = new KoboldSharpClient(options);
// Generate completion
var request = new KoboldSharpRequest
{
Prompt = "Write a short story about a robot:",
MaxLength = 200,
Temperature = 0.7f,
TopP = 0.9f
};
var response = await client.GenerateAsync(request);
Console.WriteLine(response.Results[0].Text);
// Stream completion
await foreach (var token in client.GenerateStreamAsync(request))
{
Console.Write(token);
}
Using OpenAI-Compatible API
var options = new KoboldSharpOptions
{
BaseUrl = "http://localhost:5001",
UseOpenAiApi = true
};
using var client = new KoboldSharpClient(options);
// Simple completion
string response = await client.CompleteAsync(
"Write a short story about:",
new CompletionOptions
{
MaxTokens = 200,
Temperature = 0.7f,
TopP = 0.9f
});
// Stream completion
await foreach (var token in client.StreamCompletionAsync(
"Once upon a time...",
new CompletionOptions { MaxTokens = 200 }))
{
Console.Write(token);
}
Configuration Options
Basic Options
var options = new KoboldSharpOptions
{
BaseUrl = "http://localhost:5001", // KoboldCpp server URL
ApiKey = "optional_api_key", // Optional API key
TimeoutSeconds = 600, // Request timeout
ContextSize = 2048, // Maximum context size
UseGpu = true, // Enable GPU acceleration
UseOpenAiApi = false // Use OpenAI-compatible API
};
Advanced Generation Parameters
var request = new KoboldSharpRequest
{
Prompt = "Your prompt here",
MaxLength = 200, // Maximum tokens to generate
MaxContextLength = 2048, // Maximum context length
Temperature = 0.7f, // Randomness (0.0-1.0)
TopP = 0.9f, // Nucleus sampling threshold
TopK = 40, // Top-K sampling
TopA = 0.0f, // Top-A sampling
Typical = 1.0f, // Typical sampling
Tfs = 1.0f, // Tail-free sampling
RepetitionPenalty = 1.1f, // Repetition penalty
RepetitionPenaltyRange = 64, // Penalty range
StopSequences = new List<string> { "\n" }, // Stop sequences
Stream = false, // Enable streaming
TrimStop = true, // Trim stop sequences
MirostatMode = 0, // Mirostat sampling mode
MirostatTau = 5.0f, // Mirostat target entropy
MirostatEta = 0.1f // Mirostat learning rate
};
Error Handling
try
{
var response = await client.GenerateAsync(request);
}
catch (KoboldSharpException ex)
{
Console.WriteLine($"KoboldCpp error: {ex.Message}");
Console.WriteLine($"Provider: {ex.Provider}");
if (ex.StatusCode.HasValue)
{
Console.WriteLine($"Status code: {ex.StatusCode}");
}
if (ex.ResponseContent != null)
{
Console.WriteLine($"Response content: {ex.ResponseContent}");
}
}
catch (Exception ex)
{
Console.WriteLine($"General error: {ex.Message}");
}
Logging
The client supports Microsoft.Extensions.Logging:
ILogger logger = LoggerFactory
.Create(builder => builder
.AddConsole()
.SetMinimumLevel(LogLevel.Debug))
.CreateLogger<KoboldSharpClient>();
var client = new KoboldSharpClient(options, logger);
JSON Serialization
Custom JSON settings can be provided:
var jsonSettings = new JsonSerializerSettings
{
NullValueHandling = NullValueHandling.Ignore,
DefaultValueHandling = DefaultValueHandling.Ignore
};
var client = new KoboldSharpClient(options, jsonSettings: jsonSettings);
Testing
The library includes both unit and integration tests. Integration tests require a running KoboldCpp server.
To run the tests:
dotnet test
To configure the test environment:
// Set environment variables for testing
Environment.SetEnvironmentVariable("KOBOLDCPP_BASE_URL", "http://localhost:5001");
Environment.SetEnvironmentVariable("KOBOLDCPP_OPENAI_BASE_URL", "http://localhost:5001/v1");
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
For issues and feature requests, please use the GitHub issues page.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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 is compatible. 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 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. 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. |
-
net6.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.0)
- OllamaSharp (>= 4.0.11)
- Polly (>= 8.5.0)
- SpongeEngine.LLMSharp.Core (>= 1.0.3)
- System.Linq.Async (>= 6.0.1)
-
net7.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.0)
- OllamaSharp (>= 4.0.11)
- Polly (>= 8.5.0)
- SpongeEngine.LLMSharp.Core (>= 1.0.3)
- System.Linq.Async (>= 6.0.1)
-
net8.0
- Microsoft.Extensions.Caching.Memory (>= 9.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.0)
- OllamaSharp (>= 4.0.11)
- Polly (>= 8.5.0)
- SpongeEngine.LLMSharp.Core (>= 1.0.3)
- System.Linq.Async (>= 6.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.