LM-Kit.NET 2024.12.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package LM-Kit.NET --version 2024.12.2                
NuGet\Install-Package LM-Kit.NET -Version 2024.12.2                
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="LM-Kit.NET" Version="2024.12.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LM-Kit.NET --version 2024.12.2                
#r "nuget: LM-Kit.NET, 2024.12.2"                
#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 LM-Kit.NET as a Cake Addin
#addin nuget:?package=LM-Kit.NET&version=2024.12.2

// Install LM-Kit.NET as a Cake Tool
#tool nuget:?package=LM-Kit.NET&version=2024.12.2                

Enterprise-Grade .NET SDK for Integrating Generative AI Capabilities

Build Smarter Apps with Language Models

LM-Kit.NET integrates cutting-edge Generative AI into C# and VB.NET applications through on-device LLM inference, ensuring rapid, secure, and private AI performance without the need for cloud services. Key features include AI chatbot development, natural language processing (NLP), retrieval-augmented generation (RAG), structured data extraction, text improvement, translation, and more.

<br/>

Wide Range of Capabilities

LM-Kit.NET offers a suite of highly optimized low-level APIs designed to facilitate the development of fully customized Large Language Model (LLM) inference pipelines for C# and VB.NET developers.

Additionally, LM-Kit.NET provides an extensive array of high-level AI functionalities across multiple domains, grouped into the following categories:

Data Processing

  • πŸ—ƒοΈ Structured Data Extraction: Accurately extract and structure data from any source using customizable extraction schemes.
  • πŸ” Retrieval-Augmented Generation (RAG): Enhance text generation with information retrieved from a large corpus.

Text Analysis

  • 😊 Emotion and Sentiment Analysis: Detect and interpret the emotional tone from text.
  • 🏷️ Custom Text Classification: Categorize text into predefined classes based on content.
  • πŸ”‘ Keyword Extraction: Identify the most relevant keywords or phrases within large volumes of text.
  • πŸ”’ Text Embeddings: Transform text into numerical representations that capture semantic meanings.

AI Agents Orchestration

  • πŸ’¬ Chatbot & Conversational AI: Develop AI chatbots capable of engaging in natural and context-aware conversations.
  • ❓ Question Answering: Provide answers to queries, supporting both single-turn and multi-turn interactions.
  • πŸ”— Function Calling: Dynamically invoke specific functions within your application.

Language Services

  • 🌐 Language Detection: Identify the language of text input with high accuracy.
  • πŸ”„ Translation: Seamlessly convert text between multiple languages.

Text Generation

  • πŸ“ Structured Content Creation: Generate content that follows a predefined structure using JSON schemas, templates, or grammar rules.
  • πŸ“ Content Summarization: Condense long pieces of text into concise summaries.
  • ✍️ Grammar & Spell Check: Correct grammar and spelling in text of any length.
  • πŸ”„ Text Enhancement: Rewrite text to improve clarity, style, or adapt to a specific communication tone.

Model Customization and Optimization

  • πŸ› οΈ Model Fine-Tuning: Customize pre-trained models to better suit specific needs.
  • βš™οΈ Model Quantization: Optimize models for efficient inference.
  • πŸ”— LoRA Adapter Support: Merge Low-Rank Adaptation (LoRA) transformations into base models for efficient fine-tuning.

And More

  • πŸš€ Additional Features: Explore other functionalities that extend your application's capabilities.

These ever-expanding functionalities ensure seamless integration of advanced AI solutions, tailored to meet diverse needs through a single Software Development Kit (SDK) for C# and VB.NET application development.

<br/>

Run Local LLMs on Any Device

The LM-Kit.NET model inference system is built to deliver high performance across a wide variety of hardware with minimal setup and no external dependencies. LM-Kit.NET runs inference entirely on-device, also known as edge computing, providing users with full control and precise tuning of the inference process. Moreover, LM-Kit.NET supports an ever-growing list of model architectures, including LLaMA-2, LLaMA-3, Mistral, Falcon, Phi, and others.

<br/>

Highest Degree of Performance

1. πŸš€ Optimized for Various GPUs and CPUs

LM-Kit.NET is expertly engineered to maximize the capabilities of a wide range of hardware configurations, ensuring top-tier performance across all platforms. This multi-platform optimization allows LM-Kit.NET to specifically leverage the unique hardware strengths of each device. For instance, it automatically utilizes CUDA on NVIDIA GPUs to significantly boost computation speeds, Metal on Apple devices to enhance both graphics and processing tasks, and Vulkan to efficiently harness the power of multiple GPUsβ€”including those from AMD, Intel, and NVIDIAβ€”across diverse environments.

2. βš™οΈ State-of-the-Art Architectural Foundations

At the core of LM-Kit.NET lies llama.cpp, which serves as the native inference framework. This powerful engine has been rigorously optimized to handle a wide array of scenarios efficiently. Its advanced internal caching and recycling mechanisms are designed to maintain high performance levels consistently, even under varied operational conditions. Whether your application is running a single instance or multiple concurrent instances, LM-Kit.NET's sophisticated core system orchestrates all requests smoothly, delivering rapid performance while minimizing resource consumption.

3. 🌟 Unrivaled Performance

Experience model inference speeds up to 5Γ— faster with LM-Kit.NET, thanks to its cutting-edge underlying technologies that are continuously refined and benchmarked to ensure you stay ahead of the curve.

<br/>

Be an Early Adopter of the Latest and Future Generative AI Innovations

LM-Kit.NET is crafted by industry experts employing a strategy of continuous innovation. It is designed to rapidly address emerging market needs and introduce new capabilities to modernize existing applications. Leveraging state-of-the-art AI technologies, LM-Kit.NET offers a modern, user-friendly, and intuitive API suite, making advanced AI accessible for any type of application in C# and VB.NET.

<br/>

Maintain Full Control Over Your Data

Maintaining full control over your data is crucial for both privacy and security. By using LM-Kit.NET, which performs model inference directly on-device, you ensure that your sensitive data remains within your controlled environment and does not traverse external networks. Here are some key benefits of this approach:

1. πŸ”’ Enhanced Privacy

All data processing is done locally on your device, eliminating the need to send data to a remote server. This drastically reduces the risk of exposure or leakage of sensitive information, keeping your data confidential.

2. πŸ›‘οΈ Increased Security

With zero external requests, the risk of data interception during transmission is completely eliminated. This closed-system approach minimizes vulnerabilities that are often exploited in data breaches, offering a more secure solution.

3. ⚑ Faster Response Times

Processing data locally reduces the latency typically associated with sending data to a remote server and waiting for a response. This results in quicker model inferences, leading to faster decision-making and improved user experience.

4. πŸ“‰ Reduced Bandwidth Usage

By avoiding the need to transfer large volumes of data over the internet, LM-Kit.NET minimizes bandwidth consumption. This is particularly beneficial in environments with limited or costly data connectivity.

5. βœ… Full Compliance with Data Regulations

Local processing helps in complying with strict data protection regulations, such as GDPR or HIPAA, which often require certain types of data to be stored and processed within specific geographical boundaries or environments. By leveraging LM-Kit.NET's on-device processing capabilities, organizations can achieve higher levels of data autonomy and protection while still benefiting from advanced computational models and real-time analytics.

<br/>

Seamless Integration and Simple Deployment

LM-Kit.NET offers an exceptionally streamlined deployment model, packaged as a single NuGet package for all supported platforms. Integrating LM-Kit.NET into any C# or VB.NET application is a straightforward process, typically requiring just a few clicks. LM-Kit.NET combines C# and C++ code, meticulously crafted without external dependencies to perfectly suit its functionalities.

1. πŸ”§ Simplified Integration

LM-Kit.NET requires no external containers or complex deployment procedures, making the integration process exceptionally straightforward. This approach significantly reduces development time and lowers the learning curve, enabling a broader range of developers to effectively deploy and leverage the technology.

2. πŸš€ Streamlined Deployment

Designed for efficiency and simplicity, LM-Kit.NET runs directly within the same application process that calls it by default, avoiding the complexities and resource demands typically associated with containerized systems. This direct integration accelerates performance and simplifies incorporation into existing applications by removing common hurdles associated with container use.

3. βš™οΈ Efficient Resource Management

Operating in-process, LM-Kit.NET minimizes its impact on system resources, making it ideal for devices with limited capacity or situations where maximizing computing efficiency is essential.

4. 🌟 Enhanced Reliability

By avoiding reliance on external services or containers, LM-Kit.NET offers more stable and predictable performance. This reliability is vital for applications that demand consistent, rapid data processing without external dependencies.

<br/>

Supported Operating Systems

LM-Kit.NET is designed for full compatibility with a wide range of operating systems, ensuring smooth and reliable performance on all supported platforms:

  • πŸͺŸ Windows: Compatible with versions from Windows 7 through to the latest release.
  • 🍏 macOS: Supports macOS 11 and all subsequent versions.
  • 🐧 Linux: Functions optimally on distributions with glibc version 2.27 or newer.

<br/>

Supported .NET Frameworks

LM-Kit.NET is compatible with a wide range of .NET frameworks, spanning from version 4.6.2 up to .NET 9. To maximize performance through specific optimizations, separate binaries are provided for each supported framework version.

<br/>

Hugging Face Integration

The LM-Kit section on Hugging Face provides state-of-the-art quantized models that have been rigorously tested with the LM-Kit SDK. Moreover, LM-Kit enables you to seamlessly load models directly from Hugging Face repositories via the Hugging Face API, simplifying the integration and deployment of the latest models into your C# and VB.NET applications.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  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 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 is compatible.  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. 
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
2025.1.9 46 1/27/2025
2025.1.8 98 1/26/2025
2025.1.7 83 1/24/2025
2025.1.6 352 1/22/2025
2025.1.4 215 1/19/2025
2025.1.3 300 1/18/2025
2025.1.2 278 1/11/2025
2025.1.1 524 1/1/2025
2024.12.13 148 12/29/2024
2024.12.12 303 12/26/2024
2024.12.11 340 12/23/2024
2024.12.10 368 12/22/2024
2024.12.9 250 12/20/2024
2024.12.8 192 12/19/2024
2024.12.7 409 12/15/2024
2024.12.6 343 12/13/2024
2024.12.5 304 12/11/2024
2024.12.4 329 12/10/2024
2024.12.3 397 12/7/2024
2024.12.2 222 12/7/2024
2024.12.1 194 12/6/2024
2024.11.10 318 11/29/2024
2024.11.9 202 11/27/2024
2024.11.8 232 11/25/2024
2024.11.7 176 11/25/2024
2024.11.6 220 11/25/2024
2024.11.5 346 11/23/2024
2024.11.4 281 11/18/2024
2024.11.3 176 11/12/2024
2024.11.2 145 11/5/2024
2024.11.1 153 11/4/2024
2024.10.5 192 10/24/2024
2024.10.4 227 10/17/2024
2024.10.3 151 10/16/2024
2024.10.2 182 10/9/2024
2024.10.1 189 10/1/2024
2024.9.4 163 9/25/2024
2024.9.3 197 9/18/2024
2024.9.2 181 9/11/2024
2024.9.1 177 9/6/2024
2024.9.0 162 9/3/2024
2024.8.4 173 8/26/2024
2024.8.3 201 8/21/2024
2024.8.2 161 8/20/2024
2024.8.1 178 8/15/2024
2024.8.0 135 8/11/2024
2024.7.10 130 8/6/2024
2024.7.9 107 7/31/2024
2024.7.8 90 7/30/2024
2024.7.7 101 7/29/2024
2024.7.6 111 7/27/2024
2024.7.5 147 7/26/2024