OllamaSharp 4.0.7

dotnet add package OllamaSharp --version 4.0.7                
NuGet\Install-Package OllamaSharp -Version 4.0.7                
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="OllamaSharp" Version="4.0.7" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add OllamaSharp --version 4.0.7                
#r "nuget: OllamaSharp, 4.0.7"                
#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 OllamaSharp as a Cake Addin
#addin nuget:?package=OllamaSharp&version=4.0.7

// Install OllamaSharp as a Cake Tool
#tool nuget:?package=OllamaSharp&version=4.0.7                

<p align="center">  <img alt="ollama" height="200px" src="https://github.com/awaescher/OllamaSharp/blob/main/Ollama.png"> </p>

OllamaSharp 🦙

OllamaSharp provides .NET bindings for the Ollama API, simplifying interactions with Ollama both locally and remotely.

✅ Supporting Microsoft.Extensions.AI and Microsoft Semantic Kernel

Features

  • Ease of use: Interact with Ollama in just a few lines of code.
  • API endpoint coverage: Support for all the Ollama API endpoints, including chats, embeddings, listing models, pulling and creating new models, and more.
  • Real-time streaming: Stream responses directly to your application.
  • Progress reporting: Get real-time progress feedback on tasks like model pulling.
  • Support for vision models and tools (function calling).

Usage

OllamaSharp wraps each Ollama API endpoint in awaitable methods that fully support response streaming.

The following list shows a few simple code examples.

Try our full featured demo application that's included in this repository

Initializing

// set up the client
var uri = new Uri("http://localhost:11434");
var ollama = new OllamaApiClient(uri);

// select a model which should be used for further operations
ollama.SelectedModel = "llama3.1:8b";

Listing all models that are available locally

var models = await ollama.ListLocalModelsAsync();

Pulling a model and reporting progress

await foreach (var status in ollama.PullModelAsync("llama3.1:405b"))
    Console.WriteLine($"{status.Percent}% {status.Status}");

Generating a completion directly into the console

await foreach (var stream in ollama.GenerateAsync("How are you today?"))
    Console.Write(stream.Response);

Building interactive chats

var chat = new Chat(ollama);
while (true)
{
    var message = Console.ReadLine();
    await foreach (var answerToken in chat.SendAsync(message))
        Console.Write(answerToken);
}
// messages including their roles and tool calls will automatically be tracked within the chat object
// and are accessible via the Messages property

Usage with Microsoft.Extensions.AI

Microsoft built an abstraction library to streamline the usage of different AI providers. This is a really interesting concept if you plan to build apps that might use different providers, like ChatGPT, Claude and local models with Ollama.

I encourage you to read their accouncement Introducing Microsoft.Extensions.AI Preview – Unified AI Building Blocks for .NET.

OllamaSharp is the first full implementation of their IChatClient and IEmbeddingGenerator that makes it possible to use Ollama just like every other chat provider.

To do this, simply use the OllamaApiClient as IChatClient instead of IOllamaApiClient.

// install package Microsoft.Extensions.AI.Abstractions

private static IChatClient CreateChatClient(Arguments arguments)
{
  if (arguments.Provider.Equals("ollama", StringComparison.OrdinalIgnoreCase))
    return new OllamaApiClient(arguments.Uri, arguments.Model);
  else
    return new OpenAIChatClient(new OpenAI.OpenAIClient(arguments.ApiKey), arguments.Model); // ChatGPT or compatible
}

[!NOTE] IOllamaApiClient provides many Ollama specific methods that IChatClient and IEmbeddingGenerator miss. Because these are abstractions, IChatClient and IEmbeddingGenerator will never implement the full Ollama API specification. However, OllamaApiClient implements three interfaces: the native IOllamaApiClient and Microsoft IChatClient and IEmbeddingGenerator<string, Embedding<float>> which allows you to cast it to any of these two interfaces as you need them at any time.

Credits

The icon and name were reused from the amazing Ollama project.

I would like to thank all the contributors who take the time to improve OllamaSharp. First and foremost mili-tan, who always keeps OllamaSharp in sync with the Ollama API. ❤

Product 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. 
.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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (9)

Showing the top 5 NuGet packages that depend on OllamaSharp:

Package Downloads
Microsoft.KernelMemory.AI.Ollama

Provide access to Ollama LLM models in Kernel Memory to generate embeddings and text

Microsoft.SemanticKernel.Connectors.Ollama

Semantic Kernel connector for Ollama. Contains services for text generation, chat completion and text embeddings.

CommunityToolkit.Aspire.Hosting.Ollama

An Aspire integration leveraging the Ollama container with support for downloading a model on startup.

CommunityToolkit.Aspire.OllamaSharp

A .NET Aspire client integration for the OllamaSharp library.

Atc.SemanticKernel.Connectors.Ollama

Atc.SemanticKernel.Connectors.Ollama contains a connector for integrating with local llms through Ollama.

GitHub repositories (5)

Showing the top 5 popular GitHub repositories that depend on OllamaSharp:

Repository Stars
microsoft/kernel-memory
RAG architecture: index and query any data using LLM and natural language, track sources, show citations, asynchronous memory patterns.
dotnet/ai-samples
platformplatform/PlatformPlatform
🚀 Pre-alpha state. A platform designed for building enterprise-grade, multi-tenant products using Azure, .NET, React, TypeScript, Infrastructure as Code, etc.
lindexi/lindexi_gd
博客用到的代码
CommunityToolkit/Aspire
A community project with additional components and extensions for .NET Aspire
Version Downloads Last updated
4.0.7 62 11/13/2024
4.0.6 3,067 11/7/2024
4.0.5 1,265 11/5/2024
4.0.4 255 11/4/2024
4.0.3 1,601 10/30/2024
4.0.2 240 10/29/2024
4.0.1 2,027 10/26/2024
4.0.0-preview.10 66 10/23/2024
4.0.0-preview.9 44 10/21/2024
4.0.0-preview.8 67 10/17/2024
3.0.15 2,559 10/21/2024
3.0.14 4,996 10/16/2024
3.0.13 72 10/16/2024
3.0.12 10,652 10/14/2024
3.0.11 1,241 10/9/2024
3.0.10 7,190 10/4/2024
3.0.9 88 10/4/2024
3.0.8 10,439 9/26/2024
3.0.7 14,001 9/12/2024
3.0.6 1,139 9/11/2024
3.0.5 780 9/11/2024
3.0.4 24,218 9/6/2024
3.0.3 104 9/6/2024
3.0.2 336 9/5/2024
3.0.1 15,233 9/2/2024
3.0.0 1,834 8/26/2024
2.1.3 2,477 8/23/2024
2.1.2 2,054 8/19/2024
2.1.1 4,084 8/5/2024
2.0.15 81 8/5/2024
2.0.14 94 8/3/2024
2.0.13 1,651 7/29/2024
2.0.12 97 7/28/2024
2.0.11 104 7/28/2024
2.0.10 3,589 7/12/2024
2.0.9 90 7/12/2024
2.0.8 124 7/12/2024
2.0.7 1,478 7/10/2024
2.0.6 3,072 6/25/2024
2.0.5 98 6/25/2024
2.0.4 564 6/24/2024
2.0.3 98 6/24/2024
2.0.2 138 6/24/2024
2.0.1 3,644 6/5/2024
1.1.13 172 6/5/2024
1.1.12 383 6/4/2024
1.1.11 287 6/2/2024
1.1.10 885 5/31/2024
1.1.9 6,374 5/15/2024
1.1.8 1,352 5/10/2024
1.1.7 112 5/10/2024
1.1.5 106 5/10/2024
1.1.4 150 5/10/2024
1.1.3 106 5/10/2024
1.1.2 109 5/10/2024
1.1.1 3,005 3/27/2024
1.1.0 1,765 1/8/2024
1.0.4 288 12/27/2023
1.0.3 328 11/30/2023
1.0.2 294 11/5/2023
1.0.1 184 10/16/2023
1.0.0 1,404 10/16/2023