Welcome Gemma 4: Frontier multimodal intelligence on device

Hugging Face Blog Models

Summary

Google DeepMind releases Gemma 4, a frontier multimodal model family available on Hugging Face with Apache 2 licensing, optimized for on-device deployment and supported by various inference libraries.

No content available
Original Article
View Cached Full Text

Cached at: 05/08/26, 09:09 AM

Welcome Gemma 4: Frontier multimodal intelligence on device

Source: https://huggingface.co/blog/gemma4 Back to Articles

The Gemma 4 family of multimodal models by Google DeepMind is out on Hugging Face, with support for your favorite agents, inference engines, and fine-tuning libraries 🤗

These models are the real deal: truly open with Apache 2 licenses, high quality with pareto frontier arena scores, multimodal including audio, and sizes you can useeverywhereincluding on-device. Gemma 4 builds on advances from previous families and makes them click together. In our tests with pre-release checkpoints we have been impressed by their capabilities, to the extent that we struggled to find good fine-tuning examples because they areso goodout of the box.

We collaborated with Google and the community to make them available everywhere: transformers, llama.cpp, MLX, WebGPU, Rust; you name it. This blog post will show you how to build withyour favorite toolsso let us know what you think!

https://huggingface.co/blog/gemma4#table-of-contentsTable of Contents

https://huggingface.co/blog/gemma4#what-is-new-with-gemma-4What is new with Gemma 4?

Similar to Gemma-3n, Gemma 4 supports image, text, and audio inputs, and generates text responses. The text decoder is based on the Gemma model with support for long context windows. The image encoder is similar to the one from Gemma 3 but with two crucial improvements: variable aspect ratios, and configurable number of image token inputs to find your sweet spot between speed, memory, and quality. All models support images (or video) and text inputs, while the small variants (E2B and E4B) support audio as well.

Gemma 4 comes in four sizes, all base and instruction fine-tuned:

ModelParameter SizeContext WindowCheckpointsGemma 4 E2B2.3B effective, 5.1B with embeddings128kbase,ITGemma 4 E4B4.5B effective, 8B with embeddings128kbase,ITGemma 4 31B31B dense model256Kbase,ITGemma 4 26B A4Bmixture-of-experts with 4B activated/26B total parameters256Kbase,IT

https://huggingface.co/blog/gemma4#overview-of-capabilities-and-architectureOverview of Capabilities and Architecture

Gemma 4 leverages several architecture components used in previous Gemma versions and other open models, and leaves out complex or inconclusive features such as Altup. The combination is a mix designed to be highly compatible across libraries and devices, that can efficiently support long context and agentic use cases, whilst being ideal for quantization.

As shown in the benchmarks above, this feature mix (combined with the training data and recipe) enables the 31B dense model to achieve an estimated LMArena score (text only) of 1452, while the 26B MoE reaches 1441 with just 4B active parameters 🤯. As we’ll see, multimodal operation is comparatively as good as text generation, at least in informal and subjective tests.

These are the main architecture characteristics in Gemma 4:

  • Alternatinglocal sliding-windowandglobal full-contextattention layers. Smaller dense models use sliding windows of 512 tokens while larger models use 1024 tokens.
  • Dual RoPEconfigurations: standard RoPE for sliding layers, pruned RoPE for global layers, to enable longer context.
  • Per-Layer Embeddings (PLE): a second embedding table that feeds a small residual signal into every decoder layer.
  • Shared KV Cache: the last N layers of the model reuse key-value states from earlier layers, eliminating redundant KV projections.
  • Vision encoder: uses learned 2D positions and multidimensional RoPE. Preserves the original aspect ratios and can encode images to a few different token budgets (70, 140, 280, 560, 1120).
  • Audio encoder: USM-style conformer with the same base architecture as the one in Gemma-3n.

https://huggingface.co/blog/gemma4#per-layer-embeddings-plePer-Layer Embeddings (PLE)

One of the most distinctive features in smaller Gemma 4 models is Per-Layer Embeddings (PLE), which was introduced previously in Gemma-3n. In a standard transformer, each token gets a single embedding vector at input, and the same initial representation is what the residual stream builds on across all layers, forcing the embedding to frontload everything the model might need. PLE adds a parallel, lower-dimensional conditioning pathway alongside the main residual stream. For each token, it produces a small dedicated vector for every layer by combining two signals: a token-identity component (from an embedding lookup) and a context-aware component (from a learned projection of the main embeddings). Each decoder layer then uses its corresponding vector to modulate the hidden states via a lightweight residual block after attention and feed-forward. This gives each layer its own channel to receive token-specific information only when it becomes relevant, rather than requiring everything to be packed into a single upfront embedding. Because the PLE dimension is much smaller than the main hidden size, this adds meaningful per-layer specialization at modest parameter cost. For multimodal inputs (images, audio, video), PLE is computed before soft tokens are merged into the embedding sequence — since PLE relies on token IDs that are lost once multimodal features replace the placeholders. Multimodal positions use the pad token ID, effectively receiving neutral per-layer signals.

https://huggingface.co/blog/gemma4#shared-kv-cacheShared KV Cache

Theshared KV cacheis an efficiency optimization that reduces both compute and memory during inference. The lastnum\_kv\_shared\_layerslayers of the model don’t compute their own key and value projections. Instead, theyreusethe K and V tensors from the last non-shared layer of the same attention type (sliding or full).

In practice, this has a minimal impact on quality while being much more efficient (in terms of both memory and compute) for long context generation and on-device use.

https://huggingface.co/blog/gemma4#multimodal-capabilitiesMultimodal Capabilities

We saw in our tests that Gemma 4 supports comprehensive multimodal capabilities out of the box. We don’t know what was the training mix, but we had success using it for tasks such as OCR, speech-to-text, object detection, or pointing. It also supports text-only and multimodal function calling, reasoning, code completion and correction.

Here, we show a few inference examples across different model sizes. You can run them conveniently withthis notebook. We encourage you to try the demos and share them below this blog!

https://huggingface.co/blog/gemma4#object-detection-and-pointingObject Detection and Pointing

https://huggingface.co/blog/gemma4#gui-detectionGUI detection

We test Gemma 4 on GUI element detection and pointing across different sizes, with the following image and text prompt: “What’s the bounding box for the “view recipe” element in the image?“

Image

With this prompt, the model natively responds in JSON format with the detected bounding boxes - no need for specific instructions or grammar-constrained generation. We found the coordinates refer to an image size of 1000x1000, relative to the input dimensions.

We visualize the outputs below for your convenience. We parse the bounding boxes from the returned JSON:json\\n\[\\n \{"box\_2d": \[171, 75, 245, 308\], "label": "view recipe element"\}\\n\]\\n

https://huggingface.co/blog/gemma4#object-detectionObject Detection

We test models to detect everyday objects, here we ask them to detect the bike and compare different model outputs. As in the previous case, we parse the bounding box from the json and translate to image space coordinates.

https://huggingface.co/blog/gemma4#multimodal-thinking-and-function-callingMultimodal Thinking and Function Calling

We asked Gemma 4 to write HTML code to reconstruct a page we made with Gemini 3. Below you can find the code to do this, we enable thinking and ask each model to generate up to 4000 new tokens, to make it foolproof.

Inference code``` messages = [ { “role”: “user”, “content”: [ { “type”: “image”, “image”: “https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/landing_page.png”, }, {“type”: “text”, “text”: “Write HTML code for this page.”}, ], } ] inputs = processor.apply_chat_template( messages, tokenize=True, return_dict=True, return_tensors=“pt”, add_generation_prompt=True, enable_thinking=True, ).to(model.device) output = model.generate(**inputs, max_new_tokens=4000) input_len = inputs.input_ids.shape[-1] generated_text_ids = output[0][input_len:] generated_text = processor.decode(generated_text_ids, skip_special_tokens=True) result = processor.parse_response(generated_text) print(result[“content”])


### [https://huggingface.co/blog/gemma4#video-understanding](https://huggingface.co/blog/gemma4#video-understanding)Video Understanding

Smaller Gemma 4 models can take in videos with audio while larger ones can take in videos without audio\. While the models are not explicitly post\-trained on videos, they can understand videos both with and without audio\. The model is particularly strong in audios

Inference code```
messages = [
    {
        "role": "user",
        "content": [
            {"type": "video", "url": "https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/concert.mp4"},
            {"type": "text", "text": "What is happening in the video? What is the song about?"},
        ],
    },
]
inputs = processor.apply_chat_template(
    messages,
    tokenize=True,
    return_dict=True,
    return_tensors="pt",
    add_generation_prompt=True,
    load_audio_from_video=True, # disable this for larger models
).to(model.device)
output = model.generate(**inputs, max_new_tokens=200)
input_len = inputs.input_ids.shape[-1]
generated_text_ids = output[0][input_len:]
generated_text = processor.decode(generated_text_ids, skip_special_tokens=True)
print(result["content"])

ModelOutputE2B (hallucinated for the audio)Based on the video provided, here is an analysis:**What is happening in this video?**The video captures a live musical performance, likely at a large outdoor festival or concert. ***Setting:**The scene is a large stage set up outdoors, indicated by the extensive lighting rig, large speakers, and the audience visible in the foreground. ***Performers:**There are several musicians on stage. The focal point seems to be a lead singer/guitarist in a blue shirt and white pants who is actively performing, playing an acoustic or electric guitar. There are also other musicians, including drummers and bassists, visible in the background. ***Atmosphere:**The atmosphere is energetic and dramatic, characterized by bright stage lights, intense blue and white spotlights, and a significant amount of stage fog/smoke, which adds to the concert mood. ***Audience:**The foreground is filled with the backs of audience members, showing they are close to the stage and engaged in watching the performance.**What is the song about?**The lyrics provided below the video are: > “I don’t care ’bout street > From what I cherish > Could it’s time to protestE4B ✅The video captures a live performance of a band on a stage with bright lights and smoke effects, surrounded by an audience. The band performs and sings to the crowd. The song appears to be about the struggles and disillusionment of modern life, specifically the feeling of being stuck and the difficulties in finding one’s place in a chaotic and overwhelming world. Lyrics mention themes of the “concrete street,” “broken promises,” “storm of the day,” and the difficulty of finding oneself amidst societal pressures.26/A4B (no audio) ✅This video shows a live music performance at an outdoor concert or festival at night. A solo male artist, dressed in a blue shirt and white pants, is the central focus. He is playing an acoustic guitar and singing into a microphone on a large, lit stage. The performance is accompanied by a band, including a drummer and other musicians visible in the background and on large video screens. The stage is filled with atmospheric blue lighting, smoke, and bright spotlights. The video captures different perspectives, including shots from the crowd looking up at the stage and close-up views of the performers projected onto large screens. The crowd is visible in the foreground, watching the show. One of the screens also displays the “Estrella Damm” brand name.31B (no audio) ✅A musician is performing on stage during a concert, playing an acoustic guitar and singing into a microphone. He is wearing a blue shirt and white pants. The stage is filled with atmospheric smoke and illuminated by bright blue and white lights. Other band members, including a drummer and a keyboardist, are also visible on stage. The video shows the musician from the perspective of the audience, with some shots focusing on him and others showing the large screen on the side of the stage, which displays close-ups of the performer and the crowd.

https://huggingface.co/blog/gemma4#captioningCaptioning

We have tested all models on captioning. All checkpoints perform very well and accurately capture nuance in complex scenerios. Here’s the image we use, with the prompt “Write single detailed caption for this image.”.

image

Inference code``` messages = [ { “role”: “user”, “content”: [ {“type”: “image”, “url”: “https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/bird.png”}, {“type”: “text”, “text”: “Write single detailed caption for this image.”}, ], }, ] inputs = processor.apply_chat_template( messages, tokenize=True, return_dict=True, return_tensors=“pt”, add_generation_prompt=True, ).to(model.device) output = model.generate(**inputs, max_new_tokens=512) input_len = inputs.input_ids.shape[-1] generated_text_ids = output[0][input_len:] generated_text = processor.decode(generated_text_ids, skip_special_tokens=True) result = processor.parse_response(generated_text) print(result[“content”])


ModelOutputE2B ✅A medium shot captures a weathered seagull perched atop a stone pedestal in what appears to be a bustling European square, with a grand, classical\-style building featuring ornate columns and architectural details dominating the right side of the frame\. In the background, a low, light\-colored building stretches across the middle ground, flanked by some green foliage, and hints of other structures, including a terracotta\-roofed building, are visible\. In the foreground, part of a modern bus stop or shelter is visible, with signage indicating routes, and the overall scene is bathed in bright daylight under a pale sky\.E4B ✅A solitary seagull perches atop a grey stone pedestal in a bustling European piazza, with the historical grandeur of a classical building dominating the right side of the frame, contrasting with the more modern, low\-rise architecture in the background under a bright, hazy sky\.26B/A4B ✅A full shot shows a white and brown seagull perched on a gray pillar in Venice, Italy\. The seagull faces left, its beak pointed towards the edge of the frame\. Behind it is a light gray, two\-story building with several dark rectangular windows\. To the right of the seagull is a large, white building with columns and intricate carvings\. The sky is a clear, light blue\. The lighting is bright and even, suggesting it is daytime\.31B ✅A high\-angle, medium shot shows a white and gray seagull perched on a gray concrete pylon in Venice, Italy\. The seagull is facing left, its body angled slightly towards the camera\. Its white head, neck, and chest contrast with its gray wings and back\. The seagull's orange beak is slightly open\. The pylon is a light gray concrete cylinder with a weathered texture\. In the background, there are several buildings\. To the left is a long, low, white building with a series of small, rectangular windows\. In the center is a cluster of green trees\. To the right is a red building with a tiled roof and several small, rectangular windows\. Further right is a large, ornate, white stone building with several columns and sculptures\. The sky is a pale blue, and the light is bright and clear\. In the lower\-left corner, there is a yellow bus with the word "Ferrovia" printed on it in black letters\. There are several people walking in the background, but they are small and out of focus\.
### [https://huggingface.co/blog/gemma4#audio-question-answering](https://huggingface.co/blog/gemma4#audio-question-answering)Audio Question Answering

These models are trained to answer questions about speech in audio\. Music and non\-speech sounds were not part of the training data\.

Inference code```
messages = [
    {
        "role": "user",
        "content": [
            {"type": "audio", "url": "https://huggingface.co/datasets/hf-internal-testing/dummy-audio-samples/resolve/main/obama_first_45_secs.mp3"},
            {"type": "text", "text": "Can you describe this audio in detail?"},
        ],
    },
]

inputs = processor.apply_chat_template(
    messages,
    tokenize=True,
    return_dict=True,
    return_tensors="pt",
    add_generation_prompt=True,
).to(model.device)

output = model.generate(
    **inputs,
    max_new_tokens=1000,
    do_sample=False,
)

print(processor.decode(output[0], skip_special_tokens=True))

ModelOutputE2BThis audio is a personal reflection. The speaker is talking about their final farewell address to the nation, which they delivered in Chicago. They express gratitude for the conversations they’ve had with the American people, noting that despite not having met them face-to-face or even greeted them, these interactions in various settings like living rooms, schools, farms, factory floors, diners, and military outposts have been what has kept them going.E4BThe audio is a speech excerpt where a speaker is delivering a farewell address to the nation from Chicago. The speaker reflects on their time in office, expressing gratitude for the conversations they had with the American people across various settings like living rooms, schools, farms, factories, diners, and military outposts. The tone is reflective and appreciative, highlighting the importance of these interactions in their political journey. Here is an example if you want to do transcription:

Inference code``` messages = [ { “role”: “user”, “content”: [ {“type”: “audio”, “url”: “https://huggingface.co/datasets/hf-internal-testing/dummy-audio-samples/resolve/main/obama_first_45_secs.mp3”}, {“type”: “text”, “text”: “Transcribe the audio?”}, ], }, ]

inputs = processor.apply_chat_template( messages, tokenize=True, return_dict=True, return_tensors=“pt”, add_generation_prompt=True, ).to(model.device)

output = model.generate( **inputs, max_new_tokens=1000, do_sample=False, )

print(processor.decode(output[0], skip_special_tokens=True))


ModelOutputE2BThis week I traveled to Chicago to deliver my final farewell address to the nation following in the tradition of presidents before me It was an opportunity to say thank you whether we've seen eye to eye or rarely agreed at all my conversations with you the American people in living rooms and schools at farms and on factory floors at diners and on distant military outposts all these conversations are what have kept me honestE4BThis week I traveled to Chicago to deliver my final farewell address to the nation following in the tradition of presidents before me\. It was an opportunity to say thank you\. Whether we've seen eye to eye or rarely agreed at all, my conversations with you, the American people, in living rooms and schools, at farms and on factory floors, at diners and on distant military outposts, all these conversations are what have kept me honest\.
### [https://huggingface.co/blog/gemma4#multimodal-function-calling](https://huggingface.co/blog/gemma4#multimodal-function-calling)Multimodal Function Calling

We test the model by asking to get the weather in the place shown in the image\.

Inference code```
import re 
WEATHER_TOOL = {
    "type": "function",
    "function": {
        "name": "get_weather",
        "description": "Gets the current weather for a specific location.",
        "parameters": {
            "type": "object",
            "properties": {
                "city": {"type": "string", "description": "The city name"},
            },
            "required": ["city"],
        },
    },
}
tools = [WEATHER_TOOL]
messages = [
    {"role": "user", "content": [
          {"type": "text", "text": "What is the city in this image? Check the weather there right now."},

        {"type": "image", "image": "https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/thailand.jpg"},
    ]},
]
inputs = processor.apply_chat_template(
    messages,
    tools=[WEATHER_TOOL],
    tokenize=True,
    return_dict=True,
    return_tensors="pt",
    add_generation_prompt=True,
    enable_thinking=True,
).to(model.device)
output = model.generate(**inputs, max_new_tokens=1000)
input_len = inputs.input_ids.shape[-1]
generated_text_ids = output[0][input_len:]
generated_text = processor.decode(generated_text_ids, skip_special_tokens=True)
result = processor.parse_response(generated_text)
print(result["content"])

ModelOutputE2B**Analyze the Request:**The user has provided an image and asked two questions:\n * “What is the city in this image?” * “Check the weather there right now.”\n\n2.**Analyze the Image:**The image displays a large, ornate, tall structure, characteristic of temple architecture, likely in Southeast Asia (given the style). It appears to be a famous landmark. 3.**Identify the Landmark/Location (Internal Knowledge/Visual Cues):**The structure strongly resembles the chedis/stupas found in places like Bangkok, Thailand (e.g., Wat Arun or similar structures).\n\n4.**Determine the City:**Based on the visual evidence, the location is highly likely to be Bangkok, Thailand.\n\n5.**Check Available Tools:**The available tool isget\_weather\(city: STRING\). 6. **Formulate the Plan:**\n * Step 1: Identify the city from the image (Bangkok).\n * Step 2: Use theget\_weathertool with the identified city.\n\n7.Construct the Tool Call:get\_weather\(city="Bangkok"\)\n\n8.**Generate Response:**The model should first state the identified city and then call the tool to get the weather. (Self-correction: The modelmustcall the tool in the correct format if it needs external information.)call:get_weather{city:Bangkok}E4B’1.**Analyze the Request:**The user has provided an image and asked two things:\n a. Identify the city in the image.\n b. Check the weather in that city right now.\n\n2.**Analyze the Image:**The image shows a very distinctive, ornate tower/spire structure, characteristic of Thai architecture (specifically, a chedi or prang).\n\n3.**Determine City Identification (Internal Knowledge/Visual Recognition):**Based on the architectural style, the structure strongly resembles prominent temples in Thailand, such as Wat Arun in Bangkok.\n\n4.**Evaluate Tool Availability:**I have one available tool:get\_weather\(city: STRING\). This tool requires a city name as input.\n\n5. **Formulate a Plan:**\n a. I need the city name to use theget\_weathertool.\n b. I must first identify the city from the image.\n c. Since my internal knowledge suggests Bangkok, I will proceed with that assumption, but I must acknowledge that I cannotdefinitivelyprove the location from the image alone.\n\n6.**Execute Step 1 (City Identification):**Assume the city is Bangkok based on the visual evidence of the architecture.\n\n7.**Execute Step 2 (Tool Call Generation):**Use theget\_weathertool with “Bangkok” as thecityargument.\n\n8.**Construct the Response:**Generate the appropriate tool call in JSON format.’, ‘answer’: ’<|tool_call>call:get_weather{city:<|“|>Bangkok<|”|>}<tool_call|>’31BThe user wants to know the city in the image and the current weather there. 1.**Analyze the image:**The image shows ornate, spire-like structures (prangs) characteristic of Thai temple architecture. Specifically, these look like the prangs at Wat Phra Kaew (Temple of the Emerald Buddha) or Wat Pho in Bangkok, Thailand. The style is very distinctive of Bangkok’s royal temple complexes. 2.**Identify the city:**Based on the architectural style, the city is Bangkok. 3.**Find the weather:**I need to call theget\_weathertool withcity="Bangkok".call:get_weather{city:Bangkok}26/A4BThe image shows several tall, ornate towers (prangs) typical of Thai Buddhist temple architecture. Specifically, these look like the structures within the Grand Palace or Wat Phra Kaew in Bangkok, Thailand. The style is unmistakably Thai. I’ll confirm this by looking at the specific towers. These are very iconic.\n2.**Confirm the location:**The image shows elements of the Grand Palace complex in Bangkok.\n3.**Get weather information:**Once the city is identified as Bangkok, I will use theget\_weathertool withcity='Bangkok'.call:get_weather{city:Bangkok}

https://huggingface.co/blog/gemma4#deploy-anywhereDeploy Anywhere

Gemma 4 comes with day-0 support for many open-source inference engines, and is ideal for tool calling and agents! We also release ONNX checkpoints that can run on many hardware backends, allowing use cases on edge devices or in browser!

https://huggingface.co/blog/gemma4#transformerstransformers

Gemma 4 comes with first-class transformers support from the get-go 🤗. This integration allows using the model with other libraries like bitsandbytes, PEFT and TRL. Make sure to install the latest version of transformers.

pip install -U transformers

The easiest way to infer with the small Gemma 4 models is through theany\-to\-anypipeline. You can initialize it as follows.

from transformers import pipeline
pipe = pipeline("any-to-any", model="google/gemma-4-e2b-it")

You can then pass in images and text as follows.

messages = [
    {
        "role": "user",
        "content": [
            {
                "type": "image",
                "image": "https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/thailand.jpg",
            },
            {"type": "text", "text": "Do you have travel advice going to here?"},
        ],
    }
]
output = pipe(messages, max_new_tokens=100, return_full_text=False)
output[0]["generated_text"]
# Based on the image, which appears to show a magnificent, ornate **Buddhist temple or pagoda**, likely in Southeast Asia (such as Thailand, Myanmar, or Cambodia), here is some general travel advice..

When inferring with videos, you can include the audio track using theload\_audio\_from\_videoargument.

messages = [
    {
        "role": "user",
        "content": [
            {
                "type": "video",
                "image": "https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/rockets.mp4",
            },
            {"type": "text", "text": "What is happening in this video?"},
        ],
    }
]
pipe(messages, load_audio_from_video=True)

Going a level lower, you can load Gemma 4 using theAutoModelForMultimodalLMclass, especially useful for fine-tuning. The built-in chat template takes care of formatting the inputs correctly, please make sure you use it to prevent subtle mistakes when building the prompt manually.

Inference code``` from transformers import AutoModelForMultimodalLM, AutoProcessor model = AutoModelForMultimodalLM.from_pretrained(“google/gemma-4-E2B-it”, device_map=“auto”) processor = AutoProcessor.from_pretrained(“google/gemma-4-E2B-it”) messages = [ { “role”: “user”, “content”: [ { “type”: “video”, “image”: “https://huggingface.co/datasets/merve/vlm_test_images/resolve/main/rockets.mp4”, }, {“type”: “text”, “text”: “What is happening in this video?”}, ], } ] inputs = processor.apply_chat_template( messages, tokenize=True, add_generation_prompt=True, return_dict=True, return_tensors=“pt” ).to(model.device)

generated_ids = model.generate(**inputs, max_new_tokens=128) generated_ids_trimmed = [ out_ids[len(in_ids) :] for in_ids, out_ids in zip(inputs.input_ids, generated_ids) ] output_text = processor.batch_decode( generated_ids_trimmed, skip_special_tokens=True, clean_up_tokenization_spaces=False ) print(output_text)


## [https://huggingface.co/blog/gemma4#llamacpp](https://huggingface.co/blog/gemma4#llamacpp)Llama\.cpp

Gemma 4 models come with image\+text support in llama\.cpp from the get\-go\! This unlocks using Gemma 4 with all of your favorite local apps: llama\-cpp server, lmstudio, Jan as well as coding agents like Pi across many backends such as Metal and CUDA\.

You can install llama\-cpp as follows\.

brew install llama.cpp # MacOS winget install llama.cpp # Windows


You can then start a server compatible with the OpenAI API Replace the quantization scheme at the end of the command with the precision of your choice\.

llama-server -hf ggml-org/gemma-4-E2B-it-GGUF


Check out this link[for more](https://huggingface.co/ggml-org/gemma-4-E2B-it-GGUF?local-app=llama.cpp)options on combining llama\.cpp with different coding agents and local apps\. Find all the GGUF checkpoints[in this collection](https://huggingface.co/collections/ggml-org/gemma-4)\.

## [https://huggingface.co/blog/gemma4#plug-in-your-local-agent](https://huggingface.co/blog/gemma4#plug-in-your-local-agent)Plug in your local agent

We worked on making sure the new models work locally with agents like**openclaw, hermes, pi, and open code**\. All thanks to llama\.cpp\! Run the following to try Gemma 4 right away\.

First, start your local server:

llama-server -hf ggml-org/gemma-4-26b-a4b-it-GGUF:Q4_K_M


For**hermes:**

hermes model


For**openclaw:**

openclaw onboard


For**pi**define a`~/\.pi/agent/models\.json`:

{ “providers”: { “llama-cpp”: { “baseUrl”: “http://localhost:8080/v1”, “api”: “openai-completions”, “apiKey”: “none”, “models”: [ { “id”: “ggml-org-gemma-4-26b-4b-gguf” } ] } } }


For**open code**define a`~/\.config/opencode/opencode\.json`:

{ “$schema”: “https://opencode.ai/config.json”, “provider”: { “llama.cpp”: { “npm”: “@ai-sdk/openai-compatible”, “name”: “llama-server (local)”, “options”: { “baseURL”: “http://127.0.0.1:8080/v1” }, “models”: { “gemma-4-26b-4b-it”: { “name”: “Gemma 4 (local)”, “limit”: { “context”: 128000, “output”: 8192 } } } } } }


## [https://huggingface.co/blog/gemma4#transformersjs](https://huggingface.co/blog/gemma4#transformersjs)transformers\.js

transformers\.js enables running Gemma 4 right inside browser\. You can check out the model card to see text\-only, image & text, audio & text inference in detail[here](https://huggingface.co/onnx-community/gemma-4-E2B-it-ONNX#transformersjs-javascript)\. We also shipped a demo for you to test the model[here](https://huggingface.co/spaces/webml-community/Gemma-4-WebGPU)\.

## [https://huggingface.co/blog/gemma4#mlx](https://huggingface.co/blog/gemma4#mlx)MLX

Full multimodal support of Gemma 4 is available using the open\-source[`mlx\-vlm`library](https://github.com/Blaizzy/mlx-vlm)\. Here's how to ask the model to describe an image:

pip install -U mlx-vlm


mlx_vlm.generate
–model google/gemma-4-E4B-it
–image https://huggingface.co/datasets/huggingface/documentation-images/resolve/0052a70beed5bf71b92610a43a52df6d286cd5f3/diffusers/rabbit.jpg
–prompt “Describe this image in detail”


mlx\-vlm supports TurboQuant, which delivers the same accuracy as the uncompressed baseline while using ~4x less active memory and running a lot faster end\-to\-end\. This makes long\-context inference practical on Apple Silicon without sacrificing quality\. Use it like this:

mlx_vlm.generate
–model “mlx-community/gemma-4-26b-a4b-it-4bit”
–prompt “Your prompt here”
–kv-bits 3.5
–kv-quant-scheme turboquant


For audio examples and more details, please check[the MLX collection](https://hf.co/mlx-community/gemma-4)\.

### [https://huggingface.co/blog/gemma4#mistralrs](https://huggingface.co/blog/gemma4#mistralrs)Mistral\.rs

[mistral\.rs](https://github.com/EricLBuehler/mistral.rs)is a Rust\-native inference engine with day\-0 Gemma 4 support across all modalities \(text, image, video, audio\) and builtin tool\-calling and agentic functionality\. Install mistral\.rs:

curl –proto ‘=https’ –tlsv1.2 -sSf https://raw.githubusercontent.com/EricLBuehler/mistral.rs/master/install.sh | sh # Linux/macOS

irm https://raw.githubusercontent.com/EricLBuehler/mistral.rs/master/install.ps1 | iex # Windows


You can then start an OpenAI\-compatible HTTP server:

mistralrs serve mistralrs-community/gemma-4-E4B-it-UQFF –from-uqff 8


Or, use interactive mode:

mistralrs run -m google/gemma-4-E4B-it –isq 8 –image image.png -i “Describe this image in detail.”

mistralrs run -m google/gemma-4-E4B-it –isq 8 –audio audio.mp3 -i “Transcribe this fully.”


Find all models[here](https://huggingface.co/mistralrs-community/models)\. Please, follow[the instructions](https://huggingface.co/mistralrs-community/gemma-4-E2B-it-UQFF#install)in the model cards for installation and inference guidelines\.

## [https://huggingface.co/blog/gemma4#multi-token-prediction-drafters](https://huggingface.co/blog/gemma4#multi-token-prediction-drafters)Multi\-Token Prediction Drafters

Google has released Multi\-Token Prediction \(MTP\) drafters for the Gemma 4 family: small*assistant*models that accelerate inference via speculative decoding\. The drafter proposes several future tokens at once, and the target model verifies them in a single forward pass\. You get the same outputs as the target model, just faster — no quality loss, no changes to reasoning behaviour\. Reported end\-to\-end speedups go up to ~3x depending on hardware, batch size, and workload\.

Assistants are available for all four Gemma 4 sizes \(E2B, E4B, 26B A4B, 31B\)\. They share the KV cache with the target model to avoid recomputing context, and the smaller edge variants additionally use an embedder clustering trick to keep memory and compute low on\-device\.

Find the checkpoints in the[Gemma 4 collection](https://huggingface.co/collections/google/gemma-4)and the[mlx\-community collection](https://huggingface.co/collections/mlx-community/gemma-4-assistant-mtp)\.

## [https://huggingface.co/blog/gemma4#fine-tuning-for-all](https://huggingface.co/blog/gemma4#fine-tuning-for-all)Fine\-tuning for all

Gemma 4 models are ideal for fine\-tuning in your favorite tools and platforms and at any budget\.

## [https://huggingface.co/blog/gemma4#fine-tuning-with-trl](https://huggingface.co/blog/gemma4#fine-tuning-with-trl)Fine\-tuning with TRL

Gemma 4 is fully supported for fine\-tuning with TRL\. To celebrate, TRL has been upgraded with support for multimodal tool responses when interacting with environments, meaning models can now receive images back from tools during training, not just text\.

To showcase this, we've built an example training script where Gemma 4 learns to drive in the CARLA simulator\. The model sees the road through a camera, decides what to do and learns from the outcome\. After training, it consistently changes lanes to avoid pedestrians\. The same approach works for any task where a model needs to see and act: robotics, web browsing, or other interactive environments\.

Get started:

pip install git+https://github.com/huggingface/trl.git

python examples/scripts/openenv/carla_vlm_gemma.py
–env-urls https://sergiopaniego-carla-env.hf.space
https://sergiopaniego-carla-env-2.hf.space
–model google/gemma-4-E2B-it


Find the example[here](https://github.com/huggingface/huggingface-gemma-recipes/blob/main/scripts/carla_vlm_gemma.py)\.

### [https://huggingface.co/blog/gemma4#fine-tuning-with-trl-on-vertex-ai](https://huggingface.co/blog/gemma4#fine-tuning-with-trl-on-vertex-ai)Fine\-tuning with TRL on Vertex AI

Additionally, we have prepared an example on how to fine\-tune Gemma 4 with TRL on Vertex AI using SFT, to showcase how to extend the function calling capabilities, whilst freezing both the vision and audio towers\. The examples include how to build a custom Docker container with latest Transformers, TRL, etc\. with CUDA support on Google Cloud, and how to run it via Vertex AI Serverless Training Jobs\.

pip install google-cloud-aiplatform –upgrade –quiet

from google.cloud import aiplatform

aiplatform.init( project=“<PROJECT_ID>”, location=“”, staging_bucket=“<BUCKET_URI>”, )

job = aiplatform.CustomContainerTrainingJob( display_name=“gemma-4-fine-tuning”, container_uri=“<CONTAINER_URI>”, command=[“python”, “/gcs/gemma-4-fine-tuning/train.py”], )

job = job.submit( replica_count=1, machine_type=“a3-highgpu-1g”, accelerator_type=“NVIDIA_H100_80GB”, accelerator_count=1, base_output_dir=“<BUCKET_URI>/output-dir”, environment_variables={ “MODEL_ID”: “google/gemma-4-E2B-it”, “HF_TOKEN”: <HF_TOKEN>, }, boot_disk_size_gb=500, )


You can find the complete example in the "Hugging Face on Google Cloud" docs at[https://hf\.co/docs/google\-cloud/examples/vertex\-ai\-notebooks\-fine\-tune\-gemma\-4](https://hf.co/docs/google-cloud/examples/vertex-ai-notebooks-fine-tune-gemma-4)\.

## [https://huggingface.co/blog/gemma4#fine-tuning-with-unsloth-studio](https://huggingface.co/blog/gemma4#fine-tuning-with-unsloth-studio)Fine\-tuning with Unsloth Studio

If you want to fine tune and run a Gemma 4 model in a UI, try out[Unsloth Studio](https://unsloth.ai/docs/new/studio)\. It runs locally or on Google Colab\. First, install and start the app:

install unsloth studio on MacOS, Linux, WSL

curl -fsSL https://unsloth.ai/install.sh | sh

install unsloth studio on Windows

irm https://unsloth.ai/install.ps1 | iex

launch unsloth studio

unsloth studio -H 0.0.0.0 -p 8888

Search for for a Gemma 4 model like google/gemma-4-E2B-it


Then select any of the Gemma 4 models from the hub\.

[![Unsloth Studio](https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/gemma4/unsloth.png)](https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/gemma4/unsloth.png)

## [https://huggingface.co/blog/gemma4#try-gemma-4](https://huggingface.co/blog/gemma4#try-gemma-4)Try Gemma 4

We have shipped demos for you to try different Gemma 4 models\. We include demos based on transformers implementation for[E4B](https://huggingface.co/spaces/huggingface-projects/gemma-4-e4b-it),[26B/A4B](https://huggingface.co/spaces/huggingface-projects/gemma-4-26b-a4b-it), and dense[31B](https://huggingface.co/spaces/huggingface-projects/gemma-4-31b-it)models, as well as a[WebGPU](https://huggingface.co/spaces/webml-community/Gemma-4-WebGPU)demo with transformers\.js 🚀

## [https://huggingface.co/blog/gemma4#benchmark-results](https://huggingface.co/blog/gemma4#benchmark-results)Benchmark Results

Gemma 4 models demonstrate exceptional performance across diverse benchmarks, from reasoning and coding to vision and long\-context tasks\. The graph below shows model performance vs size, with Gemma 4 models forming an impressive Pareto frontier:

Source: Google \([blog\.google](https://blog.google/innovation-and-ai/technology/developers-tools/gemma-4/)\)

Here are detailed benchmark results for the instruction\-tuned models:

BenchmarkGemma 4 31BGemma 4 26B A4BGemma 4 E4BGemma 4 E2BGemma 3 27B \(no think\)**Reasoning & Knowledge**MMLU Pro[85\.2%](https://huggingface.co/datasets/TIGER-Lab/MMLU-Pro?eval_result=google/gemma-4-31B-it)[82\.6%](https://huggingface.co/datasets/TIGER-Lab/MMLU-Pro?eval_result=google/gemma-4-26B-A4B-it)[69\.4%](https://huggingface.co/datasets/TIGER-Lab/MMLU-Pro?eval_result=google/gemma-4-E4B-it)[60\.0%](https://huggingface.co/datasets/TIGER-Lab/MMLU-Pro?eval_result=google/gemma-4-E2B-it)67\.6%AIME 2026 no tools[89\.2%](https://huggingface.co/datasets/MathArena/aime_2026?eval_result=google/gemma-4-31B-it)[88\.3%](https://huggingface.co/datasets/MathArena/aime_2026?eval_result=google/gemma-4-26B-A4B-it)[42\.5%](https://huggingface.co/datasets/MathArena/aime_2026?eval_result=google/gemma-4-E4B-it)[37\.5%](https://huggingface.co/datasets/MathArena/aime_2026?eval_result=google/gemma-4-E2B-it)20\.8%GPQA Diamond[84\.3%](https://huggingface.co/datasets/Idavidrein/gpqa?eval_result=google/gemma-4-31B-it)[82\.3%](https://huggingface.co/datasets/Idavidrein/gpqa?eval_result=google/gemma-4-26B-A4B-it)[58\.6%](https://huggingface.co/datasets/Idavidrein/gpqa?eval_result=google/gemma-4-E4B-it)[43\.4%](https://huggingface.co/datasets/Idavidrein/gpqa?eval_result=google/gemma-4-E2B-it)42\.4%Tau2 \(average over 3\)76\.9%68\.2%42\.2%24\.5%16\.2%BigBench Extra Hard74\.4%64\.8%33\.1%21\.9%19\.3%MMMLU88\.4%86\.3%76\.6%67\.4%70\.7%**Coding**LiveCodeBench v680\.0%77\.1%52\.0%44\.0%29\.1%Codeforces ELO21501718940633110HLE no tools[19\.5%](https://huggingface.co/datasets/cais/hle?eval_result=google/gemma-4-31B-it)[8\.7%](https://huggingface.co/datasets/cais/hle?eval_result=google/gemma-4-26B-A4B-it)\-\-\-HLE with search[26\.5%](https://huggingface.co/datasets/cais/hle?eval_result=google/gemma-4-31B-it)[17\.2%](https://huggingface.co/datasets/cais/hle?eval_result=google/gemma-4-26B-A4B-it)\-\-\-**Vision**MMMU Pro76\.9%73\.8%52\.6%44\.2%49\.7%OmniDocBench 1\.5 \(edit distance\)0\.1310\.1490\.1810\.2900\.365MATH\-Vision85\.6%82\.4%59\.5%52\.4%46\.0%MedXPertQA MM61\.3%58\.1%28\.7%23\.5%\-**Audio**CoVoST\-\-35\.5433\.47\-FLEURS \(lower is better\)\-\-0\.080\.09\-**Long Context**MRCR v2 8 needle 128k \(average\)66\.4%44\.1%25\.4%19\.1%13\.5%
## [https://huggingface.co/blog/gemma4#acknowledgements](https://huggingface.co/blog/gemma4#acknowledgements)Acknowledgements

Landing Gemma\-4 in the open\-source ecosystem took a lot of effort from many people and not only the authors of this blog post\. In no particular order, we thank many people from the open\-source team: Gemma 4 transformers integration is owed to Cyril, Raushan, Eustache, Arthur, Lysandre\. We thank Joshua for transformers\.js integration and demo, Eric for mistral\.rs integration, Son for Llama\.cpp, Prince for MLX integration, Quentin, Albert and Kashif for TRL, Adarsh for SGLang transformers backend and Toshihiro for building the demos\. This work wouldn't have been possible without Google's extensive contribution with the model artefact, but also the significant effort contributing the model to transformers in an effort to standardize it\. The open\-source ecosystem is now more complete, with a very capable, freely\-licensed, open\-source model\. The Gemma 4 transformers integration was handled by Cyril, Raushan, Eustache, Arthur, Lysandre\. We thank Joshua for the transformers\.js integration and demo, Eric for mistral\.rs integration, Son for Llama\.cpp, Prince for MLX, Quentin for TRL, Adarsh for SGLang transformers backend, and Toshihiro for building several demos\.

This work wouldn't have been possible without Google's extensive contribution with the model artefact, but also their significant effort contributing the model to transformers in an effort to standardize it\. The open\-source ecosystem is now more complete, with a very capable, freely\-licensed, open\-source model\.

Similar Articles

google/gemma-4-31B-it-assistant

Hugging Face Models Trending

Google DeepMind releases Gemma 4, a family of open-weights multimodal models featuring Multi-Token Prediction (MTP) for up to 2x decoding speedups, supporting text, image, video, and audio with enhanced reasoning and coding capabilities.

Introducing Gemma 4 12B: a unified, encoder-free multimodal model

Google DeepMind Blog

Google DeepMind announces Gemma 4 12B, a novel encoder-free multimodal AI model that integrates vision and audio directly into the LLM backbone, delivering advanced reasoning and agentic capabilities on laptops with 16GB of RAM, released under Apache 2.0 license.

google/gemma-4-26B-A4B-it

Hugging Face Models Trending

Google DeepMind releases Gemma 4, a family of open-weight multimodal models ranging from 2.3B to 31B parameters with support for text, image, video, and audio inputs. The models feature 256K context windows, MoE and dense architectures, enhanced reasoning capabilities, and are optimized for deployment across devices from mobile to servers.

google/gemma-4-E4B-it-assistant

Hugging Face Models Trending

Google DeepMind releases the Gemma 4 E4B instruction-tuned assistant model, featuring multimodal capabilities, reasoning improvements, and optimized speculative decoding for low-latency on-device applications.

Gemma 4: Byte for byte, the most capable open models

Google DeepMind Blog

Google DeepMind introduces Gemma 4, its most capable family of open models to date, designed for advanced reasoning and agentic workflows with high intelligence-per-parameter efficiency across multiple sizes.