Instructions to use ewre324/moondream2 with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- llama-cpp-python
How to use ewre324/moondream2 with llama-cpp-python:
# !pip install llama-cpp-python from llama_cpp import Llama llm = Llama.from_pretrained( repo_id="ewre324/moondream2", filename="moondream2-mmproj-f16.gguf", )
output = llm( "Once upon a time,", max_tokens=512, echo=True ) print(output)
- Notebooks
- Google Colab
- Kaggle
- Local Apps Settings
- llama.cpp
How to use ewre324/moondream2 with llama.cpp:
Install from brew
brew install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf ewre324/moondream2:F16 # Run inference directly in the terminal: llama-cli -hf ewre324/moondream2:F16
Install from WinGet (Windows)
winget install llama.cpp # Start a local OpenAI-compatible server with a web UI: llama-server -hf ewre324/moondream2:F16 # Run inference directly in the terminal: llama-cli -hf ewre324/moondream2:F16
Use pre-built binary
# Download pre-built binary from: # https://github.com/ggerganov/llama.cpp/releases # Start a local OpenAI-compatible server with a web UI: ./llama-server -hf ewre324/moondream2:F16 # Run inference directly in the terminal: ./llama-cli -hf ewre324/moondream2:F16
Build from source code
git clone https://github.com/ggerganov/llama.cpp.git cd llama.cpp cmake -B build cmake --build build -j --target llama-server llama-cli # Start a local OpenAI-compatible server with a web UI: ./build/bin/llama-server -hf ewre324/moondream2:F16 # Run inference directly in the terminal: ./build/bin/llama-cli -hf ewre324/moondream2:F16
Use Docker
docker model run hf.co/ewre324/moondream2:F16
- LM Studio
- Jan
- vLLM
How to use ewre324/moondream2 with vLLM:
Install from pip and serve model
# Install vLLM from pip: pip install vllm # Start the vLLM server: vllm serve "ewre324/moondream2" # Call the server using curl (OpenAI-compatible API): curl -X POST "http://localhost:8000/v1/completions" \ -H "Content-Type: application/json" \ --data '{ "model": "ewre324/moondream2", "prompt": "Once upon a time,", "max_tokens": 512, "temperature": 0.5 }'Use Docker
docker model run hf.co/ewre324/moondream2:F16
- Ollama
How to use ewre324/moondream2 with Ollama:
ollama run hf.co/ewre324/moondream2:F16
- Unsloth Studio
How to use ewre324/moondream2 with Unsloth Studio:
Install Unsloth Studio (macOS, Linux, WSL)
curl -fsSL https://unsloth.ai/install.sh | sh # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for ewre324/moondream2 to start chatting
Install Unsloth Studio (Windows)
irm https://unsloth.ai/install.ps1 | iex # Run unsloth studio unsloth studio -H 0.0.0.0 -p 8888 # Then open http://localhost:8888 in your browser # Search for ewre324/moondream2 to start chatting
Using HuggingFace Spaces for Unsloth
# No setup required # Open https://huggingface.co/spaces/unsloth/studio in your browser # Search for ewre324/moondream2 to start chatting
- Docker Model Runner
How to use ewre324/moondream2 with Docker Model Runner:
docker model run hf.co/ewre324/moondream2:F16
- Lemonade
How to use ewre324/moondream2 with Lemonade:
Pull the model
# Download Lemonade from https://lemonade-server.ai/ lemonade pull ewre324/moondream2:F16
Run and chat with the model
lemonade run user.moondream2-F16
List all available models
lemonade list
| import torch | |
| import torch.nn as nn | |
| import torch.nn.functional as F | |
| import numpy as np | |
| from typing import Union, Tuple | |
| from einops import rearrange | |
| from PIL import Image | |
| from .layers import attn, layer_norm, linear, mlp | |
| from .image_crops import overlap_crop_image | |
| from .config import VisionConfig | |
| if torch.backends.mps.is_available(): | |
| # Non-divisible input sizes are not implemented on MPS device yet. | |
| # https://github.com/pytorch/pytorch/issues/96056 | |
| def adaptive_avg_pool2d(input, output_size): | |
| return F.adaptive_avg_pool2d(input.to("cpu"), output_size).to("mps") | |
| else: | |
| adaptive_avg_pool2d = F.adaptive_avg_pool2d | |
| DeviceLike = Union[str, torch.device, int] | |
| def prepare_crops( | |
| image: Image.Image, config: VisionConfig, device: DeviceLike | |
| ) -> Tuple[torch.Tensor, Tuple[int, int]]: | |
| np_image = np.array(image.convert("RGB")) | |
| overlap_crops = overlap_crop_image( | |
| np_image, max_crops=config.max_crops, overlap_margin=config.overlap_margin | |
| ) | |
| all_crops = overlap_crops["crops"] | |
| all_crops = np.transpose(all_crops, (0, 3, 1, 2)) | |
| all_crops = ( | |
| torch.from_numpy(all_crops) | |
| .to(device=device, dtype=torch.float16) | |
| .div_(255.0) | |
| .sub_(0.5) | |
| .div_(0.5) | |
| ) | |
| return all_crops, overlap_crops["tiling"] | |
| def vision_encoder(input_BCHW: torch.Tensor, w: nn.Module, config: VisionConfig): | |
| x = rearrange( | |
| input_BCHW, | |
| "b c (h p1) (w p2) -> b (h w) (c p1 p2)", | |
| p1=config.enc_patch_size, | |
| p2=config.enc_patch_size, | |
| ) # B3HW -> B(HxW)(3xP1xP2), aka BTC | |
| x = linear(x, w.patch_emb) | |
| x = x + w.pos_emb | |
| for block in w.blocks: | |
| x = x + attn(layer_norm(x, block.ln1), block.attn, n_heads=config.enc_n_heads) | |
| x = x + mlp(layer_norm(x, block.ln2), block.mlp) | |
| x = layer_norm(x, w.post_ln) | |
| return x | |
| def vision_projection( | |
| global_features: torch.Tensor, | |
| reconstructed: torch.Tensor, | |
| w: nn.Module, | |
| config: VisionConfig, | |
| ): | |
| reconstructed = reconstructed.permute(2, 0, 1) | |
| reconstructed = adaptive_avg_pool2d( | |
| reconstructed, output_size=(config.enc_n_layers, config.enc_n_layers) | |
| ) | |
| reconstructed = reconstructed.permute(1, 2, 0).view(729, config.enc_dim) | |
| final_features = torch.cat([global_features, reconstructed], dim=-1) | |
| return mlp(final_features, w.proj_mlp) | |
| def build_vision_model(config: VisionConfig, dtype: torch.dtype): | |
| patch_dim = config.enc_patch_size * config.enc_patch_size * config.in_channels | |
| grid_size = config.crop_size // config.enc_patch_size | |
| num_patches = grid_size * grid_size | |
| vision = nn.ModuleDict( | |
| { | |
| "patch_emb": nn.Linear(patch_dim, config.enc_dim, dtype=dtype), | |
| "blocks": nn.ModuleList( | |
| [ | |
| nn.ModuleDict( | |
| { | |
| "ln1": nn.LayerNorm(config.enc_dim, dtype=dtype), | |
| "attn": nn.ModuleDict( | |
| { | |
| "qkv": nn.Linear( | |
| config.enc_dim, 3 * config.enc_dim, dtype=dtype | |
| ), | |
| "proj": nn.Linear( | |
| config.enc_dim, config.enc_dim, dtype=dtype | |
| ), | |
| } | |
| ), | |
| "ln2": nn.LayerNorm(config.enc_dim, dtype=dtype), | |
| "mlp": nn.ModuleDict( | |
| { | |
| "fc1": nn.Linear( | |
| config.enc_dim, config.enc_ff_dim, dtype=dtype | |
| ), | |
| "fc2": nn.Linear( | |
| config.enc_ff_dim, config.enc_dim, dtype=dtype | |
| ), | |
| } | |
| ), | |
| } | |
| ) | |
| for _ in range(config.enc_n_layers) | |
| ] | |
| ), | |
| "post_ln": nn.LayerNorm(config.enc_dim, dtype=dtype), | |
| "proj_mlp": nn.ModuleDict( | |
| { | |
| "fc1": nn.Linear( | |
| config.enc_dim * 2, config.proj_inner_dim, dtype=dtype | |
| ), | |
| "fc2": nn.Linear( | |
| config.proj_inner_dim, config.proj_out_dim, dtype=dtype | |
| ), | |
| } | |
| ), | |
| } | |
| ) | |
| vision.pos_emb = nn.Parameter( | |
| torch.zeros(1, num_patches, config.enc_dim, dtype=dtype) | |
| ) | |
| return vision | |