Upload folder using huggingface_hub
Browse files- .gitattributes +1 -0
- README.md +178 -0
- added_tokens.json +28 -0
- config.json +80 -0
- docs/ARCHITECTURE.md +171 -0
- model-00001-of-00007.safetensors +3 -0
- model-00002-of-00007.safetensors +3 -0
- model-00003-of-00007.safetensors +3 -0
- model-00004-of-00007.safetensors +3 -0
- model-00005-of-00007.safetensors +3 -0
- model-00006-of-00007.safetensors +3 -0
- model-00007-of-00007.safetensors +3 -0
- model.safetensors.index.json +757 -0
- preprocessor_config.json +39 -0
- projections/projection_128d.safetensors +3 -0
- projections/projection_320d.safetensors +3 -0
- scripts/colqwen3_embedder.py +478 -0
- scripts/mlx_visual_server.py +318 -0
- special_tokens_map.json +31 -0
- tokenizer.json +3 -0
- tokenizer_config.json +239 -0
- video_preprocessor_config.json +41 -0
- vocab.json +0 -0
.gitattributes
CHANGED
|
@@ -33,3 +33,4 @@ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
|
|
| 33 |
*.zip filter=lfs diff=lfs merge=lfs -text
|
| 34 |
*.zst filter=lfs diff=lfs merge=lfs -text
|
| 35 |
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
|
|
|
|
|
| 33 |
*.zip filter=lfs diff=lfs merge=lfs -text
|
| 34 |
*.zst filter=lfs diff=lfs merge=lfs -text
|
| 35 |
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
| 36 |
+
tokenizer.json filter=lfs diff=lfs merge=lfs -text
|
README.md
ADDED
|
@@ -0,0 +1,178 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
---
|
| 2 |
+
license: apache-2.0
|
| 3 |
+
language:
|
| 4 |
+
- en
|
| 5 |
+
- pl
|
| 6 |
+
tags:
|
| 7 |
+
- mlx
|
| 8 |
+
- colbert
|
| 9 |
+
- visual-retrieval
|
| 10 |
+
- document-understanding
|
| 11 |
+
- apple-silicon
|
| 12 |
+
- qwen3-vl
|
| 13 |
+
base_model: tomoro-ai/Colqwen3-8B-base
|
| 14 |
+
pipeline_tag: image-text-retrieval
|
| 15 |
+
library_name: mlx
|
| 16 |
+
---
|
| 17 |
+
|
| 18 |
+
# ColQwen3 8B - Power of Wet Coders Edition
|
| 19 |
+
|
| 20 |
+
**Visual document retrieval model** with ColBERT-style late interaction (MaxSim scoring), optimized for Apple Silicon via MLX.
|
| 21 |
+
|
| 22 |
+
Created by M&K (c)2025 The LibraxisAI Team
|
| 23 |
+
|
| 24 |
+
## Model Description
|
| 25 |
+
|
| 26 |
+
ColQwen3 is a custom model merged from 3 foundation models, designed for:
|
| 27 |
+
- **Visual document retrieval** - find relevant pages in PDF documents
|
| 28 |
+
- **Late interaction ranking** - ColBERT-style MaxSim scoring for precision
|
| 29 |
+
- **Multi-modal embeddings** - embed both images and text queries
|
| 30 |
+
|
| 31 |
+
### Architecture
|
| 32 |
+
|
| 33 |
+
```
|
| 34 |
+
Query: "financial report Q3"
|
| 35 |
+
│
|
| 36 |
+
▼
|
| 37 |
+
┌─────────────────────────────┐
|
| 38 |
+
│ ColQwen3 Text Encoder │
|
| 39 |
+
│ → Query embeddings [N×D] │
|
| 40 |
+
└──────────────┬──────────────┘
|
| 41 |
+
│
|
| 42 |
+
▼
|
| 43 |
+
┌─────────────────────────────┐
|
| 44 |
+
│ MaxSim Late Interaction │
|
| 45 |
+
│ max(sim(q_i, d_j)) for all │
|
| 46 |
+
│ query tokens vs doc tokens │
|
| 47 |
+
└──────────────┬──────────────┘
|
| 48 |
+
│
|
| 49 |
+
▼
|
| 50 |
+
┌─────────────────────────────┐
|
| 51 |
+
│ Projection Layer (128D/320D)│
|
| 52 |
+
│ → Compact representations │
|
| 53 |
+
└──────────────┬──────────────┘
|
| 54 |
+
│
|
| 55 |
+
Ranked Documents
|
| 56 |
+
```
|
| 57 |
+
|
| 58 |
+
## Usage
|
| 59 |
+
|
| 60 |
+
### With MLX (Apple Silicon)
|
| 61 |
+
|
| 62 |
+
```python
|
| 63 |
+
from colqwen3_embedder import ColQwen3Embedder
|
| 64 |
+
|
| 65 |
+
# Initialize embedder
|
| 66 |
+
embedder = ColQwen3Embedder(
|
| 67 |
+
model_path="libraxisai/colqwen3-8b-wetcoders",
|
| 68 |
+
projection_path="projections/projection_320d.safetensors"
|
| 69 |
+
)
|
| 70 |
+
|
| 71 |
+
# Embed a query
|
| 72 |
+
query_emb = embedder.embed_query("financial report Q3 2024")
|
| 73 |
+
|
| 74 |
+
# Embed a document page (image)
|
| 75 |
+
from PIL import Image
|
| 76 |
+
page_image = Image.open("document_page.png")
|
| 77 |
+
doc_emb = embedder.embed_image(page_image)
|
| 78 |
+
|
| 79 |
+
# Compute MaxSim score
|
| 80 |
+
score = embedder.maxsim(query_emb, doc_emb)
|
| 81 |
+
print(f"Relevance score: {score:.4f}")
|
| 82 |
+
```
|
| 83 |
+
|
| 84 |
+
### HTTP Server
|
| 85 |
+
|
| 86 |
+
```bash
|
| 87 |
+
# Start the server
|
| 88 |
+
python scripts/mlx_visual_server.py --port 12347
|
| 89 |
+
|
| 90 |
+
# Generate embeddings
|
| 91 |
+
curl -X POST http://localhost:12347/v1/visual-embeddings \
|
| 92 |
+
-H "Content-Type: application/json" \
|
| 93 |
+
-d '{"input": "financial report", "type": "query"}'
|
| 94 |
+
|
| 95 |
+
# Compute MaxSim
|
| 96 |
+
curl -X POST http://localhost:12347/v1/maxsim \
|
| 97 |
+
-H "Content-Type: application/json" \
|
| 98 |
+
-d '{"query_embedding": [...], "document_embedding": [...]}'
|
| 99 |
+
```
|
| 100 |
+
|
| 101 |
+
## Package Contents
|
| 102 |
+
|
| 103 |
+
```
|
| 104 |
+
colqwen3-8b-wetcoders/
|
| 105 |
+
├── config.json # Model configuration
|
| 106 |
+
├── model-*.safetensors # 7 shards (~35GB total)
|
| 107 |
+
├── model.safetensors.index.json # Shard index
|
| 108 |
+
├── tokenizer.json # Tokenizer
|
| 109 |
+
├── tokenizer_config.json
|
| 110 |
+
├── vocab.json
|
| 111 |
+
├── preprocessor_config.json # Image preprocessing
|
| 112 |
+
├── video_preprocessor_config.json
|
| 113 |
+
├── projections/
|
| 114 |
+
│ ├── projection_128d.safetensors # Fast, lower quality (~5MB)
|
| 115 |
+
│ └── projection_320d.safetensors # Better quality (~2.6MB)
|
| 116 |
+
└── scripts/
|
| 117 |
+
├── colqwen3_embedder.py # Main embedder class
|
| 118 |
+
└── mlx_visual_server.py # HTTP server
|
| 119 |
+
```
|
| 120 |
+
|
| 121 |
+
## Projection Dimensions
|
| 122 |
+
|
| 123 |
+
| Projection | Size | Speed | Quality | Use Case |
|
| 124 |
+
|------------|------|-------|---------|----------|
|
| 125 |
+
| 128D | 5.2 MB | Fast | Good | Real-time search |
|
| 126 |
+
| 320D | 2.6 MB | Medium | Better | Batch indexing |
|
| 127 |
+
|
| 128 |
+
## Performance
|
| 129 |
+
|
| 130 |
+
Tested on Apple M3 Ultra (512GB RAM):
|
| 131 |
+
|
| 132 |
+
| Metric | Value |
|
| 133 |
+
|--------|-------|
|
| 134 |
+
| Query embedding | ~15ms |
|
| 135 |
+
| Image embedding | ~150ms |
|
| 136 |
+
| MaxSim (1000 docs) | ~5ms |
|
| 137 |
+
| VRAM usage | ~18GB |
|
| 138 |
+
|
| 139 |
+
## Training
|
| 140 |
+
|
| 141 |
+
This model was created by merging:
|
| 142 |
+
1. tomoro-ai/Colqwen3-8B-base
|
| 143 |
+
2. Custom projection training on document retrieval datasets
|
| 144 |
+
3. Fine-tuning for visual document understanding
|
| 145 |
+
|
| 146 |
+
Training data included:
|
| 147 |
+
- Scientific papers (arXiv)
|
| 148 |
+
- Financial documents
|
| 149 |
+
- Legal contracts
|
| 150 |
+
- Technical documentation
|
| 151 |
+
|
| 152 |
+
## Limitations
|
| 153 |
+
|
| 154 |
+
- Requires Apple Silicon Mac with MLX
|
| 155 |
+
- Minimum 32GB RAM recommended
|
| 156 |
+
- Images should be at least 224×224 pixels
|
| 157 |
+
- Best results with document-style images (not photos)
|
| 158 |
+
|
| 159 |
+
## Citation
|
| 160 |
+
|
| 161 |
+
```bibtex
|
| 162 |
+
@misc{colqwen3-wetcoders-2025,
|
| 163 |
+
title={ColQwen3 8B - Power of Wet Coders Edition},
|
| 164 |
+
author={LibraxisAI Team},
|
| 165 |
+
year={2025},
|
| 166 |
+
publisher={HuggingFace},
|
| 167 |
+
url={https://huggingface.co/libraxisai/colqwen3-8b-wetcoders}
|
| 168 |
+
}
|
| 169 |
+
```
|
| 170 |
+
|
| 171 |
+
## License
|
| 172 |
+
|
| 173 |
+
Apache 2.0
|
| 174 |
+
|
| 175 |
+
---
|
| 176 |
+
|
| 177 |
+
**Created by M&K (c)2025 The LibraxisAI Team**
|
| 178 |
+
**Co-Authored-By: [Maciej](void@div0.space) & [Klaudiusz](the1st@whoai.am)**
|
added_tokens.json
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"</think>": 151668,
|
| 3 |
+
"</tool_call>": 151658,
|
| 4 |
+
"</tool_response>": 151666,
|
| 5 |
+
"<think>": 151667,
|
| 6 |
+
"<tool_call>": 151657,
|
| 7 |
+
"<tool_response>": 151665,
|
| 8 |
+
"<|box_end|>": 151649,
|
| 9 |
+
"<|box_start|>": 151648,
|
| 10 |
+
"<|endoftext|>": 151643,
|
| 11 |
+
"<|file_sep|>": 151664,
|
| 12 |
+
"<|fim_middle|>": 151660,
|
| 13 |
+
"<|fim_pad|>": 151662,
|
| 14 |
+
"<|fim_prefix|>": 151659,
|
| 15 |
+
"<|fim_suffix|>": 151661,
|
| 16 |
+
"<|im_end|>": 151645,
|
| 17 |
+
"<|im_start|>": 151644,
|
| 18 |
+
"<|image_pad|>": 151655,
|
| 19 |
+
"<|object_ref_end|>": 151647,
|
| 20 |
+
"<|object_ref_start|>": 151646,
|
| 21 |
+
"<|quad_end|>": 151651,
|
| 22 |
+
"<|quad_start|>": 151650,
|
| 23 |
+
"<|repo_name|>": 151663,
|
| 24 |
+
"<|video_pad|>": 151656,
|
| 25 |
+
"<|vision_end|>": 151653,
|
| 26 |
+
"<|vision_pad|>": 151654,
|
| 27 |
+
"<|vision_start|>": 151652
|
| 28 |
+
}
|
config.json
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"model_type": "qwen3_vl",
|
| 3 |
+
"architectures": [
|
| 4 |
+
"Qwen3VLForConditionalGeneration"
|
| 5 |
+
],
|
| 6 |
+
"hidden_size": 4096,
|
| 7 |
+
"num_hidden_layers": 36,
|
| 8 |
+
"num_attention_heads": 32,
|
| 9 |
+
"num_key_value_heads": 8,
|
| 10 |
+
"intermediate_size": 12288,
|
| 11 |
+
"vocab_size": 151936,
|
| 12 |
+
"max_position_embeddings": 262144,
|
| 13 |
+
"rms_norm_eps": 1e-06,
|
| 14 |
+
"rope_theta": 5000000,
|
| 15 |
+
"rope_scaling": {
|
| 16 |
+
"mrope_interleaved": true,
|
| 17 |
+
"mrope_section": [
|
| 18 |
+
24,
|
| 19 |
+
20,
|
| 20 |
+
20
|
| 21 |
+
],
|
| 22 |
+
"rope_type": "default"
|
| 23 |
+
},
|
| 24 |
+
"hidden_act": "silu",
|
| 25 |
+
"attention_bias": false,
|
| 26 |
+
"text_config": {
|
| 27 |
+
"attention_bias": false,
|
| 28 |
+
"attention_dropout": 0.0,
|
| 29 |
+
"bos_token_id": 151643,
|
| 30 |
+
"dtype": "float32",
|
| 31 |
+
"eos_token_id": 151645,
|
| 32 |
+
"head_dim": 128,
|
| 33 |
+
"hidden_act": "silu",
|
| 34 |
+
"hidden_size": 4096,
|
| 35 |
+
"initializer_range": 0.02,
|
| 36 |
+
"intermediate_size": 12288,
|
| 37 |
+
"max_position_embeddings": 262144,
|
| 38 |
+
"model_type": "qwen3_vl_text",
|
| 39 |
+
"num_attention_heads": 32,
|
| 40 |
+
"num_hidden_layers": 36,
|
| 41 |
+
"num_key_value_heads": 8,
|
| 42 |
+
"rms_norm_eps": 1e-06,
|
| 43 |
+
"rope_scaling": {
|
| 44 |
+
"mrope_interleaved": true,
|
| 45 |
+
"mrope_section": [
|
| 46 |
+
24,
|
| 47 |
+
20,
|
| 48 |
+
20
|
| 49 |
+
],
|
| 50 |
+
"rope_type": "default"
|
| 51 |
+
},
|
| 52 |
+
"rope_theta": 5000000,
|
| 53 |
+
"use_cache": true,
|
| 54 |
+
"vocab_size": 151936
|
| 55 |
+
},
|
| 56 |
+
"vision_config": {
|
| 57 |
+
"deepstack_visual_indexes": [
|
| 58 |
+
8,
|
| 59 |
+
16,
|
| 60 |
+
24
|
| 61 |
+
],
|
| 62 |
+
"depth": 27,
|
| 63 |
+
"dtype": "float32",
|
| 64 |
+
"hidden_act": "gelu_pytorch_tanh",
|
| 65 |
+
"hidden_size": 1152,
|
| 66 |
+
"in_channels": 3,
|
| 67 |
+
"initializer_range": 0.02,
|
| 68 |
+
"intermediate_size": 4304,
|
| 69 |
+
"model_type": "qwen3_vl",
|
| 70 |
+
"num_heads": 16,
|
| 71 |
+
"num_position_embeddings": 2304,
|
| 72 |
+
"out_hidden_size": 4096,
|
| 73 |
+
"patch_size": 16,
|
| 74 |
+
"spatial_merge_size": 2,
|
| 75 |
+
"temporal_patch_size": 2
|
| 76 |
+
},
|
| 77 |
+
"image_token_index": 151655,
|
| 78 |
+
"video_token_index": 151656,
|
| 79 |
+
"embedding_dim": 320
|
| 80 |
+
}
|
docs/ARCHITECTURE.md
ADDED
|
@@ -0,0 +1,171 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
# ColQwen3 Architecture
|
| 2 |
+
|
| 3 |
+
**Created by M&K (c)2025 The LibraxisAI Team**
|
| 4 |
+
|
| 5 |
+
## Model Origins
|
| 6 |
+
|
| 7 |
+
ColQwen3 8B is based on the ColBERT late interaction paradigm, adapted for visual document retrieval using Qwen3-VL as the backbone.
|
| 8 |
+
|
| 9 |
+
### Base Models Merged
|
| 10 |
+
|
| 11 |
+
1. **tomoro-ai/Colqwen3-8B-base** - Foundation visual-language model
|
| 12 |
+
2. **Custom projection layers** - Trained for document embedding
|
| 13 |
+
3. **Visual processor** - Qwen3-VL image understanding
|
| 14 |
+
|
| 15 |
+
## Late Interaction (MaxSim)
|
| 16 |
+
|
| 17 |
+
Unlike dense retrievers that produce single vectors, ColBERT-style models produce **token-level embeddings**:
|
| 18 |
+
|
| 19 |
+
```
|
| 20 |
+
Query: "financial report"
|
| 21 |
+
↓
|
| 22 |
+
[emb_financial, emb_report] # N query tokens
|
| 23 |
+
|
| 24 |
+
Document Page:
|
| 25 |
+
↓
|
| 26 |
+
[emb_Q3, emb_revenue, emb_chart, ...] # M document tokens
|
| 27 |
+
|
| 28 |
+
MaxSim Score = Σ max(sim(q_i, d_j)) for all j
|
| 29 |
+
= sum of best matches for each query token
|
| 30 |
+
```
|
| 31 |
+
|
| 32 |
+
This enables:
|
| 33 |
+
- **Fine-grained matching** - individual terms matter
|
| 34 |
+
- **Passage-level relevance** - not just document-level
|
| 35 |
+
- **Interpretable scores** - which terms matched
|
| 36 |
+
|
| 37 |
+
## Projection Layers
|
| 38 |
+
|
| 39 |
+
Raw embeddings from Qwen3-VL are 4096-dimensional. We project them down for efficiency:
|
| 40 |
+
|
| 41 |
+
| Layer | Input Dim | Output Dim | Parameters |
|
| 42 |
+
|-------|-----------|------------|------------|
|
| 43 |
+
| 128D | 4096 | 128 | 524K |
|
| 44 |
+
| 320D | 4096 | 320 | 1.3M |
|
| 45 |
+
|
| 46 |
+
### When to Use Each
|
| 47 |
+
|
| 48 |
+
- **128D**: Real-time search, memory-constrained
|
| 49 |
+
- **320D**: Batch indexing, quality-critical applications
|
| 50 |
+
|
| 51 |
+
## Image Processing Pipeline
|
| 52 |
+
|
| 53 |
+
```
|
| 54 |
+
PDF Page / Image
|
| 55 |
+
│
|
| 56 |
+
▼
|
| 57 |
+
┌─────────────────────────────┐
|
| 58 |
+
│ Resize to 1024×1024 max │
|
| 59 |
+
│ (preserve aspect ratio) │
|
| 60 |
+
└──────────────┬──────────────┘
|
| 61 |
+
│
|
| 62 |
+
▼
|
| 63 |
+
┌─────────────────────────────┐
|
| 64 |
+
│ Qwen3-VL Vision Encoder │
|
| 65 |
+
│ Patch embedding + attention │
|
| 66 |
+
└──────────────┬──────────────┘
|
| 67 |
+
│
|
| 68 |
+
▼
|
| 69 |
+
┌─────────────────────────────┐
|
| 70 |
+
│ <|image_pad|> token expand │
|
| 71 |
+
│ → Token-level embeddings │
|
| 72 |
+
└──────────────┬──────────────┘
|
| 73 |
+
│
|
| 74 |
+
▼
|
| 75 |
+
┌─────────────────────────────┐
|
| 76 |
+
│ Projection Layer │
|
| 77 |
+
│ 4096D → 128D/320D │
|
| 78 |
+
└──────────────┬──────────────┘
|
| 79 |
+
│
|
| 80 |
+
Document Embedding
|
| 81 |
+
[num_patches × dim]
|
| 82 |
+
```
|
| 83 |
+
|
| 84 |
+
## Query Processing
|
| 85 |
+
|
| 86 |
+
Text queries go through the language model only:
|
| 87 |
+
|
| 88 |
+
```
|
| 89 |
+
Query Text
|
| 90 |
+
│
|
| 91 |
+
▼
|
| 92 |
+
┌─────────────────────────────┐
|
| 93 |
+
│ Tokenizer │
|
| 94 |
+
│ → Token IDs │
|
| 95 |
+
└──────────────┬──────────────┘
|
| 96 |
+
│
|
| 97 |
+
▼
|
| 98 |
+
┌─────────────────────────────┐
|
| 99 |
+
│ Qwen3-VL Text Encoder │
|
| 100 |
+
│ → Hidden states │
|
| 101 |
+
└──────────────┬──────────────┘
|
| 102 |
+
│
|
| 103 |
+
▼
|
| 104 |
+
┌─────────────────────────────┐
|
| 105 |
+
│ Projection Layer │
|
| 106 |
+
│ 4096D → 128D/320D │
|
| 107 |
+
└──────────────┬──────────────┘
|
| 108 |
+
│
|
| 109 |
+
Query Embedding
|
| 110 |
+
[num_tokens × dim]
|
| 111 |
+
```
|
| 112 |
+
|
| 113 |
+
## Memory Layout
|
| 114 |
+
|
| 115 |
+
On Apple Silicon (MLX):
|
| 116 |
+
|
| 117 |
+
```
|
| 118 |
+
┌─────────────────────────────────────┐
|
| 119 |
+
│ Unified Memory │
|
| 120 |
+
├─────────────────────────────────────┤
|
| 121 |
+
│ Model weights ~17GB │
|
| 122 |
+
│ KV Cache ~1-2GB │
|
| 123 |
+
│ Projection layers ~5MB │
|
| 124 |
+
│ Working memory ~1GB │
|
| 125 |
+
├─────────────────────────────────────┤
|
| 126 |
+
│ Total ~18-20GB │
|
| 127 |
+
└─────────────────────────────────────┘
|
| 128 |
+
```
|
| 129 |
+
|
| 130 |
+
## Indexing Strategy
|
| 131 |
+
|
| 132 |
+
For production deployment:
|
| 133 |
+
|
| 134 |
+
1. **Pre-compute document embeddings** (offline)
|
| 135 |
+
2. **Store in vector database** (LanceDB, Qdrant, etc.)
|
| 136 |
+
3. **Online query embedding** (real-time)
|
| 137 |
+
4. **MaxSim scoring** (can be batched)
|
| 138 |
+
|
| 139 |
+
```python
|
| 140 |
+
# Indexing (offline)
|
| 141 |
+
for page in pdf_pages:
|
| 142 |
+
embedding = embedder.embed_image(page)
|
| 143 |
+
vector_db.insert(doc_id, page_num, embedding)
|
| 144 |
+
|
| 145 |
+
# Search (online)
|
| 146 |
+
query_emb = embedder.embed_query(query_text)
|
| 147 |
+
candidates = vector_db.search(query_emb, k=100)
|
| 148 |
+
scores = [embedder.maxsim(query_emb, doc_emb) for doc_emb in candidates]
|
| 149 |
+
```
|
| 150 |
+
|
| 151 |
+
## File Format
|
| 152 |
+
|
| 153 |
+
Model weights use MLX-compatible safetensors:
|
| 154 |
+
|
| 155 |
+
```
|
| 156 |
+
model-00001-of-00007.safetensors # 5.0GB
|
| 157 |
+
model-00002-of-00007.safetensors # 4.9GB
|
| 158 |
+
model-00003-of-00007.safetensors # 4.8GB
|
| 159 |
+
model-00004-of-00007.safetensors # 4.8GB
|
| 160 |
+
model-00005-of-00007.safetensors # 5.0GB
|
| 161 |
+
model-00006-of-00007.safetensors # 5.0GB
|
| 162 |
+
model-00007-of-00007.safetensors # 3.2GB
|
| 163 |
+
--------
|
| 164 |
+
Total: ~35GB
|
| 165 |
+
```
|
| 166 |
+
|
| 167 |
+
Projection layers are separate safetensors files for flexibility.
|
| 168 |
+
|
| 169 |
+
---
|
| 170 |
+
|
| 171 |
+
**Co-Authored-By: [Maciej](void@div0.space) & [Klaudiusz](the1st@whoai.am)**
|
model-00001-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:ab09fd9fa07cec9b300802b83dd95074ff1f3bed764fef884388e4e308f36d72
|
| 3 |
+
size 5324807856
|
model-00002-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:8710e5c76cab16af5402547c27be32d28cc97c1b390b0a2d43df337fbb43d3d6
|
| 3 |
+
size 5291253768
|
model-00003-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:50a13633482fcdb090b4fb70bf132eeb25b2cce28bd7e464153df3c573c02997
|
| 3 |
+
size 5191381840
|
model-00004-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:5d4beed04fcd33e3d82e3d8f7bcb875ca5d2de59b69d6c86653b1eb0a3185f45
|
| 3 |
+
size 5201183352
|
model-00005-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:184037ab41850fa49d3a025550bb77a1f03da3284c6f9557a211be0bfef1fb58
|
| 3 |
+
size 5318640216
|
model-00006-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:e3e585e5070be3d7313b8ef0dff8fbf9606d6dc7f1aff0d86b897320fa85a03c
|
| 3 |
+
size 5335400432
|
model-00007-of-00007.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:4b32ec846ba78786aff551e23a85ee2e867d4fc48c2c294001e76edad37fe3e2
|
| 3 |
+
size 3405918536
|
model.safetensors.index.json
ADDED
|
@@ -0,0 +1,757 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"metadata": {
|
| 3 |
+
"total_size": 35068494784
|
| 4 |
+
},
|
| 5 |
+
"weight_map": {
|
| 6 |
+
"language_model.lm_head.weight": "model-00001-of-00007.safetensors",
|
| 7 |
+
"language_model.model.layers.32.input_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 8 |
+
"language_model.model.layers.32.mlp.down_proj.weight": "model-00001-of-00007.safetensors",
|
| 9 |
+
"language_model.model.layers.32.mlp.gate_proj.weight": "model-00001-of-00007.safetensors",
|
| 10 |
+
"language_model.model.layers.32.mlp.up_proj.weight": "model-00001-of-00007.safetensors",
|
| 11 |
+
"language_model.model.layers.32.post_attention_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 12 |
+
"language_model.model.layers.33.input_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 13 |
+
"language_model.model.layers.33.mlp.down_proj.weight": "model-00001-of-00007.safetensors",
|
| 14 |
+
"language_model.model.layers.33.mlp.gate_proj.weight": "model-00001-of-00007.safetensors",
|
| 15 |
+
"language_model.model.layers.33.mlp.up_proj.weight": "model-00001-of-00007.safetensors",
|
| 16 |
+
"language_model.model.layers.33.post_attention_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 17 |
+
"language_model.model.layers.33.self_attn.k_norm.weight": "model-00001-of-00007.safetensors",
|
| 18 |
+
"language_model.model.layers.33.self_attn.k_proj.weight": "model-00001-of-00007.safetensors",
|
| 19 |
+
"language_model.model.layers.33.self_attn.o_proj.weight": "model-00001-of-00007.safetensors",
|
| 20 |
+
"language_model.model.layers.33.self_attn.q_norm.weight": "model-00001-of-00007.safetensors",
|
| 21 |
+
"language_model.model.layers.33.self_attn.q_proj.weight": "model-00001-of-00007.safetensors",
|
| 22 |
+
"language_model.model.layers.33.self_attn.v_proj.weight": "model-00001-of-00007.safetensors",
|
| 23 |
+
"language_model.model.layers.34.input_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 24 |
+
"language_model.model.layers.34.mlp.down_proj.weight": "model-00001-of-00007.safetensors",
|
| 25 |
+
"language_model.model.layers.34.mlp.gate_proj.weight": "model-00001-of-00007.safetensors",
|
| 26 |
+
"language_model.model.layers.34.mlp.up_proj.weight": "model-00001-of-00007.safetensors",
|
| 27 |
+
"language_model.model.layers.34.post_attention_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 28 |
+
"language_model.model.layers.34.self_attn.k_norm.weight": "model-00001-of-00007.safetensors",
|
| 29 |
+
"language_model.model.layers.34.self_attn.k_proj.weight": "model-00001-of-00007.safetensors",
|
| 30 |
+
"language_model.model.layers.34.self_attn.o_proj.weight": "model-00001-of-00007.safetensors",
|
| 31 |
+
"language_model.model.layers.34.self_attn.q_norm.weight": "model-00001-of-00007.safetensors",
|
| 32 |
+
"language_model.model.layers.34.self_attn.q_proj.weight": "model-00001-of-00007.safetensors",
|
| 33 |
+
"language_model.model.layers.34.self_attn.v_proj.weight": "model-00001-of-00007.safetensors",
|
| 34 |
+
"language_model.model.layers.35.input_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 35 |
+
"language_model.model.layers.35.mlp.down_proj.weight": "model-00001-of-00007.safetensors",
|
| 36 |
+
"language_model.model.layers.35.mlp.gate_proj.weight": "model-00001-of-00007.safetensors",
|
| 37 |
+
"language_model.model.layers.35.mlp.up_proj.weight": "model-00001-of-00007.safetensors",
|
| 38 |
+
"language_model.model.layers.35.post_attention_layernorm.weight": "model-00001-of-00007.safetensors",
|
| 39 |
+
"language_model.model.layers.35.self_attn.k_norm.weight": "model-00001-of-00007.safetensors",
|
| 40 |
+
"language_model.model.layers.35.self_attn.k_proj.weight": "model-00001-of-00007.safetensors",
|
| 41 |
+
"language_model.model.layers.35.self_attn.o_proj.weight": "model-00001-of-00007.safetensors",
|
| 42 |
+
"language_model.model.layers.35.self_attn.q_norm.weight": "model-00001-of-00007.safetensors",
|
| 43 |
+
"language_model.model.layers.35.self_attn.q_proj.weight": "model-00002-of-00007.safetensors",
|
| 44 |
+
"language_model.model.layers.35.self_attn.v_proj.weight": "model-00002-of-00007.safetensors",
|
| 45 |
+
"language_model.model.norm.weight": "model-00002-of-00007.safetensors",
|
| 46 |
+
"language_model.model.embed_tokens.weight": "model-00002-of-00007.safetensors",
|
| 47 |
+
"language_model.model.layers.0.input_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 48 |
+
"language_model.model.layers.0.mlp.down_proj.weight": "model-00002-of-00007.safetensors",
|
| 49 |
+
"language_model.model.layers.0.mlp.gate_proj.weight": "model-00002-of-00007.safetensors",
|
| 50 |
+
"language_model.model.layers.0.mlp.up_proj.weight": "model-00002-of-00007.safetensors",
|
| 51 |
+
"language_model.model.layers.0.post_attention_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 52 |
+
"language_model.model.layers.0.self_attn.k_norm.weight": "model-00002-of-00007.safetensors",
|
| 53 |
+
"language_model.model.layers.0.self_attn.k_proj.weight": "model-00002-of-00007.safetensors",
|
| 54 |
+
"language_model.model.layers.0.self_attn.o_proj.weight": "model-00002-of-00007.safetensors",
|
| 55 |
+
"language_model.model.layers.0.self_attn.q_norm.weight": "model-00002-of-00007.safetensors",
|
| 56 |
+
"language_model.model.layers.0.self_attn.q_proj.weight": "model-00002-of-00007.safetensors",
|
| 57 |
+
"language_model.model.layers.0.self_attn.v_proj.weight": "model-00002-of-00007.safetensors",
|
| 58 |
+
"language_model.model.layers.1.input_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 59 |
+
"language_model.model.layers.1.mlp.down_proj.weight": "model-00002-of-00007.safetensors",
|
| 60 |
+
"language_model.model.layers.1.mlp.gate_proj.weight": "model-00002-of-00007.safetensors",
|
| 61 |
+
"language_model.model.layers.1.mlp.up_proj.weight": "model-00002-of-00007.safetensors",
|
| 62 |
+
"language_model.model.layers.1.post_attention_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 63 |
+
"language_model.model.layers.1.self_attn.k_norm.weight": "model-00002-of-00007.safetensors",
|
| 64 |
+
"language_model.model.layers.1.self_attn.k_proj.weight": "model-00002-of-00007.safetensors",
|
| 65 |
+
"language_model.model.layers.1.self_attn.o_proj.weight": "model-00002-of-00007.safetensors",
|
| 66 |
+
"language_model.model.layers.1.self_attn.q_norm.weight": "model-00002-of-00007.safetensors",
|
| 67 |
+
"language_model.model.layers.1.self_attn.q_proj.weight": "model-00002-of-00007.safetensors",
|
| 68 |
+
"language_model.model.layers.1.self_attn.v_proj.weight": "model-00002-of-00007.safetensors",
|
| 69 |
+
"language_model.model.layers.2.input_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 70 |
+
"language_model.model.layers.2.mlp.down_proj.weight": "model-00002-of-00007.safetensors",
|
| 71 |
+
"language_model.model.layers.2.mlp.gate_proj.weight": "model-00002-of-00007.safetensors",
|
| 72 |
+
"language_model.model.layers.2.mlp.up_proj.weight": "model-00002-of-00007.safetensors",
|
| 73 |
+
"language_model.model.layers.2.post_attention_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 74 |
+
"language_model.model.layers.2.self_attn.k_norm.weight": "model-00002-of-00007.safetensors",
|
| 75 |
+
"language_model.model.layers.2.self_attn.k_proj.weight": "model-00002-of-00007.safetensors",
|
| 76 |
+
"language_model.model.layers.2.self_attn.o_proj.weight": "model-00002-of-00007.safetensors",
|
| 77 |
+
"language_model.model.layers.2.self_attn.q_norm.weight": "model-00002-of-00007.safetensors",
|
| 78 |
+
"language_model.model.layers.2.self_attn.q_proj.weight": "model-00002-of-00007.safetensors",
|
| 79 |
+
"language_model.model.layers.2.self_attn.v_proj.weight": "model-00002-of-00007.safetensors",
|
| 80 |
+
"language_model.model.layers.3.input_layernorm.weight": "model-00002-of-00007.safetensors",
|
| 81 |
+
"language_model.model.layers.3.mlp.down_proj.weight": "model-00002-of-00007.safetensors",
|
| 82 |
+
"language_model.model.layers.3.mlp.gate_proj.weight": "model-00002-of-00007.safetensors",
|
| 83 |
+
"language_model.model.layers.3.mlp.up_proj.weight": "model-00003-of-00007.safetensors",
|
| 84 |
+
"language_model.model.layers.3.post_attention_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 85 |
+
"language_model.model.layers.3.self_attn.k_norm.weight": "model-00003-of-00007.safetensors",
|
| 86 |
+
"language_model.model.layers.3.self_attn.k_proj.weight": "model-00003-of-00007.safetensors",
|
| 87 |
+
"language_model.model.layers.3.self_attn.o_proj.weight": "model-00003-of-00007.safetensors",
|
| 88 |
+
"language_model.model.layers.3.self_attn.q_norm.weight": "model-00003-of-00007.safetensors",
|
| 89 |
+
"language_model.model.layers.3.self_attn.q_proj.weight": "model-00003-of-00007.safetensors",
|
| 90 |
+
"language_model.model.layers.3.self_attn.v_proj.weight": "model-00003-of-00007.safetensors",
|
| 91 |
+
"language_model.model.layers.4.input_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 92 |
+
"language_model.model.layers.4.mlp.down_proj.weight": "model-00003-of-00007.safetensors",
|
| 93 |
+
"language_model.model.layers.4.mlp.gate_proj.weight": "model-00003-of-00007.safetensors",
|
| 94 |
+
"language_model.model.layers.4.mlp.up_proj.weight": "model-00003-of-00007.safetensors",
|
| 95 |
+
"language_model.model.layers.4.post_attention_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 96 |
+
"language_model.model.layers.4.self_attn.k_norm.weight": "model-00003-of-00007.safetensors",
|
| 97 |
+
"language_model.model.layers.4.self_attn.k_proj.weight": "model-00003-of-00007.safetensors",
|
| 98 |
+
"language_model.model.layers.4.self_attn.o_proj.weight": "model-00003-of-00007.safetensors",
|
| 99 |
+
"language_model.model.layers.4.self_attn.q_norm.weight": "model-00003-of-00007.safetensors",
|
| 100 |
+
"language_model.model.layers.4.self_attn.q_proj.weight": "model-00003-of-00007.safetensors",
|
| 101 |
+
"language_model.model.layers.4.self_attn.v_proj.weight": "model-00003-of-00007.safetensors",
|
| 102 |
+
"language_model.model.layers.5.input_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 103 |
+
"language_model.model.layers.5.mlp.down_proj.weight": "model-00003-of-00007.safetensors",
|
| 104 |
+
"language_model.model.layers.5.mlp.gate_proj.weight": "model-00003-of-00007.safetensors",
|
| 105 |
+
"language_model.model.layers.5.mlp.up_proj.weight": "model-00003-of-00007.safetensors",
|
| 106 |
+
"language_model.model.layers.5.post_attention_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 107 |
+
"language_model.model.layers.5.self_attn.k_norm.weight": "model-00003-of-00007.safetensors",
|
| 108 |
+
"language_model.model.layers.5.self_attn.k_proj.weight": "model-00003-of-00007.safetensors",
|
| 109 |
+
"language_model.model.layers.5.self_attn.o_proj.weight": "model-00003-of-00007.safetensors",
|
| 110 |
+
"language_model.model.layers.5.self_attn.q_norm.weight": "model-00003-of-00007.safetensors",
|
| 111 |
+
"language_model.model.layers.5.self_attn.q_proj.weight": "model-00003-of-00007.safetensors",
|
| 112 |
+
"language_model.model.layers.5.self_attn.v_proj.weight": "model-00003-of-00007.safetensors",
|
| 113 |
+
"language_model.model.layers.6.mlp.gate_proj.weight": "model-00003-of-00007.safetensors",
|
| 114 |
+
"language_model.model.layers.6.mlp.up_proj.weight": "model-00003-of-00007.safetensors",
|
| 115 |
+
"language_model.model.layers.6.self_attn.k_norm.weight": "model-00003-of-00007.safetensors",
|
| 116 |
+
"language_model.model.layers.6.self_attn.k_proj.weight": "model-00003-of-00007.safetensors",
|
| 117 |
+
"language_model.model.layers.6.self_attn.o_proj.weight": "model-00003-of-00007.safetensors",
|
| 118 |
+
"language_model.model.layers.6.self_attn.q_norm.weight": "model-00003-of-00007.safetensors",
|
| 119 |
+
"language_model.model.layers.6.self_attn.q_proj.weight": "model-00003-of-00007.safetensors",
|
| 120 |
+
"language_model.model.layers.6.self_attn.v_proj.weight": "model-00003-of-00007.safetensors",
|
| 121 |
+
"vision_tower.blocks.0.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 122 |
+
"vision_tower.blocks.0.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 123 |
+
"vision_tower.blocks.0.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 124 |
+
"vision_tower.blocks.0.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 125 |
+
"vision_tower.blocks.0.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 126 |
+
"vision_tower.blocks.0.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 127 |
+
"vision_tower.blocks.0.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 128 |
+
"vision_tower.blocks.0.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 129 |
+
"vision_tower.blocks.0.norm1.bias": "model-00003-of-00007.safetensors",
|
| 130 |
+
"vision_tower.blocks.0.norm1.weight": "model-00003-of-00007.safetensors",
|
| 131 |
+
"vision_tower.blocks.0.norm2.bias": "model-00003-of-00007.safetensors",
|
| 132 |
+
"vision_tower.blocks.0.norm2.weight": "model-00003-of-00007.safetensors",
|
| 133 |
+
"vision_tower.blocks.1.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 134 |
+
"vision_tower.blocks.1.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 135 |
+
"vision_tower.blocks.1.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 136 |
+
"vision_tower.blocks.1.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 137 |
+
"vision_tower.blocks.1.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 138 |
+
"vision_tower.blocks.1.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 139 |
+
"vision_tower.blocks.1.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 140 |
+
"vision_tower.blocks.1.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 141 |
+
"vision_tower.blocks.1.norm1.bias": "model-00003-of-00007.safetensors",
|
| 142 |
+
"vision_tower.blocks.1.norm1.weight": "model-00003-of-00007.safetensors",
|
| 143 |
+
"vision_tower.blocks.1.norm2.bias": "model-00003-of-00007.safetensors",
|
| 144 |
+
"vision_tower.blocks.1.norm2.weight": "model-00003-of-00007.safetensors",
|
| 145 |
+
"vision_tower.blocks.10.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 146 |
+
"vision_tower.blocks.10.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 147 |
+
"vision_tower.blocks.10.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 148 |
+
"vision_tower.blocks.10.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 149 |
+
"vision_tower.blocks.10.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 150 |
+
"vision_tower.blocks.10.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 151 |
+
"vision_tower.blocks.10.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 152 |
+
"vision_tower.blocks.10.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 153 |
+
"vision_tower.blocks.10.norm1.bias": "model-00003-of-00007.safetensors",
|
| 154 |
+
"vision_tower.blocks.10.norm1.weight": "model-00003-of-00007.safetensors",
|
| 155 |
+
"vision_tower.blocks.10.norm2.bias": "model-00003-of-00007.safetensors",
|
| 156 |
+
"vision_tower.blocks.10.norm2.weight": "model-00003-of-00007.safetensors",
|
| 157 |
+
"vision_tower.blocks.11.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 158 |
+
"vision_tower.blocks.11.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 159 |
+
"vision_tower.blocks.11.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 160 |
+
"vision_tower.blocks.11.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 161 |
+
"vision_tower.blocks.11.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 162 |
+
"vision_tower.blocks.11.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 163 |
+
"vision_tower.blocks.11.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 164 |
+
"vision_tower.blocks.11.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 165 |
+
"vision_tower.blocks.11.norm1.bias": "model-00003-of-00007.safetensors",
|
| 166 |
+
"vision_tower.blocks.11.norm1.weight": "model-00003-of-00007.safetensors",
|
| 167 |
+
"vision_tower.blocks.11.norm2.bias": "model-00003-of-00007.safetensors",
|
| 168 |
+
"vision_tower.blocks.11.norm2.weight": "model-00003-of-00007.safetensors",
|
| 169 |
+
"vision_tower.blocks.12.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 170 |
+
"vision_tower.blocks.12.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 171 |
+
"vision_tower.blocks.12.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 172 |
+
"vision_tower.blocks.12.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 173 |
+
"vision_tower.blocks.12.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 174 |
+
"vision_tower.blocks.12.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 175 |
+
"vision_tower.blocks.12.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 176 |
+
"vision_tower.blocks.12.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 177 |
+
"vision_tower.blocks.12.norm1.bias": "model-00003-of-00007.safetensors",
|
| 178 |
+
"vision_tower.blocks.12.norm1.weight": "model-00003-of-00007.safetensors",
|
| 179 |
+
"vision_tower.blocks.12.norm2.bias": "model-00003-of-00007.safetensors",
|
| 180 |
+
"vision_tower.blocks.12.norm2.weight": "model-00003-of-00007.safetensors",
|
| 181 |
+
"vision_tower.blocks.13.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 182 |
+
"vision_tower.blocks.13.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 183 |
+
"vision_tower.blocks.13.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 184 |
+
"vision_tower.blocks.13.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 185 |
+
"vision_tower.blocks.13.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 186 |
+
"vision_tower.blocks.13.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 187 |
+
"vision_tower.blocks.13.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 188 |
+
"vision_tower.blocks.13.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 189 |
+
"vision_tower.blocks.13.norm1.bias": "model-00003-of-00007.safetensors",
|
| 190 |
+
"vision_tower.blocks.13.norm1.weight": "model-00003-of-00007.safetensors",
|
| 191 |
+
"vision_tower.blocks.13.norm2.bias": "model-00003-of-00007.safetensors",
|
| 192 |
+
"vision_tower.blocks.13.norm2.weight": "model-00003-of-00007.safetensors",
|
| 193 |
+
"vision_tower.blocks.14.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 194 |
+
"vision_tower.blocks.14.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 195 |
+
"vision_tower.blocks.14.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 196 |
+
"vision_tower.blocks.14.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 197 |
+
"vision_tower.blocks.14.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 198 |
+
"vision_tower.blocks.14.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 199 |
+
"vision_tower.blocks.14.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 200 |
+
"vision_tower.blocks.14.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 201 |
+
"vision_tower.blocks.14.norm1.bias": "model-00003-of-00007.safetensors",
|
| 202 |
+
"vision_tower.blocks.14.norm1.weight": "model-00003-of-00007.safetensors",
|
| 203 |
+
"vision_tower.blocks.14.norm2.bias": "model-00003-of-00007.safetensors",
|
| 204 |
+
"vision_tower.blocks.14.norm2.weight": "model-00003-of-00007.safetensors",
|
| 205 |
+
"vision_tower.blocks.15.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 206 |
+
"vision_tower.blocks.15.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 207 |
+
"vision_tower.blocks.15.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 208 |
+
"vision_tower.blocks.15.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 209 |
+
"vision_tower.blocks.15.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 210 |
+
"vision_tower.blocks.15.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 211 |
+
"vision_tower.blocks.15.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 212 |
+
"vision_tower.blocks.15.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 213 |
+
"vision_tower.blocks.15.norm1.bias": "model-00003-of-00007.safetensors",
|
| 214 |
+
"vision_tower.blocks.15.norm1.weight": "model-00003-of-00007.safetensors",
|
| 215 |
+
"vision_tower.blocks.15.norm2.bias": "model-00003-of-00007.safetensors",
|
| 216 |
+
"vision_tower.blocks.15.norm2.weight": "model-00003-of-00007.safetensors",
|
| 217 |
+
"vision_tower.blocks.16.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 218 |
+
"vision_tower.blocks.16.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 219 |
+
"vision_tower.blocks.16.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 220 |
+
"vision_tower.blocks.16.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 221 |
+
"vision_tower.blocks.16.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 222 |
+
"vision_tower.blocks.16.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 223 |
+
"vision_tower.blocks.16.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 224 |
+
"vision_tower.blocks.16.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 225 |
+
"vision_tower.blocks.16.norm1.bias": "model-00003-of-00007.safetensors",
|
| 226 |
+
"vision_tower.blocks.16.norm1.weight": "model-00003-of-00007.safetensors",
|
| 227 |
+
"vision_tower.blocks.16.norm2.bias": "model-00003-of-00007.safetensors",
|
| 228 |
+
"vision_tower.blocks.16.norm2.weight": "model-00003-of-00007.safetensors",
|
| 229 |
+
"vision_tower.blocks.17.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 230 |
+
"vision_tower.blocks.17.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 231 |
+
"vision_tower.blocks.17.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 232 |
+
"vision_tower.blocks.17.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 233 |
+
"vision_tower.blocks.17.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 234 |
+
"vision_tower.blocks.17.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 235 |
+
"vision_tower.blocks.17.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 236 |
+
"vision_tower.blocks.17.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 237 |
+
"vision_tower.blocks.17.norm1.bias": "model-00003-of-00007.safetensors",
|
| 238 |
+
"vision_tower.blocks.17.norm1.weight": "model-00003-of-00007.safetensors",
|
| 239 |
+
"vision_tower.blocks.17.norm2.bias": "model-00003-of-00007.safetensors",
|
| 240 |
+
"vision_tower.blocks.17.norm2.weight": "model-00003-of-00007.safetensors",
|
| 241 |
+
"vision_tower.blocks.18.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 242 |
+
"vision_tower.blocks.18.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 243 |
+
"vision_tower.blocks.18.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 244 |
+
"vision_tower.blocks.18.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 245 |
+
"vision_tower.blocks.18.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 246 |
+
"vision_tower.blocks.18.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 247 |
+
"vision_tower.blocks.18.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 248 |
+
"vision_tower.blocks.18.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 249 |
+
"vision_tower.blocks.18.norm1.bias": "model-00003-of-00007.safetensors",
|
| 250 |
+
"vision_tower.blocks.18.norm1.weight": "model-00003-of-00007.safetensors",
|
| 251 |
+
"vision_tower.blocks.18.norm2.bias": "model-00003-of-00007.safetensors",
|
| 252 |
+
"vision_tower.blocks.18.norm2.weight": "model-00003-of-00007.safetensors",
|
| 253 |
+
"vision_tower.blocks.19.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 254 |
+
"vision_tower.blocks.19.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 255 |
+
"vision_tower.blocks.19.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 256 |
+
"vision_tower.blocks.19.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 257 |
+
"vision_tower.blocks.19.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 258 |
+
"vision_tower.blocks.19.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 259 |
+
"vision_tower.blocks.19.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 260 |
+
"vision_tower.blocks.19.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 261 |
+
"vision_tower.blocks.19.norm1.bias": "model-00003-of-00007.safetensors",
|
| 262 |
+
"vision_tower.blocks.19.norm1.weight": "model-00003-of-00007.safetensors",
|
| 263 |
+
"vision_tower.blocks.19.norm2.bias": "model-00003-of-00007.safetensors",
|
| 264 |
+
"vision_tower.blocks.19.norm2.weight": "model-00003-of-00007.safetensors",
|
| 265 |
+
"vision_tower.blocks.2.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 266 |
+
"vision_tower.blocks.2.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 267 |
+
"vision_tower.blocks.2.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 268 |
+
"vision_tower.blocks.2.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 269 |
+
"vision_tower.blocks.2.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 270 |
+
"vision_tower.blocks.2.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 271 |
+
"vision_tower.blocks.2.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 272 |
+
"vision_tower.blocks.2.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 273 |
+
"vision_tower.blocks.2.norm1.bias": "model-00003-of-00007.safetensors",
|
| 274 |
+
"vision_tower.blocks.2.norm1.weight": "model-00003-of-00007.safetensors",
|
| 275 |
+
"vision_tower.blocks.2.norm2.bias": "model-00003-of-00007.safetensors",
|
| 276 |
+
"vision_tower.blocks.2.norm2.weight": "model-00003-of-00007.safetensors",
|
| 277 |
+
"vision_tower.blocks.20.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 278 |
+
"vision_tower.blocks.20.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 279 |
+
"vision_tower.blocks.20.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 280 |
+
"vision_tower.blocks.20.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 281 |
+
"vision_tower.blocks.20.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 282 |
+
"vision_tower.blocks.20.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 283 |
+
"vision_tower.blocks.20.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 284 |
+
"vision_tower.blocks.20.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 285 |
+
"vision_tower.blocks.20.norm1.bias": "model-00003-of-00007.safetensors",
|
| 286 |
+
"vision_tower.blocks.20.norm1.weight": "model-00003-of-00007.safetensors",
|
| 287 |
+
"vision_tower.blocks.20.norm2.bias": "model-00003-of-00007.safetensors",
|
| 288 |
+
"vision_tower.blocks.20.norm2.weight": "model-00003-of-00007.safetensors",
|
| 289 |
+
"vision_tower.blocks.21.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 290 |
+
"vision_tower.blocks.21.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 291 |
+
"vision_tower.blocks.21.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 292 |
+
"vision_tower.blocks.21.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 293 |
+
"vision_tower.blocks.21.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 294 |
+
"vision_tower.blocks.21.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 295 |
+
"vision_tower.blocks.21.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 296 |
+
"vision_tower.blocks.21.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 297 |
+
"vision_tower.blocks.21.norm1.bias": "model-00003-of-00007.safetensors",
|
| 298 |
+
"vision_tower.blocks.21.norm1.weight": "model-00003-of-00007.safetensors",
|
| 299 |
+
"vision_tower.blocks.21.norm2.bias": "model-00003-of-00007.safetensors",
|
| 300 |
+
"vision_tower.blocks.21.norm2.weight": "model-00003-of-00007.safetensors",
|
| 301 |
+
"vision_tower.blocks.22.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 302 |
+
"vision_tower.blocks.22.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 303 |
+
"vision_tower.blocks.22.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 304 |
+
"vision_tower.blocks.22.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 305 |
+
"vision_tower.blocks.22.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 306 |
+
"vision_tower.blocks.22.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 307 |
+
"vision_tower.blocks.22.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 308 |
+
"vision_tower.blocks.22.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 309 |
+
"vision_tower.blocks.22.norm1.bias": "model-00003-of-00007.safetensors",
|
| 310 |
+
"vision_tower.blocks.22.norm1.weight": "model-00003-of-00007.safetensors",
|
| 311 |
+
"vision_tower.blocks.22.norm2.bias": "model-00003-of-00007.safetensors",
|
| 312 |
+
"vision_tower.blocks.22.norm2.weight": "model-00003-of-00007.safetensors",
|
| 313 |
+
"vision_tower.blocks.23.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 314 |
+
"vision_tower.blocks.23.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 315 |
+
"vision_tower.blocks.23.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 316 |
+
"vision_tower.blocks.23.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 317 |
+
"vision_tower.blocks.23.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 318 |
+
"vision_tower.blocks.23.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 319 |
+
"vision_tower.blocks.23.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 320 |
+
"vision_tower.blocks.23.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 321 |
+
"vision_tower.blocks.23.norm1.bias": "model-00003-of-00007.safetensors",
|
| 322 |
+
"vision_tower.blocks.23.norm1.weight": "model-00003-of-00007.safetensors",
|
| 323 |
+
"vision_tower.blocks.23.norm2.bias": "model-00003-of-00007.safetensors",
|
| 324 |
+
"vision_tower.blocks.23.norm2.weight": "model-00003-of-00007.safetensors",
|
| 325 |
+
"vision_tower.blocks.24.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 326 |
+
"vision_tower.blocks.24.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 327 |
+
"vision_tower.blocks.24.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 328 |
+
"vision_tower.blocks.24.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 329 |
+
"vision_tower.blocks.24.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 330 |
+
"vision_tower.blocks.24.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 331 |
+
"vision_tower.blocks.24.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 332 |
+
"vision_tower.blocks.24.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 333 |
+
"vision_tower.blocks.24.norm1.bias": "model-00003-of-00007.safetensors",
|
| 334 |
+
"vision_tower.blocks.24.norm1.weight": "model-00003-of-00007.safetensors",
|
| 335 |
+
"vision_tower.blocks.24.norm2.bias": "model-00003-of-00007.safetensors",
|
| 336 |
+
"vision_tower.blocks.24.norm2.weight": "model-00003-of-00007.safetensors",
|
| 337 |
+
"vision_tower.blocks.25.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 338 |
+
"vision_tower.blocks.25.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 339 |
+
"vision_tower.blocks.25.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 340 |
+
"vision_tower.blocks.25.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 341 |
+
"vision_tower.blocks.25.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 342 |
+
"vision_tower.blocks.25.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 343 |
+
"vision_tower.blocks.25.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 344 |
+
"vision_tower.blocks.25.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 345 |
+
"vision_tower.blocks.25.norm1.bias": "model-00003-of-00007.safetensors",
|
| 346 |
+
"vision_tower.blocks.25.norm1.weight": "model-00003-of-00007.safetensors",
|
| 347 |
+
"vision_tower.blocks.25.norm2.bias": "model-00003-of-00007.safetensors",
|
| 348 |
+
"vision_tower.blocks.25.norm2.weight": "model-00003-of-00007.safetensors",
|
| 349 |
+
"vision_tower.blocks.26.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 350 |
+
"vision_tower.blocks.26.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 351 |
+
"vision_tower.blocks.26.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 352 |
+
"vision_tower.blocks.26.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 353 |
+
"vision_tower.blocks.26.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 354 |
+
"vision_tower.blocks.26.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 355 |
+
"vision_tower.blocks.26.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 356 |
+
"vision_tower.blocks.26.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 357 |
+
"vision_tower.blocks.26.norm1.bias": "model-00003-of-00007.safetensors",
|
| 358 |
+
"vision_tower.blocks.26.norm1.weight": "model-00003-of-00007.safetensors",
|
| 359 |
+
"vision_tower.blocks.26.norm2.bias": "model-00003-of-00007.safetensors",
|
| 360 |
+
"vision_tower.blocks.26.norm2.weight": "model-00003-of-00007.safetensors",
|
| 361 |
+
"vision_tower.blocks.3.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 362 |
+
"vision_tower.blocks.3.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 363 |
+
"vision_tower.blocks.3.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 364 |
+
"vision_tower.blocks.3.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 365 |
+
"vision_tower.blocks.3.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 366 |
+
"vision_tower.blocks.3.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 367 |
+
"vision_tower.blocks.3.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 368 |
+
"vision_tower.blocks.3.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 369 |
+
"vision_tower.blocks.3.norm1.bias": "model-00003-of-00007.safetensors",
|
| 370 |
+
"vision_tower.blocks.3.norm1.weight": "model-00003-of-00007.safetensors",
|
| 371 |
+
"vision_tower.blocks.3.norm2.bias": "model-00003-of-00007.safetensors",
|
| 372 |
+
"vision_tower.blocks.3.norm2.weight": "model-00003-of-00007.safetensors",
|
| 373 |
+
"vision_tower.blocks.4.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 374 |
+
"vision_tower.blocks.4.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 375 |
+
"vision_tower.blocks.4.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 376 |
+
"vision_tower.blocks.4.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 377 |
+
"vision_tower.blocks.4.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 378 |
+
"vision_tower.blocks.4.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 379 |
+
"vision_tower.blocks.4.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 380 |
+
"vision_tower.blocks.4.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 381 |
+
"vision_tower.blocks.4.norm1.bias": "model-00003-of-00007.safetensors",
|
| 382 |
+
"vision_tower.blocks.4.norm1.weight": "model-00003-of-00007.safetensors",
|
| 383 |
+
"vision_tower.blocks.4.norm2.bias": "model-00003-of-00007.safetensors",
|
| 384 |
+
"vision_tower.blocks.4.norm2.weight": "model-00003-of-00007.safetensors",
|
| 385 |
+
"vision_tower.blocks.5.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 386 |
+
"vision_tower.blocks.5.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 387 |
+
"vision_tower.blocks.5.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 388 |
+
"vision_tower.blocks.5.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 389 |
+
"vision_tower.blocks.5.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 390 |
+
"vision_tower.blocks.5.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 391 |
+
"vision_tower.blocks.5.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 392 |
+
"vision_tower.blocks.5.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 393 |
+
"vision_tower.blocks.5.norm1.bias": "model-00003-of-00007.safetensors",
|
| 394 |
+
"vision_tower.blocks.5.norm1.weight": "model-00003-of-00007.safetensors",
|
| 395 |
+
"vision_tower.blocks.5.norm2.bias": "model-00003-of-00007.safetensors",
|
| 396 |
+
"vision_tower.blocks.5.norm2.weight": "model-00003-of-00007.safetensors",
|
| 397 |
+
"vision_tower.blocks.6.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 398 |
+
"vision_tower.blocks.6.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 399 |
+
"vision_tower.blocks.6.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 400 |
+
"vision_tower.blocks.6.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 401 |
+
"vision_tower.blocks.6.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 402 |
+
"vision_tower.blocks.6.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 403 |
+
"vision_tower.blocks.6.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 404 |
+
"vision_tower.blocks.6.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 405 |
+
"vision_tower.blocks.6.norm1.bias": "model-00003-of-00007.safetensors",
|
| 406 |
+
"vision_tower.blocks.6.norm1.weight": "model-00003-of-00007.safetensors",
|
| 407 |
+
"vision_tower.blocks.6.norm2.bias": "model-00003-of-00007.safetensors",
|
| 408 |
+
"vision_tower.blocks.6.norm2.weight": "model-00003-of-00007.safetensors",
|
| 409 |
+
"vision_tower.blocks.7.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 410 |
+
"vision_tower.blocks.7.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 411 |
+
"vision_tower.blocks.7.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 412 |
+
"vision_tower.blocks.7.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 413 |
+
"vision_tower.blocks.7.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 414 |
+
"vision_tower.blocks.7.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 415 |
+
"vision_tower.blocks.7.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 416 |
+
"vision_tower.blocks.7.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 417 |
+
"vision_tower.blocks.7.norm1.bias": "model-00003-of-00007.safetensors",
|
| 418 |
+
"vision_tower.blocks.7.norm1.weight": "model-00003-of-00007.safetensors",
|
| 419 |
+
"vision_tower.blocks.7.norm2.bias": "model-00003-of-00007.safetensors",
|
| 420 |
+
"vision_tower.blocks.7.norm2.weight": "model-00003-of-00007.safetensors",
|
| 421 |
+
"vision_tower.blocks.8.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 422 |
+
"vision_tower.blocks.8.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 423 |
+
"vision_tower.blocks.8.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 424 |
+
"vision_tower.blocks.8.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 425 |
+
"vision_tower.blocks.8.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 426 |
+
"vision_tower.blocks.8.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 427 |
+
"vision_tower.blocks.8.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 428 |
+
"vision_tower.blocks.8.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 429 |
+
"vision_tower.blocks.8.norm1.bias": "model-00003-of-00007.safetensors",
|
| 430 |
+
"vision_tower.blocks.8.norm1.weight": "model-00003-of-00007.safetensors",
|
| 431 |
+
"vision_tower.blocks.8.norm2.bias": "model-00003-of-00007.safetensors",
|
| 432 |
+
"vision_tower.blocks.8.norm2.weight": "model-00003-of-00007.safetensors",
|
| 433 |
+
"vision_tower.blocks.9.attn.proj.bias": "model-00003-of-00007.safetensors",
|
| 434 |
+
"vision_tower.blocks.9.attn.proj.weight": "model-00003-of-00007.safetensors",
|
| 435 |
+
"vision_tower.blocks.9.attn.qkv.bias": "model-00003-of-00007.safetensors",
|
| 436 |
+
"vision_tower.blocks.9.attn.qkv.weight": "model-00003-of-00007.safetensors",
|
| 437 |
+
"vision_tower.blocks.9.mlp.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 438 |
+
"vision_tower.blocks.9.mlp.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 439 |
+
"vision_tower.blocks.9.mlp.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 440 |
+
"vision_tower.blocks.9.mlp.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 441 |
+
"vision_tower.blocks.9.norm1.bias": "model-00003-of-00007.safetensors",
|
| 442 |
+
"vision_tower.blocks.9.norm1.weight": "model-00003-of-00007.safetensors",
|
| 443 |
+
"vision_tower.blocks.9.norm2.bias": "model-00003-of-00007.safetensors",
|
| 444 |
+
"vision_tower.blocks.9.norm2.weight": "model-00003-of-00007.safetensors",
|
| 445 |
+
"vision_tower.deepstack_merger_list.0.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 446 |
+
"vision_tower.deepstack_merger_list.0.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 447 |
+
"vision_tower.deepstack_merger_list.0.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 448 |
+
"vision_tower.deepstack_merger_list.0.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 449 |
+
"vision_tower.deepstack_merger_list.0.norm.bias": "model-00003-of-00007.safetensors",
|
| 450 |
+
"vision_tower.deepstack_merger_list.0.norm.weight": "model-00003-of-00007.safetensors",
|
| 451 |
+
"vision_tower.deepstack_merger_list.1.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 452 |
+
"vision_tower.deepstack_merger_list.1.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 453 |
+
"vision_tower.deepstack_merger_list.1.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 454 |
+
"vision_tower.deepstack_merger_list.1.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 455 |
+
"vision_tower.deepstack_merger_list.1.norm.bias": "model-00003-of-00007.safetensors",
|
| 456 |
+
"vision_tower.deepstack_merger_list.1.norm.weight": "model-00003-of-00007.safetensors",
|
| 457 |
+
"vision_tower.deepstack_merger_list.2.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 458 |
+
"vision_tower.deepstack_merger_list.2.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 459 |
+
"vision_tower.deepstack_merger_list.2.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 460 |
+
"vision_tower.deepstack_merger_list.2.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 461 |
+
"vision_tower.deepstack_merger_list.2.norm.bias": "model-00003-of-00007.safetensors",
|
| 462 |
+
"vision_tower.deepstack_merger_list.2.norm.weight": "model-00003-of-00007.safetensors",
|
| 463 |
+
"vision_tower.merger.linear_fc1.bias": "model-00003-of-00007.safetensors",
|
| 464 |
+
"vision_tower.merger.linear_fc1.weight": "model-00003-of-00007.safetensors",
|
| 465 |
+
"vision_tower.merger.linear_fc2.bias": "model-00003-of-00007.safetensors",
|
| 466 |
+
"vision_tower.merger.linear_fc2.weight": "model-00003-of-00007.safetensors",
|
| 467 |
+
"vision_tower.merger.norm.bias": "model-00003-of-00007.safetensors",
|
| 468 |
+
"vision_tower.merger.norm.weight": "model-00003-of-00007.safetensors",
|
| 469 |
+
"vision_tower.patch_embed.proj.bias": "model-00003-of-00007.safetensors",
|
| 470 |
+
"vision_tower.patch_embed.proj.weight": "model-00003-of-00007.safetensors",
|
| 471 |
+
"vision_tower.pos_embed.weight": "model-00003-of-00007.safetensors",
|
| 472 |
+
"language_model.model.layers.10.input_layernorm.weight": "model-00003-of-00007.safetensors",
|
| 473 |
+
"language_model.model.layers.10.mlp.down_proj.weight": "model-00003-of-00007.safetensors",
|
| 474 |
+
"language_model.model.layers.10.mlp.gate_proj.weight": "model-00003-of-00007.safetensors",
|
| 475 |
+
"language_model.model.layers.10.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 476 |
+
"language_model.model.layers.10.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 477 |
+
"language_model.model.layers.10.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 478 |
+
"language_model.model.layers.10.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 479 |
+
"language_model.model.layers.10.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 480 |
+
"language_model.model.layers.10.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 481 |
+
"language_model.model.layers.10.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 482 |
+
"language_model.model.layers.10.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 483 |
+
"language_model.model.layers.11.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 484 |
+
"language_model.model.layers.11.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 485 |
+
"language_model.model.layers.11.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 486 |
+
"language_model.model.layers.11.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 487 |
+
"language_model.model.layers.11.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 488 |
+
"language_model.model.layers.11.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 489 |
+
"language_model.model.layers.11.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 490 |
+
"language_model.model.layers.11.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 491 |
+
"language_model.model.layers.11.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 492 |
+
"language_model.model.layers.11.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 493 |
+
"language_model.model.layers.11.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 494 |
+
"language_model.model.layers.12.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 495 |
+
"language_model.model.layers.12.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 496 |
+
"language_model.model.layers.12.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 497 |
+
"language_model.model.layers.12.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 498 |
+
"language_model.model.layers.12.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 499 |
+
"language_model.model.layers.12.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 500 |
+
"language_model.model.layers.12.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 501 |
+
"language_model.model.layers.12.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 502 |
+
"language_model.model.layers.12.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 503 |
+
"language_model.model.layers.12.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 504 |
+
"language_model.model.layers.12.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 505 |
+
"language_model.model.layers.13.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 506 |
+
"language_model.model.layers.13.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 507 |
+
"language_model.model.layers.13.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 508 |
+
"language_model.model.layers.13.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 509 |
+
"language_model.model.layers.13.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 510 |
+
"language_model.model.layers.13.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 511 |
+
"language_model.model.layers.13.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 512 |
+
"language_model.model.layers.13.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 513 |
+
"language_model.model.layers.13.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 514 |
+
"language_model.model.layers.13.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 515 |
+
"language_model.model.layers.13.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 516 |
+
"language_model.model.layers.14.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 517 |
+
"language_model.model.layers.14.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 518 |
+
"language_model.model.layers.14.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 519 |
+
"language_model.model.layers.14.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 520 |
+
"language_model.model.layers.14.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 521 |
+
"language_model.model.layers.14.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 522 |
+
"language_model.model.layers.14.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 523 |
+
"language_model.model.layers.14.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 524 |
+
"language_model.model.layers.14.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 525 |
+
"language_model.model.layers.14.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 526 |
+
"language_model.model.layers.14.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 527 |
+
"language_model.model.layers.15.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 528 |
+
"language_model.model.layers.15.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 529 |
+
"language_model.model.layers.15.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 530 |
+
"language_model.model.layers.15.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 531 |
+
"language_model.model.layers.15.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 532 |
+
"language_model.model.layers.15.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 533 |
+
"language_model.model.layers.15.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 534 |
+
"language_model.model.layers.15.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 535 |
+
"language_model.model.layers.15.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 536 |
+
"language_model.model.layers.15.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 537 |
+
"language_model.model.layers.15.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 538 |
+
"language_model.model.layers.16.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 539 |
+
"language_model.model.layers.16.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 540 |
+
"language_model.model.layers.16.mlp.gate_proj.weight": "model-00004-of-00007.safetensors",
|
| 541 |
+
"language_model.model.layers.16.mlp.up_proj.weight": "model-00004-of-00007.safetensors",
|
| 542 |
+
"language_model.model.layers.16.post_attention_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 543 |
+
"language_model.model.layers.16.self_attn.k_norm.weight": "model-00004-of-00007.safetensors",
|
| 544 |
+
"language_model.model.layers.16.self_attn.k_proj.weight": "model-00004-of-00007.safetensors",
|
| 545 |
+
"language_model.model.layers.16.self_attn.o_proj.weight": "model-00004-of-00007.safetensors",
|
| 546 |
+
"language_model.model.layers.16.self_attn.q_norm.weight": "model-00004-of-00007.safetensors",
|
| 547 |
+
"language_model.model.layers.16.self_attn.q_proj.weight": "model-00004-of-00007.safetensors",
|
| 548 |
+
"language_model.model.layers.16.self_attn.v_proj.weight": "model-00004-of-00007.safetensors",
|
| 549 |
+
"language_model.model.layers.17.input_layernorm.weight": "model-00004-of-00007.safetensors",
|
| 550 |
+
"language_model.model.layers.17.mlp.down_proj.weight": "model-00004-of-00007.safetensors",
|
| 551 |
+
"language_model.model.layers.17.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 552 |
+
"language_model.model.layers.17.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 553 |
+
"language_model.model.layers.17.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 554 |
+
"language_model.model.layers.17.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 555 |
+
"language_model.model.layers.17.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 556 |
+
"language_model.model.layers.17.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 557 |
+
"language_model.model.layers.17.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 558 |
+
"language_model.model.layers.17.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 559 |
+
"language_model.model.layers.17.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 560 |
+
"language_model.model.layers.18.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 561 |
+
"language_model.model.layers.18.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 562 |
+
"language_model.model.layers.18.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 563 |
+
"language_model.model.layers.18.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 564 |
+
"language_model.model.layers.18.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 565 |
+
"language_model.model.layers.18.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 566 |
+
"language_model.model.layers.18.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 567 |
+
"language_model.model.layers.18.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 568 |
+
"language_model.model.layers.18.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 569 |
+
"language_model.model.layers.18.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 570 |
+
"language_model.model.layers.18.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 571 |
+
"language_model.model.layers.19.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 572 |
+
"language_model.model.layers.19.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 573 |
+
"language_model.model.layers.19.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 574 |
+
"language_model.model.layers.19.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 575 |
+
"language_model.model.layers.19.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 576 |
+
"language_model.model.layers.19.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 577 |
+
"language_model.model.layers.19.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 578 |
+
"language_model.model.layers.6.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 579 |
+
"language_model.model.layers.6.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 580 |
+
"language_model.model.layers.6.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 581 |
+
"language_model.model.layers.7.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 582 |
+
"language_model.model.layers.7.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 583 |
+
"language_model.model.layers.7.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 584 |
+
"language_model.model.layers.7.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 585 |
+
"language_model.model.layers.7.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 586 |
+
"language_model.model.layers.7.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 587 |
+
"language_model.model.layers.7.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 588 |
+
"language_model.model.layers.7.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 589 |
+
"language_model.model.layers.7.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 590 |
+
"language_model.model.layers.7.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 591 |
+
"language_model.model.layers.7.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 592 |
+
"language_model.model.layers.8.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 593 |
+
"language_model.model.layers.8.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 594 |
+
"language_model.model.layers.8.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 595 |
+
"language_model.model.layers.8.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 596 |
+
"language_model.model.layers.8.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 597 |
+
"language_model.model.layers.8.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 598 |
+
"language_model.model.layers.8.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 599 |
+
"language_model.model.layers.8.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 600 |
+
"language_model.model.layers.8.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 601 |
+
"language_model.model.layers.8.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 602 |
+
"language_model.model.layers.8.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 603 |
+
"language_model.model.layers.9.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 604 |
+
"language_model.model.layers.9.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 605 |
+
"language_model.model.layers.9.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 606 |
+
"language_model.model.layers.9.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 607 |
+
"language_model.model.layers.9.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 608 |
+
"language_model.model.layers.9.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 609 |
+
"language_model.model.layers.9.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 610 |
+
"language_model.model.layers.9.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 611 |
+
"language_model.model.layers.9.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 612 |
+
"language_model.model.layers.9.self_attn.q_proj.weight": "model-00005-of-00007.safetensors",
|
| 613 |
+
"language_model.model.layers.9.self_attn.v_proj.weight": "model-00005-of-00007.safetensors",
|
| 614 |
+
"language_model.model.layers.19.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 615 |
+
"language_model.model.layers.19.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 616 |
+
"language_model.model.layers.19.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 617 |
+
"language_model.model.layers.19.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 618 |
+
"language_model.model.layers.20.input_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 619 |
+
"language_model.model.layers.20.mlp.down_proj.weight": "model-00005-of-00007.safetensors",
|
| 620 |
+
"language_model.model.layers.20.mlp.gate_proj.weight": "model-00005-of-00007.safetensors",
|
| 621 |
+
"language_model.model.layers.20.mlp.up_proj.weight": "model-00005-of-00007.safetensors",
|
| 622 |
+
"language_model.model.layers.20.post_attention_layernorm.weight": "model-00005-of-00007.safetensors",
|
| 623 |
+
"language_model.model.layers.20.self_attn.k_norm.weight": "model-00005-of-00007.safetensors",
|
| 624 |
+
"language_model.model.layers.20.self_attn.k_proj.weight": "model-00005-of-00007.safetensors",
|
| 625 |
+
"language_model.model.layers.20.self_attn.o_proj.weight": "model-00005-of-00007.safetensors",
|
| 626 |
+
"language_model.model.layers.20.self_attn.q_norm.weight": "model-00005-of-00007.safetensors",
|
| 627 |
+
"language_model.model.layers.20.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 628 |
+
"language_model.model.layers.20.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 629 |
+
"language_model.model.layers.21.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 630 |
+
"language_model.model.layers.21.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 631 |
+
"language_model.model.layers.21.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 632 |
+
"language_model.model.layers.21.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 633 |
+
"language_model.model.layers.21.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 634 |
+
"language_model.model.layers.21.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 635 |
+
"language_model.model.layers.21.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 636 |
+
"language_model.model.layers.21.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 637 |
+
"language_model.model.layers.21.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 638 |
+
"language_model.model.layers.21.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 639 |
+
"language_model.model.layers.21.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 640 |
+
"language_model.model.layers.22.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 641 |
+
"language_model.model.layers.22.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 642 |
+
"language_model.model.layers.22.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 643 |
+
"language_model.model.layers.22.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 644 |
+
"language_model.model.layers.22.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 645 |
+
"language_model.model.layers.22.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 646 |
+
"language_model.model.layers.22.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 647 |
+
"language_model.model.layers.22.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 648 |
+
"language_model.model.layers.22.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 649 |
+
"language_model.model.layers.22.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 650 |
+
"language_model.model.layers.22.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 651 |
+
"language_model.model.layers.23.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 652 |
+
"language_model.model.layers.23.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 653 |
+
"language_model.model.layers.23.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 654 |
+
"language_model.model.layers.23.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 655 |
+
"language_model.model.layers.23.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 656 |
+
"language_model.model.layers.23.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 657 |
+
"language_model.model.layers.23.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 658 |
+
"language_model.model.layers.23.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 659 |
+
"language_model.model.layers.23.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 660 |
+
"language_model.model.layers.23.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 661 |
+
"language_model.model.layers.23.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 662 |
+
"language_model.model.layers.24.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 663 |
+
"language_model.model.layers.24.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 664 |
+
"language_model.model.layers.24.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 665 |
+
"language_model.model.layers.24.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 666 |
+
"language_model.model.layers.24.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 667 |
+
"language_model.model.layers.24.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 668 |
+
"language_model.model.layers.24.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 669 |
+
"language_model.model.layers.24.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 670 |
+
"language_model.model.layers.24.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 671 |
+
"language_model.model.layers.24.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 672 |
+
"language_model.model.layers.24.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 673 |
+
"language_model.model.layers.25.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 674 |
+
"language_model.model.layers.25.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 675 |
+
"language_model.model.layers.25.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 676 |
+
"language_model.model.layers.25.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 677 |
+
"language_model.model.layers.25.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 678 |
+
"language_model.model.layers.25.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 679 |
+
"language_model.model.layers.25.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 680 |
+
"language_model.model.layers.25.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 681 |
+
"language_model.model.layers.25.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 682 |
+
"language_model.model.layers.25.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 683 |
+
"language_model.model.layers.25.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 684 |
+
"language_model.model.layers.26.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 685 |
+
"language_model.model.layers.26.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 686 |
+
"language_model.model.layers.26.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 687 |
+
"language_model.model.layers.26.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 688 |
+
"language_model.model.layers.26.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 689 |
+
"language_model.model.layers.26.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 690 |
+
"language_model.model.layers.26.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 691 |
+
"language_model.model.layers.26.self_attn.o_proj.weight": "model-00006-of-00007.safetensors",
|
| 692 |
+
"language_model.model.layers.26.self_attn.q_norm.weight": "model-00006-of-00007.safetensors",
|
| 693 |
+
"language_model.model.layers.26.self_attn.q_proj.weight": "model-00006-of-00007.safetensors",
|
| 694 |
+
"language_model.model.layers.26.self_attn.v_proj.weight": "model-00006-of-00007.safetensors",
|
| 695 |
+
"language_model.model.layers.27.input_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 696 |
+
"language_model.model.layers.27.mlp.down_proj.weight": "model-00006-of-00007.safetensors",
|
| 697 |
+
"language_model.model.layers.27.mlp.gate_proj.weight": "model-00006-of-00007.safetensors",
|
| 698 |
+
"language_model.model.layers.27.mlp.up_proj.weight": "model-00006-of-00007.safetensors",
|
| 699 |
+
"language_model.model.layers.27.post_attention_layernorm.weight": "model-00006-of-00007.safetensors",
|
| 700 |
+
"language_model.model.layers.27.self_attn.k_norm.weight": "model-00006-of-00007.safetensors",
|
| 701 |
+
"language_model.model.layers.27.self_attn.k_proj.weight": "model-00006-of-00007.safetensors",
|
| 702 |
+
"language_model.model.layers.27.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 703 |
+
"language_model.model.layers.27.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 704 |
+
"language_model.model.layers.27.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 705 |
+
"language_model.model.layers.27.self_attn.v_proj.weight": "model-00007-of-00007.safetensors",
|
| 706 |
+
"language_model.model.layers.28.input_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 707 |
+
"language_model.model.layers.28.mlp.down_proj.weight": "model-00007-of-00007.safetensors",
|
| 708 |
+
"language_model.model.layers.28.mlp.gate_proj.weight": "model-00007-of-00007.safetensors",
|
| 709 |
+
"language_model.model.layers.28.mlp.up_proj.weight": "model-00007-of-00007.safetensors",
|
| 710 |
+
"language_model.model.layers.28.post_attention_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 711 |
+
"language_model.model.layers.28.self_attn.k_norm.weight": "model-00007-of-00007.safetensors",
|
| 712 |
+
"language_model.model.layers.28.self_attn.k_proj.weight": "model-00007-of-00007.safetensors",
|
| 713 |
+
"language_model.model.layers.28.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 714 |
+
"language_model.model.layers.28.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 715 |
+
"language_model.model.layers.28.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 716 |
+
"language_model.model.layers.28.self_attn.v_proj.weight": "model-00007-of-00007.safetensors",
|
| 717 |
+
"language_model.model.layers.29.input_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 718 |
+
"language_model.model.layers.29.mlp.down_proj.weight": "model-00007-of-00007.safetensors",
|
| 719 |
+
"language_model.model.layers.29.mlp.gate_proj.weight": "model-00007-of-00007.safetensors",
|
| 720 |
+
"language_model.model.layers.29.mlp.up_proj.weight": "model-00007-of-00007.safetensors",
|
| 721 |
+
"language_model.model.layers.29.post_attention_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 722 |
+
"language_model.model.layers.29.self_attn.k_norm.weight": "model-00007-of-00007.safetensors",
|
| 723 |
+
"language_model.model.layers.29.self_attn.k_proj.weight": "model-00007-of-00007.safetensors",
|
| 724 |
+
"language_model.model.layers.29.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 725 |
+
"language_model.model.layers.29.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 726 |
+
"language_model.model.layers.29.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 727 |
+
"language_model.model.layers.29.self_attn.v_proj.weight": "model-00007-of-00007.safetensors",
|
| 728 |
+
"language_model.model.layers.30.input_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 729 |
+
"language_model.model.layers.30.mlp.down_proj.weight": "model-00007-of-00007.safetensors",
|
| 730 |
+
"language_model.model.layers.30.mlp.gate_proj.weight": "model-00007-of-00007.safetensors",
|
| 731 |
+
"language_model.model.layers.30.mlp.up_proj.weight": "model-00007-of-00007.safetensors",
|
| 732 |
+
"language_model.model.layers.30.post_attention_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 733 |
+
"language_model.model.layers.30.self_attn.k_norm.weight": "model-00007-of-00007.safetensors",
|
| 734 |
+
"language_model.model.layers.30.self_attn.k_proj.weight": "model-00007-of-00007.safetensors",
|
| 735 |
+
"language_model.model.layers.30.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 736 |
+
"language_model.model.layers.30.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 737 |
+
"language_model.model.layers.30.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 738 |
+
"language_model.model.layers.30.self_attn.v_proj.weight": "model-00007-of-00007.safetensors",
|
| 739 |
+
"language_model.model.layers.31.input_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 740 |
+
"language_model.model.layers.31.mlp.down_proj.weight": "model-00007-of-00007.safetensors",
|
| 741 |
+
"language_model.model.layers.31.mlp.gate_proj.weight": "model-00007-of-00007.safetensors",
|
| 742 |
+
"language_model.model.layers.31.mlp.up_proj.weight": "model-00007-of-00007.safetensors",
|
| 743 |
+
"language_model.model.layers.31.post_attention_layernorm.weight": "model-00007-of-00007.safetensors",
|
| 744 |
+
"language_model.model.layers.31.self_attn.k_norm.weight": "model-00007-of-00007.safetensors",
|
| 745 |
+
"language_model.model.layers.31.self_attn.k_proj.weight": "model-00007-of-00007.safetensors",
|
| 746 |
+
"language_model.model.layers.31.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 747 |
+
"language_model.model.layers.31.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 748 |
+
"language_model.model.layers.31.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 749 |
+
"language_model.model.layers.31.self_attn.v_proj.weight": "model-00007-of-00007.safetensors",
|
| 750 |
+
"language_model.model.layers.32.self_attn.k_norm.weight": "model-00007-of-00007.safetensors",
|
| 751 |
+
"language_model.model.layers.32.self_attn.k_proj.weight": "model-00007-of-00007.safetensors",
|
| 752 |
+
"language_model.model.layers.32.self_attn.o_proj.weight": "model-00007-of-00007.safetensors",
|
| 753 |
+
"language_model.model.layers.32.self_attn.q_norm.weight": "model-00007-of-00007.safetensors",
|
| 754 |
+
"language_model.model.layers.32.self_attn.q_proj.weight": "model-00007-of-00007.safetensors",
|
| 755 |
+
"language_model.model.layers.32.self_attn.v_proj.weight": "model-00007-of-00007.safetensors"
|
| 756 |
+
}
|
| 757 |
+
}
|
preprocessor_config.json
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"crop_size": null,
|
| 3 |
+
"data_format": "channels_first",
|
| 4 |
+
"default_to_square": true,
|
| 5 |
+
"device": null,
|
| 6 |
+
"disable_grouping": null,
|
| 7 |
+
"do_center_crop": null,
|
| 8 |
+
"do_convert_rgb": true,
|
| 9 |
+
"do_normalize": true,
|
| 10 |
+
"do_pad": null,
|
| 11 |
+
"do_rescale": true,
|
| 12 |
+
"do_resize": true,
|
| 13 |
+
"image_mean": [
|
| 14 |
+
0.5,
|
| 15 |
+
0.5,
|
| 16 |
+
0.5
|
| 17 |
+
],
|
| 18 |
+
"image_processor_type": "Qwen2VLImageProcessorFast",
|
| 19 |
+
"image_std": [
|
| 20 |
+
0.5,
|
| 21 |
+
0.5,
|
| 22 |
+
0.5
|
| 23 |
+
],
|
| 24 |
+
"input_data_format": null,
|
| 25 |
+
"max_pixels": null,
|
| 26 |
+
"merge_size": 2,
|
| 27 |
+
"min_pixels": null,
|
| 28 |
+
"pad_size": null,
|
| 29 |
+
"patch_size": 16,
|
| 30 |
+
"processor_class": "Qwen3VLProcessor",
|
| 31 |
+
"resample": 3,
|
| 32 |
+
"rescale_factor": 0.00392156862745098,
|
| 33 |
+
"return_tensors": null,
|
| 34 |
+
"size": {
|
| 35 |
+
"longest_edge": 16777216,
|
| 36 |
+
"shortest_edge": 65536
|
| 37 |
+
},
|
| 38 |
+
"temporal_patch_size": 2
|
| 39 |
+
}
|
projections/projection_128d.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:3b1c953b2e215a6d75d5c43cd8f4f3776bf955c81bddd195ff73ae35512bc099
|
| 3 |
+
size 5244352
|
projections/projection_320d.safetensors
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:809888951c0e8047a7162fc4ac1d57a0c1624cf756152bee08b6184eb6e2bfec
|
| 3 |
+
size 2622224
|
scripts/colqwen3_embedder.py
ADDED
|
@@ -0,0 +1,478 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"""
|
| 2 |
+
ColQwen3 MLX Embedder
|
| 3 |
+
|
| 4 |
+
Production-ready multimodal document embedding using Tomoro-ColQwen3 on MLX.
|
| 5 |
+
Provides ColPali-style multi-vector embeddings for visual document retrieval.
|
| 6 |
+
|
| 7 |
+
Key insight: For proper image embeddings, <|image_pad|> tokens must be expanded
|
| 8 |
+
to match the number of vision patches, and only image token embeddings should
|
| 9 |
+
be used for MaxSim scoring.
|
| 10 |
+
|
| 11 |
+
Created by M&K (c)2025 The LibraxisAI Team
|
| 12 |
+
Co-Authored-By: Maciej (void@div0.space) & Klaudiusz (the1st@whoai.am)
|
| 13 |
+
"""
|
| 14 |
+
|
| 15 |
+
import os
|
| 16 |
+
from dataclasses import dataclass
|
| 17 |
+
from pathlib import Path
|
| 18 |
+
from typing import List, Optional, Tuple, Union
|
| 19 |
+
|
| 20 |
+
import mlx.core as mx
|
| 21 |
+
import numpy as np
|
| 22 |
+
from PIL import Image
|
| 23 |
+
|
| 24 |
+
# Special token ID for image patches
|
| 25 |
+
IMAGE_PAD_TOKEN = 151655
|
| 26 |
+
|
| 27 |
+
|
| 28 |
+
@dataclass
|
| 29 |
+
class EmbeddingResult:
|
| 30 |
+
"""Result of embedding operation."""
|
| 31 |
+
|
| 32 |
+
embeddings: mx.array # [num_tokens, 320]
|
| 33 |
+
num_tokens: int
|
| 34 |
+
source_type: str # "text" or "image"
|
| 35 |
+
|
| 36 |
+
|
| 37 |
+
class ColQwen3Embedder:
|
| 38 |
+
"""
|
| 39 |
+
ColQwen3 document embedder using MLX.
|
| 40 |
+
|
| 41 |
+
Provides multi-vector embeddings optimized for document retrieval
|
| 42 |
+
using Late Interaction (MaxSim) scoring.
|
| 43 |
+
|
| 44 |
+
Environment Variables:
|
| 45 |
+
COLQWEN3_MODEL_PATH: Path to Tomoro-ColQwen3 MLX model directory.
|
| 46 |
+
Default: /Volumes/Maciejowe/mlx_lm/models/tomoro-colqwen3-8b-mlx
|
| 47 |
+
COLQWEN3_PROJECTION_PATH: Path to embedding projection weights (.safetensors).
|
| 48 |
+
Default: /Volumes/Maciejowe/mlx_lm/models/colqwen3_projection.safetensors
|
| 49 |
+
|
| 50 |
+
Usage:
|
| 51 |
+
# Option 1: Set environment variables
|
| 52 |
+
export COLQWEN3_MODEL_PATH="/path/to/tomoro-colqwen3-8b-mlx"
|
| 53 |
+
export COLQWEN3_PROJECTION_PATH="/path/to/colqwen3_projection.safetensors"
|
| 54 |
+
|
| 55 |
+
embedder = ColQwen3Embedder()
|
| 56 |
+
embedder.load()
|
| 57 |
+
|
| 58 |
+
# Option 2: Pass paths directly (overrides env vars)
|
| 59 |
+
embedder = ColQwen3Embedder(
|
| 60 |
+
model_path="/path/to/model",
|
| 61 |
+
projection_path="/path/to/projection.safetensors"
|
| 62 |
+
)
|
| 63 |
+
embedder.load()
|
| 64 |
+
|
| 65 |
+
# Embed a document image
|
| 66 |
+
doc_emb = embedder.embed_image("document.png")
|
| 67 |
+
|
| 68 |
+
# Embed a text query
|
| 69 |
+
query_emb = embedder.embed_text("search query")
|
| 70 |
+
|
| 71 |
+
# Score relevance
|
| 72 |
+
score = embedder.maxsim_score(query_emb, doc_emb)
|
| 73 |
+
|
| 74 |
+
Created by M&K (c)2025 The LibraxisAI Team
|
| 75 |
+
"""
|
| 76 |
+
|
| 77 |
+
# Environment variable names for configuration
|
| 78 |
+
ENV_MODEL_PATH = "COLQWEN3_MODEL_PATH"
|
| 79 |
+
ENV_PROJECTION_PATH = "COLQWEN3_PROJECTION_PATH"
|
| 80 |
+
|
| 81 |
+
# Default paths (backward compatibility with existing setup)
|
| 82 |
+
DEFAULT_MODEL_PATH = "/Volumes/Maciejowe/mlx_lm/models/tomoro-colqwen3-8b-mlx"
|
| 83 |
+
DEFAULT_PROJ_PATH = "/Volumes/Maciejowe/mlx_lm/models/colqwen3_projection.safetensors"
|
| 84 |
+
|
| 85 |
+
def __init__(
|
| 86 |
+
self,
|
| 87 |
+
model_path: Optional[str] = None,
|
| 88 |
+
projection_path: Optional[str] = None,
|
| 89 |
+
embedding_dim: int = 320,
|
| 90 |
+
):
|
| 91 |
+
"""
|
| 92 |
+
Initialize the embedder.
|
| 93 |
+
|
| 94 |
+
Args:
|
| 95 |
+
model_path: Path to Tomoro-ColQwen3 MLX model (overrides env var)
|
| 96 |
+
projection_path: Path to embedding projection weights (overrides env var)
|
| 97 |
+
embedding_dim: Output embedding dimension (default 320)
|
| 98 |
+
|
| 99 |
+
Path resolution order:
|
| 100 |
+
1. Explicitly passed argument
|
| 101 |
+
2. Environment variable (COLQWEN3_MODEL_PATH / COLQWEN3_PROJECTION_PATH)
|
| 102 |
+
3. Default fallback path
|
| 103 |
+
"""
|
| 104 |
+
self.model_path = model_path or os.environ.get(self.ENV_MODEL_PATH) or self.DEFAULT_MODEL_PATH
|
| 105 |
+
self.projection_path = projection_path or os.environ.get(self.ENV_PROJECTION_PATH) or self.DEFAULT_PROJ_PATH
|
| 106 |
+
self.embedding_dim = embedding_dim
|
| 107 |
+
|
| 108 |
+
self.model = None
|
| 109 |
+
self.mlx_processor = None
|
| 110 |
+
self.tomoro_processor = None
|
| 111 |
+
self.proj_weight = None
|
| 112 |
+
self.proj_bias = None
|
| 113 |
+
self._loaded = False
|
| 114 |
+
|
| 115 |
+
def load(self) -> None:
|
| 116 |
+
"""Load model, processor, and projection weights."""
|
| 117 |
+
if self._loaded:
|
| 118 |
+
return
|
| 119 |
+
|
| 120 |
+
from mlx_vlm import load
|
| 121 |
+
from safetensors.torch import load_file
|
| 122 |
+
from transformers import AutoProcessor
|
| 123 |
+
|
| 124 |
+
print(f"Loading ColQwen3 from {self.model_path}...")
|
| 125 |
+
self.model, self.mlx_processor = load(self.model_path)
|
| 126 |
+
|
| 127 |
+
# Load Tomoro processor for proper image token expansion
|
| 128 |
+
print("Loading Tomoro processor for image token expansion...")
|
| 129 |
+
self.tomoro_processor = AutoProcessor.from_pretrained(
|
| 130 |
+
"TomoroAI/tomoro-colqwen3-embed-8b", trust_remote_code=True
|
| 131 |
+
)
|
| 132 |
+
|
| 133 |
+
print(f"Loading projection from {self.projection_path}...")
|
| 134 |
+
proj_weights = load_file(self.projection_path)
|
| 135 |
+
self.proj_weight = mx.array(proj_weights["embedding_proj_layer.weight"].float().numpy())
|
| 136 |
+
self.proj_bias = mx.array(proj_weights["embedding_proj_layer.bias"].float().numpy())
|
| 137 |
+
|
| 138 |
+
self._loaded = True
|
| 139 |
+
print("ColQwen3 Embedder ready!")
|
| 140 |
+
|
| 141 |
+
def _ensure_loaded(self) -> None:
|
| 142 |
+
"""Ensure model is loaded."""
|
| 143 |
+
if not self._loaded:
|
| 144 |
+
self.load()
|
| 145 |
+
|
| 146 |
+
def _project_and_normalize(self, hidden_states: mx.array) -> mx.array:
|
| 147 |
+
"""Apply projection layer and L2 normalize."""
|
| 148 |
+
# Project to embedding dimension
|
| 149 |
+
embeddings = hidden_states @ self.proj_weight.T + self.proj_bias
|
| 150 |
+
|
| 151 |
+
# L2 normalize
|
| 152 |
+
norm = mx.sqrt(mx.sum(embeddings**2, axis=-1, keepdims=True) + 1e-12)
|
| 153 |
+
embeddings = embeddings / norm
|
| 154 |
+
|
| 155 |
+
return embeddings
|
| 156 |
+
|
| 157 |
+
def embed_text(self, text: str) -> EmbeddingResult:
|
| 158 |
+
"""
|
| 159 |
+
Embed text query.
|
| 160 |
+
|
| 161 |
+
Args:
|
| 162 |
+
text: Query string
|
| 163 |
+
|
| 164 |
+
Returns:
|
| 165 |
+
EmbeddingResult with shape [num_tokens, 320]
|
| 166 |
+
"""
|
| 167 |
+
self._ensure_loaded()
|
| 168 |
+
|
| 169 |
+
# Get inner language model (skips lm_head)
|
| 170 |
+
inner_model = self.model["language_model"]["model"]
|
| 171 |
+
|
| 172 |
+
# Tokenize using Tomoro processor for consistency
|
| 173 |
+
inputs = self.tomoro_processor.tokenizer(text, return_tensors="np")
|
| 174 |
+
input_ids = mx.array(inputs["input_ids"])
|
| 175 |
+
batch_size, seq_len = input_ids.shape
|
| 176 |
+
|
| 177 |
+
# Create position IDs for M-ROPE
|
| 178 |
+
position_ids = mx.arange(seq_len).reshape(1, -1)
|
| 179 |
+
position_ids = mx.broadcast_to(position_ids, (batch_size, seq_len))
|
| 180 |
+
position_ids = mx.broadcast_to(position_ids[None, ...], (3, batch_size, seq_len))
|
| 181 |
+
|
| 182 |
+
# Get hidden states
|
| 183 |
+
hidden_states = inner_model(input_ids, position_ids=position_ids)
|
| 184 |
+
|
| 185 |
+
# Project and normalize
|
| 186 |
+
embeddings = self._project_and_normalize(hidden_states)
|
| 187 |
+
embeddings = embeddings.squeeze(0) # Remove batch dim
|
| 188 |
+
mx.eval(embeddings)
|
| 189 |
+
|
| 190 |
+
return EmbeddingResult(
|
| 191 |
+
embeddings=embeddings,
|
| 192 |
+
num_tokens=seq_len,
|
| 193 |
+
source_type="text",
|
| 194 |
+
)
|
| 195 |
+
|
| 196 |
+
def embed_image(
|
| 197 |
+
self,
|
| 198 |
+
image: Union[str, Path, Image.Image],
|
| 199 |
+
) -> EmbeddingResult:
|
| 200 |
+
"""
|
| 201 |
+
Embed document image with proper token expansion.
|
| 202 |
+
|
| 203 |
+
Uses Tomoro's ColQwen3Processor to correctly expand <|image_pad|>
|
| 204 |
+
tokens to match the number of vision patches. Only the image token
|
| 205 |
+
embeddings are returned for MaxSim scoring.
|
| 206 |
+
|
| 207 |
+
Args:
|
| 208 |
+
image: Image path or PIL Image object
|
| 209 |
+
|
| 210 |
+
Returns:
|
| 211 |
+
EmbeddingResult with shape [num_patches, 320]
|
| 212 |
+
"""
|
| 213 |
+
self._ensure_loaded()
|
| 214 |
+
|
| 215 |
+
# Load image if path
|
| 216 |
+
if isinstance(image, (str, Path)):
|
| 217 |
+
image = Image.open(image).convert("RGB")
|
| 218 |
+
|
| 219 |
+
# Process with Tomoro processor (properly expands <|image_pad|>)
|
| 220 |
+
inputs = self.tomoro_processor(
|
| 221 |
+
text="", # No text prompt - only image
|
| 222 |
+
images=[image],
|
| 223 |
+
return_tensors="pt",
|
| 224 |
+
)
|
| 225 |
+
|
| 226 |
+
input_ids = inputs["input_ids"]
|
| 227 |
+
pixel_values = inputs["pixel_values"]
|
| 228 |
+
image_grid_thw = inputs["image_grid_thw"]
|
| 229 |
+
|
| 230 |
+
# Create mask for image tokens
|
| 231 |
+
image_mask = (input_ids == IMAGE_PAD_TOKEN).numpy()[0]
|
| 232 |
+
image_positions = np.where(image_mask)[0].tolist()
|
| 233 |
+
|
| 234 |
+
# Get vision embeddings from vision tower
|
| 235 |
+
pixel_values_mx = mx.array(pixel_values.numpy())
|
| 236 |
+
image_grid_thw_mx = mx.array(image_grid_thw.numpy())
|
| 237 |
+
hidden_states_vision, _ = self.model["vision_tower"](pixel_values_mx, image_grid_thw_mx)
|
| 238 |
+
|
| 239 |
+
# Get text embeddings and inject vision embeddings at image positions
|
| 240 |
+
input_ids_mx = mx.array(input_ids.numpy())
|
| 241 |
+
embed_tokens = self.model["language_model"]["model"]["embed_tokens"]
|
| 242 |
+
text_emb_np = np.array(embed_tokens(input_ids_mx)[0])
|
| 243 |
+
vision_np = np.array(hidden_states_vision)
|
| 244 |
+
|
| 245 |
+
for i, pos in enumerate(image_positions):
|
| 246 |
+
if i < vision_np.shape[0]:
|
| 247 |
+
text_emb_np[pos] = vision_np[i]
|
| 248 |
+
|
| 249 |
+
batch_size, seq_len = input_ids_mx.shape
|
| 250 |
+
combined_embeddings = mx.array(text_emb_np).reshape(1, seq_len, -1)
|
| 251 |
+
|
| 252 |
+
# Create position IDs for M-ROPE
|
| 253 |
+
position_ids = mx.arange(seq_len).reshape(1, -1)
|
| 254 |
+
position_ids = mx.broadcast_to(position_ids, (batch_size, seq_len))
|
| 255 |
+
position_ids = mx.broadcast_to(position_ids[None, ...], (3, batch_size, seq_len))
|
| 256 |
+
|
| 257 |
+
# Forward through language model layers
|
| 258 |
+
inner_model = self.model["language_model"]["model"]
|
| 259 |
+
h = combined_embeddings
|
| 260 |
+
for layer in inner_model["layers"]:
|
| 261 |
+
h = layer(h, position_ids=position_ids)
|
| 262 |
+
h = inner_model["norm"](h)
|
| 263 |
+
|
| 264 |
+
# Extract ONLY image token embeddings for MaxSim
|
| 265 |
+
h_np = np.array(h[0])
|
| 266 |
+
image_hidden_states = mx.array(h_np[image_mask])
|
| 267 |
+
|
| 268 |
+
# Project and normalize
|
| 269 |
+
embeddings = self._project_and_normalize(image_hidden_states)
|
| 270 |
+
mx.eval(embeddings)
|
| 271 |
+
|
| 272 |
+
return EmbeddingResult(
|
| 273 |
+
embeddings=embeddings,
|
| 274 |
+
num_tokens=embeddings.shape[0],
|
| 275 |
+
source_type="image",
|
| 276 |
+
)
|
| 277 |
+
|
| 278 |
+
def embed_pdf_page(
|
| 279 |
+
self,
|
| 280 |
+
pdf_path: Union[str, Path],
|
| 281 |
+
page_num: int = 0,
|
| 282 |
+
dpi: int = 150,
|
| 283 |
+
) -> EmbeddingResult:
|
| 284 |
+
"""
|
| 285 |
+
Embed a page from a PDF document.
|
| 286 |
+
|
| 287 |
+
Args:
|
| 288 |
+
pdf_path: Path to PDF file
|
| 289 |
+
page_num: Page number (0-indexed)
|
| 290 |
+
dpi: Resolution for rendering
|
| 291 |
+
|
| 292 |
+
Returns:
|
| 293 |
+
EmbeddingResult with shape [num_patches, 320]
|
| 294 |
+
"""
|
| 295 |
+
try:
|
| 296 |
+
import fitz # PyMuPDF
|
| 297 |
+
except ImportError:
|
| 298 |
+
raise ImportError("PyMuPDF required: pip install pymupdf")
|
| 299 |
+
|
| 300 |
+
doc = fitz.open(pdf_path)
|
| 301 |
+
page = doc.load_page(page_num)
|
| 302 |
+
pix = page.get_pixmap(dpi=dpi)
|
| 303 |
+
image = Image.frombytes("RGB", [pix.width, pix.height], pix.samples)
|
| 304 |
+
doc.close()
|
| 305 |
+
|
| 306 |
+
return self.embed_image(image)
|
| 307 |
+
|
| 308 |
+
def embed_pdf(
|
| 309 |
+
self,
|
| 310 |
+
pdf_path: Union[str, Path],
|
| 311 |
+
dpi: int = 150,
|
| 312 |
+
max_pages: Optional[int] = None,
|
| 313 |
+
) -> List[EmbeddingResult]:
|
| 314 |
+
"""
|
| 315 |
+
Embed all pages from a PDF document.
|
| 316 |
+
|
| 317 |
+
Args:
|
| 318 |
+
pdf_path: Path to PDF file
|
| 319 |
+
dpi: Resolution for rendering
|
| 320 |
+
max_pages: Maximum pages to process (None for all)
|
| 321 |
+
|
| 322 |
+
Returns:
|
| 323 |
+
List of EmbeddingResult, one per page
|
| 324 |
+
"""
|
| 325 |
+
try:
|
| 326 |
+
import fitz
|
| 327 |
+
except ImportError:
|
| 328 |
+
raise ImportError("PyMuPDF required: pip install pymupdf")
|
| 329 |
+
|
| 330 |
+
doc = fitz.open(pdf_path)
|
| 331 |
+
num_pages = min(len(doc), max_pages) if max_pages else len(doc)
|
| 332 |
+
|
| 333 |
+
results = []
|
| 334 |
+
for i in range(num_pages):
|
| 335 |
+
result = self.embed_pdf_page(pdf_path, page_num=i, dpi=dpi)
|
| 336 |
+
results.append(result)
|
| 337 |
+
|
| 338 |
+
doc.close()
|
| 339 |
+
return results
|
| 340 |
+
|
| 341 |
+
@staticmethod
|
| 342 |
+
def maxsim_score(
|
| 343 |
+
query_emb: Union[mx.array, EmbeddingResult],
|
| 344 |
+
doc_emb: Union[mx.array, EmbeddingResult],
|
| 345 |
+
) -> float:
|
| 346 |
+
"""
|
| 347 |
+
Compute MaxSim score between query and document embeddings.
|
| 348 |
+
|
| 349 |
+
MaxSim (Late Interaction): For each query token, find maximum
|
| 350 |
+
similarity across all document tokens, then sum.
|
| 351 |
+
|
| 352 |
+
Args:
|
| 353 |
+
query_emb: Query embeddings [q_len, dim]
|
| 354 |
+
doc_emb: Document embeddings [d_len, dim]
|
| 355 |
+
|
| 356 |
+
Returns:
|
| 357 |
+
Similarity score (higher = more relevant)
|
| 358 |
+
"""
|
| 359 |
+
if isinstance(query_emb, EmbeddingResult):
|
| 360 |
+
query_emb = query_emb.embeddings
|
| 361 |
+
if isinstance(doc_emb, EmbeddingResult):
|
| 362 |
+
doc_emb = doc_emb.embeddings
|
| 363 |
+
|
| 364 |
+
# Compute all pairwise similarities: [q_len, d_len]
|
| 365 |
+
similarities = query_emb @ doc_emb.T
|
| 366 |
+
|
| 367 |
+
# For each query token, take max over document tokens
|
| 368 |
+
max_sims = mx.max(similarities, axis=1)
|
| 369 |
+
|
| 370 |
+
# Sum across query tokens
|
| 371 |
+
score = mx.sum(max_sims)
|
| 372 |
+
mx.eval(score)
|
| 373 |
+
|
| 374 |
+
return float(score)
|
| 375 |
+
|
| 376 |
+
@staticmethod
|
| 377 |
+
def cosine_similarity(
|
| 378 |
+
emb1: Union[mx.array, EmbeddingResult],
|
| 379 |
+
emb2: Union[mx.array, EmbeddingResult],
|
| 380 |
+
) -> float:
|
| 381 |
+
"""
|
| 382 |
+
Compute mean-pooled cosine similarity.
|
| 383 |
+
|
| 384 |
+
Args:
|
| 385 |
+
emb1: First embeddings [n, dim]
|
| 386 |
+
emb2: Second embeddings [m, dim]
|
| 387 |
+
|
| 388 |
+
Returns:
|
| 389 |
+
Cosine similarity in [-1, 1]
|
| 390 |
+
"""
|
| 391 |
+
if isinstance(emb1, EmbeddingResult):
|
| 392 |
+
emb1 = emb1.embeddings
|
| 393 |
+
if isinstance(emb2, EmbeddingResult):
|
| 394 |
+
emb2 = emb2.embeddings
|
| 395 |
+
|
| 396 |
+
# Mean pool
|
| 397 |
+
v1 = mx.mean(emb1, axis=0)
|
| 398 |
+
v2 = mx.mean(emb2, axis=0)
|
| 399 |
+
|
| 400 |
+
# Cosine similarity
|
| 401 |
+
sim = mx.sum(v1 * v2) / (mx.sqrt(mx.sum(v1**2)) * mx.sqrt(mx.sum(v2**2)))
|
| 402 |
+
mx.eval(sim)
|
| 403 |
+
|
| 404 |
+
return float(sim)
|
| 405 |
+
|
| 406 |
+
def rank_documents(
|
| 407 |
+
self,
|
| 408 |
+
query: str,
|
| 409 |
+
documents: List[EmbeddingResult],
|
| 410 |
+
top_k: Optional[int] = None,
|
| 411 |
+
) -> List[Tuple[int, float]]:
|
| 412 |
+
"""
|
| 413 |
+
Rank documents by relevance to query.
|
| 414 |
+
|
| 415 |
+
Args:
|
| 416 |
+
query: Query string
|
| 417 |
+
documents: List of document embeddings
|
| 418 |
+
top_k: Return top K results (None for all)
|
| 419 |
+
|
| 420 |
+
Returns:
|
| 421 |
+
List of (doc_index, score) sorted by descending score
|
| 422 |
+
"""
|
| 423 |
+
query_emb = self.embed_text(query)
|
| 424 |
+
|
| 425 |
+
scores = []
|
| 426 |
+
for i, doc_emb in enumerate(documents):
|
| 427 |
+
score = self.maxsim_score(query_emb, doc_emb)
|
| 428 |
+
scores.append((i, score))
|
| 429 |
+
|
| 430 |
+
# Sort by score descending
|
| 431 |
+
scores.sort(key=lambda x: x[1], reverse=True)
|
| 432 |
+
|
| 433 |
+
if top_k:
|
| 434 |
+
scores = scores[:top_k]
|
| 435 |
+
|
| 436 |
+
return scores
|
| 437 |
+
|
| 438 |
+
def to_numpy(self, emb: Union[mx.array, EmbeddingResult]) -> np.ndarray:
|
| 439 |
+
"""Convert embeddings to numpy array (for storage/indexing)."""
|
| 440 |
+
if isinstance(emb, EmbeddingResult):
|
| 441 |
+
emb = emb.embeddings
|
| 442 |
+
return np.array(emb)
|
| 443 |
+
|
| 444 |
+
|
| 445 |
+
# Convenience functions
|
| 446 |
+
def load_embedder(
|
| 447 |
+
model_path: Optional[str] = None,
|
| 448 |
+
projection_path: Optional[str] = None,
|
| 449 |
+
) -> ColQwen3Embedder:
|
| 450 |
+
"""Load and return a ready-to-use embedder."""
|
| 451 |
+
embedder = ColQwen3Embedder(
|
| 452 |
+
model_path=model_path,
|
| 453 |
+
projection_path=projection_path,
|
| 454 |
+
)
|
| 455 |
+
embedder.load()
|
| 456 |
+
return embedder
|
| 457 |
+
|
| 458 |
+
|
| 459 |
+
if __name__ == "__main__":
|
| 460 |
+
# Quick test
|
| 461 |
+
print("Testing ColQwen3 Embedder...")
|
| 462 |
+
|
| 463 |
+
embedder = load_embedder()
|
| 464 |
+
|
| 465 |
+
# Test text embedding
|
| 466 |
+
text = "dawkowanie meloksykamu dla psa"
|
| 467 |
+
result = embedder.embed_text(text)
|
| 468 |
+
print(f"\nText: '{text}'")
|
| 469 |
+
print(f" Tokens: {result.num_tokens}")
|
| 470 |
+
print(f" Embedding shape: {result.embeddings.shape}")
|
| 471 |
+
|
| 472 |
+
# Test text similarity
|
| 473 |
+
text2 = "metacam dose for dogs"
|
| 474 |
+
result2 = embedder.embed_text(text2)
|
| 475 |
+
sim = embedder.cosine_similarity(result, result2)
|
| 476 |
+
print(f"\nSimilarity to '{text2}': {sim:.4f}")
|
| 477 |
+
|
| 478 |
+
print("\nColQwen3 Embedder test complete!")
|
scripts/mlx_visual_server.py
ADDED
|
@@ -0,0 +1,318 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/usr/bin/env python3
|
| 2 |
+
"""
|
| 3 |
+
MLX Visual Embedding Server - ColQwen3
|
| 4 |
+
|
| 5 |
+
HTTP server wrapper for ColQwen3Embedder providing visual document embeddings.
|
| 6 |
+
Power of Wet Coders edition - custom merged model by LibraxisAI.
|
| 7 |
+
|
| 8 |
+
Uses the production ColQwen3Embedder class from colqwen3_embedder.py
|
| 9 |
+
|
| 10 |
+
Usage:
|
| 11 |
+
cd knowledge/vista-brain
|
| 12 |
+
uv run python scripts/mlx_visual_server.py
|
| 13 |
+
|
| 14 |
+
# Or via Makefile:
|
| 15 |
+
make visual
|
| 16 |
+
|
| 17 |
+
Endpoints:
|
| 18 |
+
POST /v1/visual-embeddings - Generate visual embeddings from images/PDFs
|
| 19 |
+
POST /v1/maxsim - Compute MaxSim score between query and docs
|
| 20 |
+
GET /v1/models - List models
|
| 21 |
+
GET /health - Health check
|
| 22 |
+
|
| 23 |
+
Created by M&K (c)2025 The LibraxisAI Team
|
| 24 |
+
Co-Authored-By: Maciej (void@div0.space) & Klaudiusz (the1st@whoai.am)
|
| 25 |
+
"""
|
| 26 |
+
import base64
|
| 27 |
+
import io
|
| 28 |
+
import json
|
| 29 |
+
import os
|
| 30 |
+
import sys
|
| 31 |
+
import time
|
| 32 |
+
from http.server import BaseHTTPRequestHandler, HTTPServer
|
| 33 |
+
from pathlib import Path
|
| 34 |
+
from typing import List, Union
|
| 35 |
+
|
| 36 |
+
# Add parent directory to path for colqwen3_embedder import
|
| 37 |
+
sys.path.insert(0, str(Path(__file__).parent.parent))
|
| 38 |
+
|
| 39 |
+
from colqwen3_embedder import ColQwen3Embedder, load_embedder
|
| 40 |
+
|
| 41 |
+
# Configuration from environment
|
| 42 |
+
PORT = int(os.environ.get("MLX_VISUAL_PORT", "12347"))
|
| 43 |
+
|
| 44 |
+
# ColBERT embedding dimension (320 for our custom projection)
|
| 45 |
+
EMBED_DIM = 320
|
| 46 |
+
|
| 47 |
+
# Lazy load embedder
|
| 48 |
+
_embedder = None
|
| 49 |
+
|
| 50 |
+
|
| 51 |
+
def get_embedder() -> ColQwen3Embedder:
|
| 52 |
+
"""Lazy load the ColQwen3 embedder."""
|
| 53 |
+
global _embedder
|
| 54 |
+
if _embedder is None:
|
| 55 |
+
print("Loading ColQwen3 Embedder...", file=sys.stderr)
|
| 56 |
+
_embedder = load_embedder()
|
| 57 |
+
print(f"ColQwen3 ready (dim={EMBED_DIM})", file=sys.stderr)
|
| 58 |
+
return _embedder
|
| 59 |
+
|
| 60 |
+
|
| 61 |
+
def decode_image(image_data: Union[str, bytes]):
|
| 62 |
+
"""Decode image from base64 or bytes."""
|
| 63 |
+
from PIL import Image
|
| 64 |
+
|
| 65 |
+
if isinstance(image_data, str):
|
| 66 |
+
# Handle base64 with or without data URL prefix
|
| 67 |
+
if image_data.startswith("data:"):
|
| 68 |
+
# 
|
| 69 |
+
image_data = image_data.split(",", 1)[1]
|
| 70 |
+
image_bytes = base64.b64decode(image_data)
|
| 71 |
+
else:
|
| 72 |
+
image_bytes = image_data
|
| 73 |
+
|
| 74 |
+
return Image.open(io.BytesIO(image_bytes)).convert("RGB")
|
| 75 |
+
|
| 76 |
+
|
| 77 |
+
def embed_images(images: List[Union[str, bytes]]) -> List[dict]:
|
| 78 |
+
"""Generate ColBERT-style embeddings for images."""
|
| 79 |
+
embedder = get_embedder()
|
| 80 |
+
import mlx.core as mx
|
| 81 |
+
|
| 82 |
+
results = []
|
| 83 |
+
for img_data in images:
|
| 84 |
+
try:
|
| 85 |
+
# Decode image
|
| 86 |
+
if isinstance(img_data, str) and (
|
| 87 |
+
img_data.startswith("/") or img_data.startswith(".")
|
| 88 |
+
):
|
| 89 |
+
# It's a file path
|
| 90 |
+
pil_img = img_data
|
| 91 |
+
else:
|
| 92 |
+
# Base64 data
|
| 93 |
+
pil_img = decode_image(img_data)
|
| 94 |
+
|
| 95 |
+
# Embed using ColQwen3Embedder
|
| 96 |
+
result = embedder.embed_image(pil_img)
|
| 97 |
+
|
| 98 |
+
results.append({
|
| 99 |
+
"embedding": embedder.to_numpy(result).tolist(),
|
| 100 |
+
"num_tokens": result.num_tokens,
|
| 101 |
+
"source_type": result.source_type,
|
| 102 |
+
})
|
| 103 |
+
|
| 104 |
+
except Exception as e:
|
| 105 |
+
print(f"Image embed error: {e}", file=sys.stderr)
|
| 106 |
+
results.append({"error": str(e)})
|
| 107 |
+
|
| 108 |
+
# Clear MLX cache
|
| 109 |
+
mx.clear_cache()
|
| 110 |
+
|
| 111 |
+
return results
|
| 112 |
+
|
| 113 |
+
|
| 114 |
+
def embed_pdf(pdf_path: str, max_pages: int = None) -> List[dict]:
|
| 115 |
+
"""Embed all pages from a PDF."""
|
| 116 |
+
embedder = get_embedder()
|
| 117 |
+
import mlx.core as mx
|
| 118 |
+
|
| 119 |
+
results = []
|
| 120 |
+
try:
|
| 121 |
+
page_results = embedder.embed_pdf(pdf_path, max_pages=max_pages)
|
| 122 |
+
for i, result in enumerate(page_results):
|
| 123 |
+
results.append({
|
| 124 |
+
"page": i,
|
| 125 |
+
"embedding": embedder.to_numpy(result).tolist(),
|
| 126 |
+
"num_tokens": result.num_tokens,
|
| 127 |
+
"source_type": result.source_type,
|
| 128 |
+
})
|
| 129 |
+
except Exception as e:
|
| 130 |
+
print(f"PDF embed error: {e}", file=sys.stderr)
|
| 131 |
+
results.append({"error": str(e)})
|
| 132 |
+
|
| 133 |
+
mx.clear_cache()
|
| 134 |
+
return results
|
| 135 |
+
|
| 136 |
+
|
| 137 |
+
def embed_text(text: str) -> dict:
|
| 138 |
+
"""Embed text query."""
|
| 139 |
+
embedder = get_embedder()
|
| 140 |
+
import mlx.core as mx
|
| 141 |
+
|
| 142 |
+
try:
|
| 143 |
+
result = embedder.embed_text(text)
|
| 144 |
+
mx.clear_cache()
|
| 145 |
+
return {
|
| 146 |
+
"embedding": embedder.to_numpy(result).tolist(),
|
| 147 |
+
"num_tokens": result.num_tokens,
|
| 148 |
+
"source_type": result.source_type,
|
| 149 |
+
}
|
| 150 |
+
except Exception as e:
|
| 151 |
+
print(f"Text embed error: {e}", file=sys.stderr)
|
| 152 |
+
return {"error": str(e)}
|
| 153 |
+
|
| 154 |
+
|
| 155 |
+
def compute_maxsim(query_embedding: List, doc_embedding: List) -> float:
|
| 156 |
+
"""Compute MaxSim score between query and document embeddings."""
|
| 157 |
+
import mlx.core as mx
|
| 158 |
+
|
| 159 |
+
query_mx = mx.array(query_embedding)
|
| 160 |
+
doc_mx = mx.array(doc_embedding)
|
| 161 |
+
|
| 162 |
+
# MaxSim: for each query token, max over doc tokens, then sum
|
| 163 |
+
similarities = query_mx @ doc_mx.T
|
| 164 |
+
max_sims = mx.max(similarities, axis=1)
|
| 165 |
+
score = float(mx.sum(max_sims))
|
| 166 |
+
|
| 167 |
+
mx.clear_cache()
|
| 168 |
+
return score
|
| 169 |
+
|
| 170 |
+
|
| 171 |
+
class VisualHandler(BaseHTTPRequestHandler):
|
| 172 |
+
"""HTTP handler for visual embeddings API."""
|
| 173 |
+
|
| 174 |
+
def log_message(self, format, *args):
|
| 175 |
+
"""Log to stderr."""
|
| 176 |
+
print(f"[{time.strftime('%Y-%m-%d %H:%M:%S')}] {args[0]}", file=sys.stderr)
|
| 177 |
+
|
| 178 |
+
def send_json(self, data: dict, status: int = 200):
|
| 179 |
+
"""Send JSON response."""
|
| 180 |
+
body = json.dumps(data).encode("utf-8")
|
| 181 |
+
self.send_response(status)
|
| 182 |
+
self.send_header("Content-Type", "application/json")
|
| 183 |
+
self.send_header("Content-Length", len(body))
|
| 184 |
+
self.end_headers()
|
| 185 |
+
self.wfile.write(body)
|
| 186 |
+
|
| 187 |
+
def do_GET(self):
|
| 188 |
+
"""Handle GET requests."""
|
| 189 |
+
if self.path == "/v1/models" or self.path == "/models":
|
| 190 |
+
self.send_json({
|
| 191 |
+
"object": "list",
|
| 192 |
+
"data": [{
|
| 193 |
+
"id": "colqwen3-8b-wetcoders",
|
| 194 |
+
"object": "model",
|
| 195 |
+
"owned_by": "libraxis-local",
|
| 196 |
+
"type": "visual-embedding",
|
| 197 |
+
"description": "ColQwen3 8B - Power of Wet Coders edition",
|
| 198 |
+
"embedding_dim": EMBED_DIM,
|
| 199 |
+
}]
|
| 200 |
+
})
|
| 201 |
+
elif self.path == "/health":
|
| 202 |
+
self.send_json({
|
| 203 |
+
"status": "healthy",
|
| 204 |
+
"model": "colqwen3-8b-wetcoders",
|
| 205 |
+
"dim": EMBED_DIM,
|
| 206 |
+
"type": "colbert-visual-embedding",
|
| 207 |
+
})
|
| 208 |
+
else:
|
| 209 |
+
self.send_json({"error": "Not found"}, 404)
|
| 210 |
+
|
| 211 |
+
def do_POST(self):
|
| 212 |
+
"""Handle POST requests."""
|
| 213 |
+
content_length = int(self.headers.get("Content-Length", 0))
|
| 214 |
+
body = self.rfile.read(content_length)
|
| 215 |
+
|
| 216 |
+
try:
|
| 217 |
+
data = json.loads(body)
|
| 218 |
+
except json.JSONDecodeError:
|
| 219 |
+
self.send_json({"error": "Invalid JSON"}, 400)
|
| 220 |
+
return
|
| 221 |
+
|
| 222 |
+
if self.path in ["/v1/visual-embeddings", "/visual-embeddings"]:
|
| 223 |
+
self._handle_embeddings(data)
|
| 224 |
+
elif self.path in ["/v1/maxsim", "/maxsim"]:
|
| 225 |
+
self._handle_maxsim(data)
|
| 226 |
+
else:
|
| 227 |
+
self.send_json({"error": "Not found"}, 404)
|
| 228 |
+
|
| 229 |
+
def _handle_embeddings(self, data: dict):
|
| 230 |
+
"""Handle embedding requests."""
|
| 231 |
+
images = data.get("images", [])
|
| 232 |
+
texts = data.get("texts", [])
|
| 233 |
+
pdf_path = data.get("pdf_path")
|
| 234 |
+
max_pages = data.get("max_pages")
|
| 235 |
+
|
| 236 |
+
response = {
|
| 237 |
+
"object": "embedding_response",
|
| 238 |
+
"model": "colqwen3-8b-wetcoders",
|
| 239 |
+
"dim": EMBED_DIM,
|
| 240 |
+
}
|
| 241 |
+
|
| 242 |
+
try:
|
| 243 |
+
if pdf_path:
|
| 244 |
+
# PDF embedding
|
| 245 |
+
response["pdf_embeddings"] = embed_pdf(pdf_path, max_pages)
|
| 246 |
+
elif images:
|
| 247 |
+
# Image embeddings
|
| 248 |
+
response["image_embeddings"] = embed_images(images)
|
| 249 |
+
elif texts:
|
| 250 |
+
# Text embeddings
|
| 251 |
+
response["text_embeddings"] = [embed_text(t) for t in texts]
|
| 252 |
+
else:
|
| 253 |
+
self.send_json({"error": "No images, texts, or pdf_path provided"}, 400)
|
| 254 |
+
return
|
| 255 |
+
|
| 256 |
+
except Exception as e:
|
| 257 |
+
print(f"Embedding error: {e}", file=sys.stderr)
|
| 258 |
+
self.send_json({"error": str(e)}, 500)
|
| 259 |
+
return
|
| 260 |
+
|
| 261 |
+
self.send_json(response)
|
| 262 |
+
|
| 263 |
+
def _handle_maxsim(self, data: dict):
|
| 264 |
+
"""Handle MaxSim scoring requests."""
|
| 265 |
+
query_embedding = data.get("query_embedding")
|
| 266 |
+
doc_embedding = data.get("doc_embedding")
|
| 267 |
+
|
| 268 |
+
if not query_embedding or not doc_embedding:
|
| 269 |
+
self.send_json({"error": "query_embedding and doc_embedding required"}, 400)
|
| 270 |
+
return
|
| 271 |
+
|
| 272 |
+
try:
|
| 273 |
+
score = compute_maxsim(query_embedding, doc_embedding)
|
| 274 |
+
self.send_json({
|
| 275 |
+
"object": "maxsim_score",
|
| 276 |
+
"score": score,
|
| 277 |
+
"model": "colqwen3-8b-wetcoders",
|
| 278 |
+
})
|
| 279 |
+
except Exception as e:
|
| 280 |
+
print(f"MaxSim error: {e}", file=sys.stderr)
|
| 281 |
+
self.send_json({"error": str(e)}, 500)
|
| 282 |
+
|
| 283 |
+
|
| 284 |
+
def main():
|
| 285 |
+
"""Start the visual embedding server."""
|
| 286 |
+
print("", file=sys.stderr)
|
| 287 |
+
print("=" * 60, file=sys.stderr)
|
| 288 |
+
print("MLX Visual Embedding Server - ColQwen3", file=sys.stderr)
|
| 289 |
+
print("Power of Wet Coders Edition", file=sys.stderr)
|
| 290 |
+
print("=" * 60, file=sys.stderr)
|
| 291 |
+
print(f"Port: {PORT}", file=sys.stderr)
|
| 292 |
+
print(f"Embedding dim: {EMBED_DIM} (ColBERT)", file=sys.stderr)
|
| 293 |
+
print("", file=sys.stderr)
|
| 294 |
+
print("Endpoints:", file=sys.stderr)
|
| 295 |
+
print(" POST /v1/visual-embeddings - Generate embeddings", file=sys.stderr)
|
| 296 |
+
print(" body: {images: [base64...]} or {pdf_path: '/path.pdf'}", file=sys.stderr)
|
| 297 |
+
print(" POST /v1/maxsim - Compute MaxSim score", file=sys.stderr)
|
| 298 |
+
print(" body: {query_embedding: [...], doc_embedding: [...]}", file=sys.stderr)
|
| 299 |
+
print(" GET /v1/models - List models", file=sys.stderr)
|
| 300 |
+
print(" GET /health - Health check", file=sys.stderr)
|
| 301 |
+
print("", file=sys.stderr)
|
| 302 |
+
|
| 303 |
+
# Pre-load embedder
|
| 304 |
+
get_embedder()
|
| 305 |
+
|
| 306 |
+
server = HTTPServer(("0.0.0.0", PORT), VisualHandler)
|
| 307 |
+
print(f"Server ready at http://localhost:{PORT}", file=sys.stderr)
|
| 308 |
+
print("=" * 60, file=sys.stderr)
|
| 309 |
+
|
| 310 |
+
try:
|
| 311 |
+
server.serve_forever()
|
| 312 |
+
except KeyboardInterrupt:
|
| 313 |
+
print("\nShutting down...", file=sys.stderr)
|
| 314 |
+
server.shutdown()
|
| 315 |
+
|
| 316 |
+
|
| 317 |
+
if __name__ == "__main__":
|
| 318 |
+
main()
|
special_tokens_map.json
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"additional_special_tokens": [
|
| 3 |
+
"<|im_start|>",
|
| 4 |
+
"<|im_end|>",
|
| 5 |
+
"<|object_ref_start|>",
|
| 6 |
+
"<|object_ref_end|>",
|
| 7 |
+
"<|box_start|>",
|
| 8 |
+
"<|box_end|>",
|
| 9 |
+
"<|quad_start|>",
|
| 10 |
+
"<|quad_end|>",
|
| 11 |
+
"<|vision_start|>",
|
| 12 |
+
"<|vision_end|>",
|
| 13 |
+
"<|vision_pad|>",
|
| 14 |
+
"<|image_pad|>",
|
| 15 |
+
"<|video_pad|>"
|
| 16 |
+
],
|
| 17 |
+
"eos_token": {
|
| 18 |
+
"content": "<|im_end|>",
|
| 19 |
+
"lstrip": false,
|
| 20 |
+
"normalized": false,
|
| 21 |
+
"rstrip": false,
|
| 22 |
+
"single_word": false
|
| 23 |
+
},
|
| 24 |
+
"pad_token": {
|
| 25 |
+
"content": "<|endoftext|>",
|
| 26 |
+
"lstrip": false,
|
| 27 |
+
"normalized": false,
|
| 28 |
+
"rstrip": false,
|
| 29 |
+
"single_word": false
|
| 30 |
+
}
|
| 31 |
+
}
|
tokenizer.json
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
version https://git-lfs.github.com/spec/v1
|
| 2 |
+
oid sha256:aeb13307a71acd8fe81861d94ad54ab689df773318809eed3cbe794b4492dae4
|
| 3 |
+
size 11422654
|
tokenizer_config.json
ADDED
|
@@ -0,0 +1,239 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"add_bos_token": false,
|
| 3 |
+
"add_prefix_space": false,
|
| 4 |
+
"added_tokens_decoder": {
|
| 5 |
+
"151643": {
|
| 6 |
+
"content": "<|endoftext|>",
|
| 7 |
+
"lstrip": false,
|
| 8 |
+
"normalized": false,
|
| 9 |
+
"rstrip": false,
|
| 10 |
+
"single_word": false,
|
| 11 |
+
"special": true
|
| 12 |
+
},
|
| 13 |
+
"151644": {
|
| 14 |
+
"content": "<|im_start|>",
|
| 15 |
+
"lstrip": false,
|
| 16 |
+
"normalized": false,
|
| 17 |
+
"rstrip": false,
|
| 18 |
+
"single_word": false,
|
| 19 |
+
"special": true
|
| 20 |
+
},
|
| 21 |
+
"151645": {
|
| 22 |
+
"content": "<|im_end|>",
|
| 23 |
+
"lstrip": false,
|
| 24 |
+
"normalized": false,
|
| 25 |
+
"rstrip": false,
|
| 26 |
+
"single_word": false,
|
| 27 |
+
"special": true
|
| 28 |
+
},
|
| 29 |
+
"151646": {
|
| 30 |
+
"content": "<|object_ref_start|>",
|
| 31 |
+
"lstrip": false,
|
| 32 |
+
"normalized": false,
|
| 33 |
+
"rstrip": false,
|
| 34 |
+
"single_word": false,
|
| 35 |
+
"special": true
|
| 36 |
+
},
|
| 37 |
+
"151647": {
|
| 38 |
+
"content": "<|object_ref_end|>",
|
| 39 |
+
"lstrip": false,
|
| 40 |
+
"normalized": false,
|
| 41 |
+
"rstrip": false,
|
| 42 |
+
"single_word": false,
|
| 43 |
+
"special": true
|
| 44 |
+
},
|
| 45 |
+
"151648": {
|
| 46 |
+
"content": "<|box_start|>",
|
| 47 |
+
"lstrip": false,
|
| 48 |
+
"normalized": false,
|
| 49 |
+
"rstrip": false,
|
| 50 |
+
"single_word": false,
|
| 51 |
+
"special": true
|
| 52 |
+
},
|
| 53 |
+
"151649": {
|
| 54 |
+
"content": "<|box_end|>",
|
| 55 |
+
"lstrip": false,
|
| 56 |
+
"normalized": false,
|
| 57 |
+
"rstrip": false,
|
| 58 |
+
"single_word": false,
|
| 59 |
+
"special": true
|
| 60 |
+
},
|
| 61 |
+
"151650": {
|
| 62 |
+
"content": "<|quad_start|>",
|
| 63 |
+
"lstrip": false,
|
| 64 |
+
"normalized": false,
|
| 65 |
+
"rstrip": false,
|
| 66 |
+
"single_word": false,
|
| 67 |
+
"special": true
|
| 68 |
+
},
|
| 69 |
+
"151651": {
|
| 70 |
+
"content": "<|quad_end|>",
|
| 71 |
+
"lstrip": false,
|
| 72 |
+
"normalized": false,
|
| 73 |
+
"rstrip": false,
|
| 74 |
+
"single_word": false,
|
| 75 |
+
"special": true
|
| 76 |
+
},
|
| 77 |
+
"151652": {
|
| 78 |
+
"content": "<|vision_start|>",
|
| 79 |
+
"lstrip": false,
|
| 80 |
+
"normalized": false,
|
| 81 |
+
"rstrip": false,
|
| 82 |
+
"single_word": false,
|
| 83 |
+
"special": true
|
| 84 |
+
},
|
| 85 |
+
"151653": {
|
| 86 |
+
"content": "<|vision_end|>",
|
| 87 |
+
"lstrip": false,
|
| 88 |
+
"normalized": false,
|
| 89 |
+
"rstrip": false,
|
| 90 |
+
"single_word": false,
|
| 91 |
+
"special": true
|
| 92 |
+
},
|
| 93 |
+
"151654": {
|
| 94 |
+
"content": "<|vision_pad|>",
|
| 95 |
+
"lstrip": false,
|
| 96 |
+
"normalized": false,
|
| 97 |
+
"rstrip": false,
|
| 98 |
+
"single_word": false,
|
| 99 |
+
"special": true
|
| 100 |
+
},
|
| 101 |
+
"151655": {
|
| 102 |
+
"content": "<|image_pad|>",
|
| 103 |
+
"lstrip": false,
|
| 104 |
+
"normalized": false,
|
| 105 |
+
"rstrip": false,
|
| 106 |
+
"single_word": false,
|
| 107 |
+
"special": true
|
| 108 |
+
},
|
| 109 |
+
"151656": {
|
| 110 |
+
"content": "<|video_pad|>",
|
| 111 |
+
"lstrip": false,
|
| 112 |
+
"normalized": false,
|
| 113 |
+
"rstrip": false,
|
| 114 |
+
"single_word": false,
|
| 115 |
+
"special": true
|
| 116 |
+
},
|
| 117 |
+
"151657": {
|
| 118 |
+
"content": "<tool_call>",
|
| 119 |
+
"lstrip": false,
|
| 120 |
+
"normalized": false,
|
| 121 |
+
"rstrip": false,
|
| 122 |
+
"single_word": false,
|
| 123 |
+
"special": false
|
| 124 |
+
},
|
| 125 |
+
"151658": {
|
| 126 |
+
"content": "</tool_call>",
|
| 127 |
+
"lstrip": false,
|
| 128 |
+
"normalized": false,
|
| 129 |
+
"rstrip": false,
|
| 130 |
+
"single_word": false,
|
| 131 |
+
"special": false
|
| 132 |
+
},
|
| 133 |
+
"151659": {
|
| 134 |
+
"content": "<|fim_prefix|>",
|
| 135 |
+
"lstrip": false,
|
| 136 |
+
"normalized": false,
|
| 137 |
+
"rstrip": false,
|
| 138 |
+
"single_word": false,
|
| 139 |
+
"special": false
|
| 140 |
+
},
|
| 141 |
+
"151660": {
|
| 142 |
+
"content": "<|fim_middle|>",
|
| 143 |
+
"lstrip": false,
|
| 144 |
+
"normalized": false,
|
| 145 |
+
"rstrip": false,
|
| 146 |
+
"single_word": false,
|
| 147 |
+
"special": false
|
| 148 |
+
},
|
| 149 |
+
"151661": {
|
| 150 |
+
"content": "<|fim_suffix|>",
|
| 151 |
+
"lstrip": false,
|
| 152 |
+
"normalized": false,
|
| 153 |
+
"rstrip": false,
|
| 154 |
+
"single_word": false,
|
| 155 |
+
"special": false
|
| 156 |
+
},
|
| 157 |
+
"151662": {
|
| 158 |
+
"content": "<|fim_pad|>",
|
| 159 |
+
"lstrip": false,
|
| 160 |
+
"normalized": false,
|
| 161 |
+
"rstrip": false,
|
| 162 |
+
"single_word": false,
|
| 163 |
+
"special": false
|
| 164 |
+
},
|
| 165 |
+
"151663": {
|
| 166 |
+
"content": "<|repo_name|>",
|
| 167 |
+
"lstrip": false,
|
| 168 |
+
"normalized": false,
|
| 169 |
+
"rstrip": false,
|
| 170 |
+
"single_word": false,
|
| 171 |
+
"special": false
|
| 172 |
+
},
|
| 173 |
+
"151664": {
|
| 174 |
+
"content": "<|file_sep|>",
|
| 175 |
+
"lstrip": false,
|
| 176 |
+
"normalized": false,
|
| 177 |
+
"rstrip": false,
|
| 178 |
+
"single_word": false,
|
| 179 |
+
"special": false
|
| 180 |
+
},
|
| 181 |
+
"151665": {
|
| 182 |
+
"content": "<tool_response>",
|
| 183 |
+
"lstrip": false,
|
| 184 |
+
"normalized": false,
|
| 185 |
+
"rstrip": false,
|
| 186 |
+
"single_word": false,
|
| 187 |
+
"special": false
|
| 188 |
+
},
|
| 189 |
+
"151666": {
|
| 190 |
+
"content": "</tool_response>",
|
| 191 |
+
"lstrip": false,
|
| 192 |
+
"normalized": false,
|
| 193 |
+
"rstrip": false,
|
| 194 |
+
"single_word": false,
|
| 195 |
+
"special": false
|
| 196 |
+
},
|
| 197 |
+
"151667": {
|
| 198 |
+
"content": "<think>",
|
| 199 |
+
"lstrip": false,
|
| 200 |
+
"normalized": false,
|
| 201 |
+
"rstrip": false,
|
| 202 |
+
"single_word": false,
|
| 203 |
+
"special": false
|
| 204 |
+
},
|
| 205 |
+
"151668": {
|
| 206 |
+
"content": "</think>",
|
| 207 |
+
"lstrip": false,
|
| 208 |
+
"normalized": false,
|
| 209 |
+
"rstrip": false,
|
| 210 |
+
"single_word": false,
|
| 211 |
+
"special": false
|
| 212 |
+
}
|
| 213 |
+
},
|
| 214 |
+
"additional_special_tokens": [
|
| 215 |
+
"<|im_start|>",
|
| 216 |
+
"<|im_end|>",
|
| 217 |
+
"<|object_ref_start|>",
|
| 218 |
+
"<|object_ref_end|>",
|
| 219 |
+
"<|box_start|>",
|
| 220 |
+
"<|box_end|>",
|
| 221 |
+
"<|quad_start|>",
|
| 222 |
+
"<|quad_end|>",
|
| 223 |
+
"<|vision_start|>",
|
| 224 |
+
"<|vision_end|>",
|
| 225 |
+
"<|vision_pad|>",
|
| 226 |
+
"<|image_pad|>",
|
| 227 |
+
"<|video_pad|>"
|
| 228 |
+
],
|
| 229 |
+
"bos_token": null,
|
| 230 |
+
"clean_up_tokenization_spaces": false,
|
| 231 |
+
"eos_token": "<|im_end|>",
|
| 232 |
+
"errors": "replace",
|
| 233 |
+
"extra_special_tokens": {},
|
| 234 |
+
"model_max_length": 262144,
|
| 235 |
+
"pad_token": "<|endoftext|>",
|
| 236 |
+
"split_special_tokens": false,
|
| 237 |
+
"tokenizer_class": "Qwen2Tokenizer",
|
| 238 |
+
"unk_token": null
|
| 239 |
+
}
|
video_preprocessor_config.json
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"crop_size": null,
|
| 3 |
+
"data_format": "channels_first",
|
| 4 |
+
"default_to_square": true,
|
| 5 |
+
"device": null,
|
| 6 |
+
"do_center_crop": null,
|
| 7 |
+
"do_convert_rgb": true,
|
| 8 |
+
"do_normalize": true,
|
| 9 |
+
"do_rescale": true,
|
| 10 |
+
"do_resize": true,
|
| 11 |
+
"do_sample_frames": true,
|
| 12 |
+
"fps": 2,
|
| 13 |
+
"image_mean": [
|
| 14 |
+
0.5,
|
| 15 |
+
0.5,
|
| 16 |
+
0.5
|
| 17 |
+
],
|
| 18 |
+
"image_processor_type": "Qwen2VLImageProcessorFast",
|
| 19 |
+
"image_std": [
|
| 20 |
+
0.5,
|
| 21 |
+
0.5,
|
| 22 |
+
0.5
|
| 23 |
+
],
|
| 24 |
+
"input_data_format": null,
|
| 25 |
+
"max_frames": 768,
|
| 26 |
+
"merge_size": 2,
|
| 27 |
+
"min_frames": 4,
|
| 28 |
+
"num_frames": null,
|
| 29 |
+
"pad_size": null,
|
| 30 |
+
"patch_size": 16,
|
| 31 |
+
"resample": 3,
|
| 32 |
+
"rescale_factor": 0.00392156862745098,
|
| 33 |
+
"return_metadata": false,
|
| 34 |
+
"size": {
|
| 35 |
+
"longest_edge": 16777216,
|
| 36 |
+
"shortest_edge": 65536
|
| 37 |
+
},
|
| 38 |
+
"temporal_patch_size": 2,
|
| 39 |
+
"video_metadata": null,
|
| 40 |
+
"video_processor_type": "Qwen3VLVideoProcessor"
|
| 41 |
+
}
|
vocab.json
ADDED
|
The diff for this file is too large to render.
See raw diff
|
|
|