LLamaSharp 0.19.0
dotnet add package LLamaSharp --version 0.19.0
NuGet\Install-Package LLamaSharp -Version 0.19.0
<PackageReference Include="LLamaSharp" Version="0.19.0" />
paket add LLamaSharp --version 0.19.0
#r "nuget: LLamaSharp, 0.19.0"
// Install LLamaSharp as a Cake Addin #addin nuget:?package=LLamaSharp&version=0.19.0 // Install LLamaSharp as a Cake Tool #tool nuget:?package=LLamaSharp&version=0.19.0
LLamaSharp is a cross-platform library to run 🦙LLaMA/LLaVA model (and others) on your local device. Based on llama.cpp, inference with LLamaSharp is efficient on both CPU and GPU. With the higher-level APIs and RAG support, it's convenient to deploy LLMs (Large Language Models) in your application with LLamaSharp.
Please star the repo to show your support for this project!🤗
<details> <summary>Table of Contents</summary> <ul> <li><a href="#Documentation">Documentation</a></li> <li><a href="#Console Demo">Console Demo</a></li> <li><a href="#Integrations & Examples">Integrations & Examples</a></li> <li><a href="#Get started">Get started</a></li> <li><a href="#FAQ">FAQ</a></li> <li><a href="#Contributing">Contributing</a></li> <li><a href="#Join the community">Join the community</a></li> <li><a href="#Star history">Star history</a></li> <li><a href="#Contributor wall of fame">Contributor wall of fame</a></li> <li><a href="#Map of LLamaSharp and llama.cpp versions">Map of LLamaSharp and llama.cpp versions</a></li> </ul> </details>
đź“–Documentation
đź“ŚConsole Demo
<table class="center"> <tr style="line-height: 0"> <td width=50% height=30 style="border: none; text-align: center">LLaMA</td> <td width=50% height=30 style="border: none; text-align: center">LLaVA</td> </tr> <tr> <td width=25% style="border: none"><img src="Assets/console_demo.gif" style="width:100%"></td> <td width=25% style="border: none"><img src="Assets/llava_demo.gif" style="width:100%"></td> </tr> </table>
đź”—Integrations & Examples
There are integrations for the following libraries, making it easier to develop your APP. Integrations for semantic-kernel and kernel-memory are developed in the LLamaSharp repository, while others are developed in their own repositories.
- semantic-kernel: an SDK that integrates LLMs like OpenAI, Azure OpenAI, and Hugging Face.
- kernel-memory: a multi-modal AI Service specialized in the efficient indexing of datasets through custom continuous data hybrid pipelines, with support for RAG (Retrieval Augmented Generation), synthetic memory, prompt engineering, and custom semantic memory processing.
- BotSharp: an open source machine learning framework for AI Bot platform builder.
- Langchain: a framework for developing applications powered by language models.
The following examples show how to build APPs with LLamaSharp.
- Official Console Examples
- Unity Demo
- LLamaStack (with WPF and Web demo)
- Blazor Demo (with Model Explorer)
- ASP.NET Demo
- LLamaWorker (ASP.NET Web API like OAI and Function Calling Support)
🚀Get started
Installation
To gain high performance, LLamaSharp interacts with native libraries compiled from c++, these are called backends
. We provide backend packages for Windows, Linux and Mac with CPU, CUDA, Metal and Vulkan. You don't need to compile any c++, just install the backend packages.
If no published backend matches your device, please open an issue to let us know. If compiling c++ code is not difficult for you, you could also follow this guide to compile a backend and run LLamaSharp with it.
- Install LLamaSharp package on NuGet:
PM> Install-Package LLamaSharp
Install one or more of these backends, or use a self-compiled backend.
LLamaSharp.Backend.Cpu
: Pure CPU for Windows, Linux & Mac. Metal (GPU) support for Mac.LLamaSharp.Backend.Cuda11
: CUDA 11 for Windows & Linux.LLamaSharp.Backend.Cuda12
: CUDA 12 for Windows & Linux.LLamaSharp.Backend.Vulkan
: Vulkan for Windows & Linux.
(optional) For Microsoft semantic-kernel integration, install the LLamaSharp.semantic-kernel package.
(optional) To enable RAG support, install the LLamaSharp.kernel-memory package (this package only supports
net6.0
or higher yet), which is based on Microsoft kernel-memory integration.
Model preparation
There are two popular formats of model file of LLMs, these are PyTorch format (.pth) and Huggingface format (.bin). LLamaSharp uses a GGUF
format file, which can be converted from these two formats. To get a GGUF
file, there are two options:
Search model name + 'gguf' in Huggingface, you will find lots of model files that have already been converted to GGUF format. Please take note of the publishing time of them because some old ones may only work with older versions of LLamaSharp.
Convert PyTorch or Huggingface format to GGUF format yourself. Please follow the instructions from this part of llama.cpp readme to convert them with python scripts.
Generally, we recommend downloading models with quantization rather than fp16, because it significantly reduces the required memory size while only slightly impacting the generation quality.
Example of LLaMA chat session
Here is a simple example to chat with a bot based on a LLM in LLamaSharp. Please replace the model path with yours.
using LLama.Common;
using LLama;
string modelPath = @"<Your Model Path>"; // change it to your own model path.
var parameters = new ModelParams(modelPath)
{
ContextSize = 1024, // The longest length of chat as memory.
GpuLayerCount = 5 // How many layers to offload to GPU. Please adjust it according to your GPU memory.
};
using var model = LLamaWeights.LoadFromFile(parameters);
using var context = model.CreateContext(parameters);
var executor = new InteractiveExecutor(context);
// Add chat histories as prompt to tell AI how to act.
var chatHistory = new ChatHistory();
chatHistory.AddMessage(AuthorRole.System, "Transcript of a dialog, where the User interacts with an Assistant named Bob. Bob is helpful, kind, honest, good at writing, and never fails to answer the User's requests immediately and with precision.");
chatHistory.AddMessage(AuthorRole.User, "Hello, Bob.");
chatHistory.AddMessage(AuthorRole.Assistant, "Hello. How may I help you today?");
ChatSession session = new(executor, chatHistory);
InferenceParams inferenceParams = new InferenceParams()
{
MaxTokens = 256, // No more than 256 tokens should appear in answer. Remove it if antiprompt is enough for control.
AntiPrompts = new List<string> { "User:" } // Stop generation once antiprompts appear.
SamplingPipeline = new DefaultSamplingPipeline(),
};
Console.ForegroundColor = ConsoleColor.Yellow;
Console.Write("The chat session has started.\nUser: ");
Console.ForegroundColor = ConsoleColor.Green;
string userInput = Console.ReadLine() ?? "";
while (userInput != "exit")
{
await foreach ( // Generate the response streamingly.
var text
in session.ChatAsync(
new ChatHistory.Message(AuthorRole.User, userInput),
inferenceParams))
{
Console.ForegroundColor = ConsoleColor.White;
Console.Write(text);
}
Console.ForegroundColor = ConsoleColor.Green;
userInput = Console.ReadLine() ?? "";
}
For more examples, please refer to LLamaSharp.Examples.
đź’ˇFAQ
Why is my GPU not used when I have installed CUDA?
- If you are using backend packages, please make sure you have installed the CUDA backend package which matches the CUDA version installed on your system.
- Add the following line to the very beginning of your code. The log will show which native library file is loaded. If the CPU library is loaded, please try to compile the native library yourself and open an issue for that. If the CUDA library is loaded, please check if
GpuLayerCount > 0
when loading the model weight.
NativeLibraryConfig.Instance.WithLogCallback(delegate (LLamaLogLevel level, string message) { Console.Write($"{level}: {message}"); } )
Why is the inference so slow?
Firstly, due to the large size of LLM models, it requires more time to generate output than other models, especially when you are using models larger than 30B parameters.
To see if that's a LLamaSharp performance issue, please follow the two tips below.
- If you are using CUDA, Metal or Vulkan, please set
GpuLayerCount
as large as possible. - If it's still slower than you expect it to be, please try to run the same model with same setting in llama.cpp examples. If llama.cpp outperforms LLamaSharp significantly, it's likely a LLamaSharp BUG and please report that to us.
Why does the program crash before any output is generated?
Generally, there are two possible cases for this problem:
- The native library (backend) you are using is not compatible with the LLamaSharp version. If you compiled the native library yourself, please make sure you have checked-out llama.cpp to the corresponding commit of LLamaSharp, which can be found at the bottom of README.
- The model file you are using is not compatible with the backend. If you are using a GGUF file downloaded from huggingface, please check its publishing time.
Why is my model generating output infinitely?
Please set anti-prompt or max-length when executing the inference.
🙌Contributing
All contributions are welcome! There's a TODO list in LLamaSharp Dev Project and you can pick an interesting one to start. Please read the contributing guide for more information.
You can also do one of the following to help us make LLamaSharp better:
- Submit a feature request.
- Star and share LLamaSharp to let others know about it.
- Write a blog or demo about LLamaSharp.
- Help to develop Web API and UI integration.
- Just open an issue about the problem you've found!
Join the community
Join our chat on Discord (please contact Rinne to join the dev channel if you want to be a contributor).
Join QQ group
Star history
Contributor wall of fame
Map of LLamaSharp and llama.cpp versions
If you want to compile llama.cpp yourself you must use the exact commit ID listed for each version.
LLamaSharp | Verified Model Resources | llama.cpp commit id |
---|---|---|
v0.2.0 | This version is not recommended to use. | - |
v0.2.1 | WizardLM, Vicuna (filenames with "old") | - |
v0.2.2, v0.2.3 | WizardLM, Vicuna (filenames without "old") | 63d2046 |
v0.3.0, v0.4.0 | LLamaSharpSamples v0.3.0, WizardLM | 7e4ea5b |
v0.4.1-preview | Open llama 3b, Open Buddy | aacdbd4 |
v0.4.2-preview | Llama2 7B (GGML) | 3323112 |
v0.5.1 | Llama2 7B (GGUF) | 6b73ef1 |
v0.6.0 | cb33f43 |
|
v0.7.0, v0.8.0 | Thespis-13B, LLaMA2-7B | 207b519 |
v0.8.1 | e937066 |
|
v0.9.0, v0.9.1 | Mixtral-8x7B | 9fb13f9 |
v0.10.0 | Phi2 | d71ac90 |
v0.11.1, v0.11.2 | LLaVA-v1.5, Phi2 | 3ab8b3a |
v0.12.0 | LLama3 | a743d76 |
v0.13.0 | 1debe72 |
|
v0.14.0 | Gemma2 | 36864569 |
v0.15.0 | LLama3.1 | 345c8c0c |
v0.16.0 | 11b84eb4 |
|
v0.17.0 | c35e586e |
|
v0.18.0 | c35e586e |
|
v0.19.0 | 958367bf |
License
This project is licensed under the terms of the MIT license.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. 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 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 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. |
.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. |
-
.NETStandard 2.0
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.AI.Abstractions (>= 9.0.0-preview.9.24525.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- System.Linq.Async (>= 6.0.1)
- System.Numerics.Tensors (>= 8.0.0)
- System.Text.Json (>= 8.0.5)
-
net6.0
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.AI.Abstractions (>= 9.0.0-preview.9.24525.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- System.Numerics.Tensors (>= 8.0.0)
-
net8.0
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.AI.Abstractions (>= 9.0.0-preview.9.24525.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- System.Numerics.Tensors (>= 8.0.0)
NuGet packages (10)
Showing the top 5 NuGet packages that depend on LLamaSharp:
Package | Downloads |
---|---|
Microsoft.KernelMemory.AI.LlamaSharp
Provide access to OpenAI LLM models in Kernel Memory to generate text |
|
LLamaSharp.semantic-kernel
The integration of LLamaSharp and Microsoft semantic-kernel. |
|
LLamaSharp.kernel-memory
The integration of LLamaSharp and Microsoft kernel-memory. It could make it easy to support document search for LLamaSharp model inference. |
|
LangChain.Providers.LLamaSharp
LLamaSharp Chat model provider. |
|
LangChain.Providers.Automatic1111
Automatic1111 Stable DIffusion model provider. |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on LLamaSharp:
Repository | Stars |
---|---|
SciSharp/BotSharp
AI Multi-Agent Framework in .NET
|
Version | Downloads | Last updated |
---|---|---|
0.19.0 | 10,772 | 11/8/2024 |
0.18.0 | 13,451 | 10/19/2024 |
0.17.0 | 1,303 | 10/13/2024 |
0.16.0 | 54,234 | 9/1/2024 |
0.15.0 | 20,487 | 8/3/2024 |
0.14.0 | 3,444 | 7/16/2024 |
0.13.0 | 55,856 | 6/4/2024 |
0.12.0 | 87,879 | 5/12/2024 |
0.11.2 | 15,797 | 4/6/2024 |
0.11.1 | 859 | 3/31/2024 |
0.10.0 | 6,562 | 2/15/2024 |
0.9.1 | 10,416 | 1/6/2024 |
0.9.0 | 576 | 1/6/2024 |
0.8.1 | 23,595 | 11/28/2023 |
0.8.0 | 24,680 | 11/12/2023 |
0.7.0 | 1,868 | 10/31/2023 |
0.6.0 | 2,388 | 10/24/2023 |
0.5.1 | 7,298 | 9/5/2023 |
0.4.2-preview | 1,975 | 8/6/2023 |
0.4.1-preview | 1,262 | 6/21/2023 |
0.4.0 | 11,473 | 6/19/2023 |
0.3.0 | 10,751 | 5/22/2023 |
0.2.3 | 726 | 5/17/2023 |
0.2.2 | 649 | 5/17/2023 |
0.2.1 | 687 | 5/12/2023 |
0.2.0 | 895 | 5/12/2023 |
Updated llama.cpp version to c35e586ea57221844442c65a1172498c54971cb0