Cette page est affichée en anglais. Une traduction française est en cours.
SkillsMar 31, 2026·2 min de lecture

llama.cpp — Run LLMs Locally in Pure C/C++

llama.cpp is a C/C++ LLM inference engine with 100K+ GitHub stars. Runs on CPU, Apple Silicon, NVIDIA, AMD GPUs. 1.5-8 bit quantization, no dependencies, supports 50+ model architectures. MIT licensed

Prêt pour agents

Installation agent prête

Cet actif peut être installé après choix du runtime, vérification du plan et exécution de la commande adaptée.

Native · 98/100Policy : autoriser
Surface agent
Tout agent MCP/CLI
Type
Skill
Installation
Single
Confiance
Confiance : Established
Point d'entrée
llama.cpp — Run LLMs Locally in Pure C/C++
Commande d'installation directe
npx -y tokrepo@latest install b2e0b71d-4b40-45c0-9609-bc5e2abe7c0f --target codex

À exécuter après confirmation du plan en dry-run.

TL;DR
llama.cpp runs large language models locally on CPU and GPU with aggressive quantization and zero external dependencies.
§01

What it is

llama.cpp is an open-source LLM inference engine written in C/C++. It runs large language models locally on consumer hardware including CPUs, Apple Silicon, NVIDIA GPUs, and AMD GPUs. The project supports 1.5-8 bit quantization, which compresses models small enough to run on laptops and desktops without dedicated AI hardware.

llama.cpp is designed for developers, researchers, and privacy-conscious users who want to run LLMs locally without sending data to cloud APIs.

§02

How it saves time or tokens

Cloud API calls cost money per token and introduce network latency. llama.cpp lets you run inference locally at zero marginal cost after the initial model download. For development, testing, and experimentation, this means unlimited generations without worrying about API bills. Quantization (GGUF format) compresses a 70B parameter model to run on a machine with 32GB RAM, making local inference practical on standard hardware.

§03

How to use

  1. Install llama.cpp:
# Homebrew (macOS/Linux)
brew install llama.cpp

# Or build from source
git clone https://github.com/ggml-org/llama.cpp && cd llama.cpp
cmake -B build && cmake --build build --config Release
  1. Download a GGUF model file from Hugging Face or convert one yourself.
  1. Run inference:
llama-cli -m model.gguf -p 'Explain the observer pattern in two sentences' -n 128

Or start a local OpenAI-compatible API server:

llama-server -m model.gguf --port 8080
§04

Example

Using the OpenAI-compatible server with a Python client:

from openai import OpenAI

client = OpenAI(
    base_url='http://localhost:8080/v1',
    api_key='not-needed',
)

response = client.chat.completions.create(
    model='local-model',
    messages=[{'role': 'user', 'content': 'Write a haiku about compilers'}],
)
print(response.choices[0].message.content)

This works with any OpenAI-compatible client library, making it a drop-in replacement for cloud APIs during development.

§05

Related on TokRepo

§06

Common pitfalls

  • Downloading a model that is too large for your RAM. A Q4_K_M quantized 70B model needs approximately 40GB RAM. Check model card memory requirements before downloading.
  • Not enabling GPU offloading when a GPU is available. Use -ngl 99 to offload all layers to GPU for significantly faster inference.
  • Using the wrong GGUF file for your hardware. Q4_K_M is a good default balance of quality and speed. Q2_K is smaller but noticeably lower quality. Q8_0 is highest quality but needs more RAM.
  • Starting with an overly complex configuration instead of defaults. Begin with the minimal setup, verify it works, then customize incrementally. This approach catches configuration errors early and keeps troubleshooting straightforward.

Questions fréquentes

What is GGUF format?+

GGUF (GPT-Generated Unified Format) is the model file format used by llama.cpp. It stores quantized model weights, tokenizer data, and metadata in a single file. GGUF replaced the older GGML format and supports more model architectures.

Which models can llama.cpp run?+

llama.cpp supports 50+ model architectures including Llama, Mistral, Phi, Gemma, Qwen, StarCoder, and many more. Any model that has been converted to GGUF format can be loaded. Hugging Face hosts thousands of pre-quantized GGUF models.

How does quantization affect model quality?+

Quantization reduces precision from 16-bit to 4-8 bits, which compresses model size by 2-4x. Quality loss is minimal at Q4_K_M and above. Below Q4, outputs may become noticeably less coherent. The tradeoff is between memory usage and generation quality.

Can llama.cpp use multiple GPUs?+

Yes. llama.cpp supports splitting model layers across multiple GPUs using the -ngl flag with layer assignments. This enables running larger models that do not fit in a single GPU's VRAM.

Is llama.cpp fast enough for production use?+

llama.cpp is suitable for production workloads with moderate concurrency. The server mode handles multiple concurrent requests. For high-throughput production serving, consider vLLM or TGI, which are optimized for batch processing and GPU utilization.

Sources citées (3)
🙏

Source et remerciements

Created by Georgi Gerganov. Licensed under MIT. ggml-org/llama.cpp — 100,000+ GitHub stars

Fil de discussion

Connectez-vous pour rejoindre la discussion.
Aucun commentaire pour l'instant. Soyez le premier à partager votre avis.

Actifs similaires