RP-mahou-sfw
Collection
2 items • Updated
How to use Pranavz/gemma4-e4b-kindling-mahou with Transformers:
# Use a pipeline as a high-level helper
from transformers import pipeline
pipe = pipeline("text-generation", model="Pranavz/gemma4-e4b-kindling-mahou")
messages = [
{
"role": "user",
"content": [
{"type": "image", "url": "https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/p-blog/candy.JPG"},
{"type": "text", "text": "What animal is on the candy?"}
]
},
]
pipe(text=messages) # Load model directly
from transformers import AutoProcessor, AutoModelForImageTextToText
processor = AutoProcessor.from_pretrained("Pranavz/gemma4-e4b-kindling-mahou")
model = AutoModelForImageTextToText.from_pretrained("Pranavz/gemma4-e4b-kindling-mahou")
messages = [
{
"role": "user",
"content": [
{"type": "image", "url": "https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/p-blog/candy.JPG"},
{"type": "text", "text": "What animal is on the candy?"}
]
},
]
inputs = processor.apply_chat_template(
messages,
add_generation_prompt=True,
tokenize=True,
return_dict=True,
return_tensors="pt",
).to(model.device)
outputs = model.generate(**inputs, max_new_tokens=40)
print(processor.decode(outputs[0][inputs["input_ids"].shape[-1]:]))How to use Pranavz/gemma4-e4b-kindling-mahou with vLLM:
# Install vLLM from pip:
pip install vllm
# Start the vLLM server:
vllm serve "Pranavz/gemma4-e4b-kindling-mahou"
# Call the server using curl (OpenAI-compatible API):
curl -X POST "http://localhost:8000/v1/chat/completions" \
-H "Content-Type: application/json" \
--data '{
"model": "Pranavz/gemma4-e4b-kindling-mahou",
"messages": [
{
"role": "user",
"content": "What is the capital of France?"
}
]
}'docker model run hf.co/Pranavz/gemma4-e4b-kindling-mahou
How to use Pranavz/gemma4-e4b-kindling-mahou with SGLang:
# Install SGLang from pip:
pip install sglang
# Start the SGLang server:
python3 -m sglang.launch_server \
--model-path "Pranavz/gemma4-e4b-kindling-mahou" \
--host 0.0.0.0 \
--port 30000
# Call the server using curl (OpenAI-compatible API):
curl -X POST "http://localhost:30000/v1/chat/completions" \
-H "Content-Type: application/json" \
--data '{
"model": "Pranavz/gemma4-e4b-kindling-mahou",
"messages": [
{
"role": "user",
"content": "What is the capital of France?"
}
]
}'docker run --gpus all \
--shm-size 32g \
-p 30000:30000 \
-v ~/.cache/huggingface:/root/.cache/huggingface \
--env "HF_TOKEN=<secret>" \
--ipc=host \
lmsysorg/sglang:latest \
python3 -m sglang.launch_server \
--model-path "Pranavz/gemma4-e4b-kindling-mahou" \
--host 0.0.0.0 \
--port 30000
# Call the server using curl (OpenAI-compatible API):
curl -X POST "http://localhost:30000/v1/chat/completions" \
-H "Content-Type: application/json" \
--data '{
"model": "Pranavz/gemma4-e4b-kindling-mahou",
"messages": [
{
"role": "user",
"content": "What is the capital of France?"
}
]
}'How to use Pranavz/gemma4-e4b-kindling-mahou with Docker Model Runner:
docker model run hf.co/Pranavz/gemma4-e4b-kindling-mahou
A full-parameter SFT of google/gemma-4-E4B-it
import torch
from transformers import AutoModelForCausalLM, AutoTokenizer
MODEL_ID = "Pranavz/gemma4-e4b-kindling-mahou"
tokenizer = AutoTokenizer.from_pretrained(MODEL_ID)
model = AutoModelForCausalLM.from_pretrained(
MODEL_ID,
dtype=torch.bfloat16,
device_map="auto",
)
messages = [
{"role": "user", "content": "a knight haunted by a broken oath"},
]
text = tokenizer.apply_chat_template(messages, tokenize=False, add_generation_prompt=True)
inputs = tokenizer(text, return_tensors="pt").to(model.device)
with torch.inference_mode():
out = model.generate(
**inputs,
max_new_tokens=768,
temperature=0.85,
top_p=0.95,
top_k=64,
repetition_penalty=1.05,
do_sample=True,
pad_token_id=tokenizer.pad_token_id,
)
print(tokenizer.decode(out[0][inputs.input_ids.shape[1]:], skip_special_tokens=True))
| Parameter | Value | Notes |
|---|---|---|
temperature |
0.7 – 0.9 | gemma's own default is 1.0; 0.85 is a good balance |
top_p |
0.95 | gemma generation_config default |
top_k |
64 | gemma generation_config default |
repetition_penalty |
1.05 | mild — gemma loops less than qwen |
max_new_tokens |
512 – 1024 | RP needs room |
Do not pass enable_thinking — that's a Qwen3 arg and will error on gemma's chat template.
Chat template uses gemma 4's new markers (<|turn>user\n...<turn|>\n<|turn>model\n...) — handled automatically by apply_chat_template.