| <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 1233" width="1200" height="1233" font-size="14"> |
| <style> |
| :root { |
| --bg: #ffffff; --fg: #1b1f24; --muted: #6b7280; --panel: #f6f8fa; --grid: #e5e7eb; |
| --embed: #dbeafe; --embed-s: #3b82f6; |
| --attn: #cffafe; --attn-s: #06b6d4; |
| --mamba: #dcfce7; --mamba-s: #22c55e; |
| --linattn: #fce7f3; --linattn-s: #ec4899; |
| --recur: #ede9fe; --recur-s: #8b5cf6; |
| --moe: #ffedd5; --moe-s: #f97316; |
| --mlp: #ede9fe; --mlp-s: #8b5cf6; |
| --norm: #e5e7eb; --norm-s: #9ca3af; |
| --head: #fee2e2; --head-s: #ef4444; |
| --config: #f1f5f9; --config-s: #64748b; |
| --rope: #fef9c3; --rope-s: #eab308; |
| --layer: #f8fafc; --layer-s: #cbd5e1; |
| --io: #f1f5f9; --io-s: #94a3b8; |
| --soft: #fae8ff; --soft-s: #c026d3; |
| --add: #ffffff; --add-s: #475569; |
| --block-s: #94a3b8; |
| --residual: #f59e0b; |
| --added: #16a34a; --over: #d97706; --deleted: #dc2626; |
| --lt-full: #06b6d4; --lt-sliding: #3b82f6; --lt-chunked: #8b5cf6; |
| --lt-compressed: #f97316; --lt-heavy: #dc2626; --lt-linear: #ec4899; --lt-mamba: #22c55e; |
| --cell-on: #0ea5e9; --cell-off: #e5e7eb; |
| --vision: #dcfce7; --vision-s: #16a34a; --audio: #fae8ff; --audio-s: #c026d3; |
| --proj: #fef3c7; --proj-s: #d97706; --xattn: #db2777; |
| --conv: #d1fae5; --conv-s: #10b981; --act: #ecfccb; --act-s: #65a30d; |
| --pool: #e0f2fe; --pool-s: #0284c7; --quant: #fae8ff; --quant-s: #c026d3; |
| } |
| @media (prefers-color-scheme: dark) { |
| :root { |
| --bg: #0d1117; --fg: #e6edf3; --muted: #8b949e; --panel: #161b22; --grid: #30363d; |
| --embed: #172554; --attn: #083344; --mamba: #052e16; --linattn: #500724; |
| --recur: #2e1065; --moe: #431407; --mlp: #2e1065; --norm: #21262d; --head: #450a0a; |
| --config: #1e293b; --rope: #422006; --layer: #161b22; |
| --conv: #022c22; --act: #1a2e05; --pool: #082f49; --quant: #3b0764; --proj: #422006; |
| --io: #1e293b; --soft: #3b0764; --add: #0d1117; --cell-off: #21262d; |
| } |
| } |
| .bg { fill: var(--bg); } |
| text { font-family: ui-sans-serif, -apple-system, "Segoe UI", Roboto, sans-serif; fill: var(--fg); } |
| .title { font-size: 22px; font-weight: 700; } |
| .subtitle { font-size: 13px; fill: var(--muted); } |
| .box-label { font-size: 14px; font-weight: 600; } |
| .box-label.sm { font-size: 12.5px; } |
| .box-sub { font-size: 11px; fill: var(--muted); } |
| .glyph { font-size: 18px; font-weight: 700; fill: var(--add-s); } |
| .badge { font-size: 12px; font-weight: 700; fill: var(--fg); } |
| .facts-k { font-size: 11.5px; fill: var(--muted); } |
| .facts-v { font-size: 11.5px; font-weight: 600; } |
| .legend-t { font-size: 11.5px; fill: var(--fg); } |
| .panel { fill: var(--panel); stroke: var(--grid); } |
| rect.b { rx: 9; stroke-width: 1.6; } |
| .c-embed { fill: var(--embed); stroke: var(--embed-s); } |
| .c-attn { fill: var(--attn); stroke: var(--attn-s); } |
| .c-mamba { fill: var(--mamba); stroke: var(--mamba-s); } |
| .c-linattn { fill: var(--linattn); stroke: var(--linattn-s); } |
| .c-recur { fill: var(--recur); stroke: var(--recur-s); } |
| .c-moe { fill: var(--moe); stroke: var(--moe-s); } |
| .c-mlp { fill: var(--mlp); stroke: var(--mlp-s); } |
| .c-norm { fill: var(--norm); stroke: var(--norm-s); } |
| .c-head { fill: var(--head); stroke: var(--head-s); } |
| .c-config{ fill: var(--config);stroke: var(--config-s); } |
| .c-rope { fill: var(--rope); stroke: var(--rope-s); } |
| .c-proj { fill: var(--proj); stroke: var(--proj-s); } |
| .c-conv { fill: var(--conv); stroke: var(--conv-s); } |
| .c-act { fill: var(--act); stroke: var(--act-s); } |
| .c-pool { fill: var(--pool); stroke: var(--pool-s); } |
| .c-quant { fill: var(--quant); stroke: var(--quant-s); } |
| .c-layer { fill: var(--layer); stroke: var(--layer-s); } |
| .c-io { fill: var(--io); stroke: var(--io-s); } |
| .c-soft { fill: var(--soft); stroke: var(--soft-s); } |
| .c-add { fill: var(--add); stroke: var(--add-s); } |
| .c-block { fill: none; stroke: var(--block-s); stroke-width: 1.6; stroke-dasharray: 7 5; } |
| .c-lt-full { fill: var(--lt-full); stroke: var(--lt-full); } |
| .c-lt-sliding { fill: var(--lt-sliding); stroke: var(--lt-sliding); } |
| .c-lt-chunked { fill: var(--lt-chunked); stroke: var(--lt-chunked); } |
| .c-lt-compressed { fill: var(--lt-compressed); stroke: var(--lt-compressed); } |
| .c-lt-heavy { fill: var(--lt-heavy); stroke: var(--lt-heavy); } |
| .c-lt-linear { fill: var(--lt-linear); stroke: var(--lt-linear); } |
| .c-lt-mamba { fill: var(--lt-mamba); stroke: var(--lt-mamba); } |
| .cell-on { fill: var(--cell-on); } |
| .cell-off { fill: var(--cell-off); } |
| .grid-frame { fill: none; stroke: var(--grid); stroke-width: 1; } |
| .mask-bg { fill: var(--cell-off); } |
| .mask-on { fill: #22c55e; } |
| .mask-div { stroke: var(--fg); stroke-width: 1.5; stroke-dasharray: 3 2; } |
| .c-vision { fill: var(--vision); stroke: var(--vision-s); } |
| .c-audio { fill: var(--audio); stroke: var(--audio-s); } |
| .c-proj { fill: var(--proj); stroke: var(--proj-s); } |
| .c-sub { fill: var(--bg); stroke: var(--block-s); stroke-width: 1.2; } |
| .sec-h { font-size: 12px; font-weight: 700; } |
| .sec-hbar { fill: var(--bg); opacity: 0.82; } |
| .residual.xattn { stroke: var(--xattn); stroke-width: 2.4; } |
| .ghost { opacity: 0.32; stroke-dasharray: 4 3; } |
| .ch-added rect.b, rect.b.ch-added { stroke: var(--added); stroke-width: 3.2; } |
| .ch-over rect.b, rect.b.ch-over { stroke: var(--over); stroke-width: 3.2; } |
| .ch-deleted rect.b, rect.b.ch-deleted { stroke: var(--deleted); stroke-width: 3.2; } |
| .edge { stroke: var(--grid); stroke-width: 2; } |
| .flow { stroke: var(--grid); stroke-width: 2; fill: none; } |
| .residual { stroke: var(--residual); stroke-width: 2; fill: none; } |
| .rope { stroke: var(--rope-s); stroke-width: 2.2; fill: none; } |
| .xattn { stroke: var(--xattn); stroke-width: 2.4; fill: none; } |
| .cell-idx { font-size: 9px; fill: #ffffff; font-weight: 600; } |
| .sky { fill: #bae6fd; } .sun { fill: #fde047; } .hill { fill: #4ade80; } |
| </style> |
| <defs><marker id="ah-flow" viewBox="0 0 10 10" refX="8" refY="5" markerWidth="7" markerHeight="7" orient="auto-start-reverse"><path d="M0,0 L10,5 L0,10 z" fill="var(--grid)"/></marker><marker id="ah-residual" viewBox="0 0 10 10" refX="8" refY="5" markerWidth="7" markerHeight="7" orient="auto-start-reverse"><path d="M0,0 L10,5 L0,10 z" fill="var(--residual)"/></marker><marker id="ah-rope" viewBox="0 0 10 10" refX="8" refY="5" markerWidth="7" markerHeight="7" orient="auto-start-reverse"><path d="M0,0 L10,5 L0,10 z" fill="var(--rope-s)"/></marker><marker id="ah-xattn" viewBox="0 0 10 10" refX="8" refY="5" markerWidth="7" markerHeight="7" orient="auto-start-reverse"><path d="M0,0 L10,5 L0,10 z" fill="var(--xattn)"/></marker></defs> |
| <rect class="bg" x="0" y="0" width="1200" height="1233"/> |
| <text class="title" x="24" y="34">bitnet</text> |
| <text class="subtitle" x="24" y="54">diff vs llama (+gemma) Β· 8 overridden Β· 0 added Β· 0 deleted Β· 0 new Β· 3 inherited-as-is</text> |
| <line class="edge" x1="485" y1="108" x2="485" y2="1191"/> |
| <g class=""><rect class="c-block" x="286" y="184" width="398" height="873" rx="14"/><text class="box-sub" x="298" y="202">BitNetModel Β· base model</text></g> |
| <g class=""><title>30 Γ BitNetDecoderLayer</title><rect class="c-block" x="294" y="257" width="382" height="760" rx="14"/><text class="box-sub" x="306" y="275">BitNetDecoderLayer</text><text class="badge" x="664" y="277" text-anchor="end">Γ 30</text></g> |
| <g class=""><rect class="c-block" x="286" y="1057" width="398" height="142" rx="14"/><text class="box-sub" x="298" y="1075">BitNetForCausalLM Β· task head</text></g> |
| <g class=""><rect class="b c-attn ch-over" x="320" y="321" width="330" height="370" rx="11"/><rect class="sec-hbar" x="325" y="325" width="320" height="18" rx="5"/><text class="sec-h" x="332" y="338">Self-Attention Β· BitNetAttention</text></g> |
| <g class=""><rect class="b c-mlp ch-over" x="320" y="787" width="330" height="182" rx="11"/><rect class="sec-hbar" x="325" y="791" width="320" height="18" rx="5"/><text class="sec-h" x="332" y="804">MLP Β· BitNetMLP</text></g> |
| <polyline class="rope" points="284,365 320,365" marker-end="url(#ah-rope)"/> |
| <polyline class="residual" points="320,279 286,279 286,718 320,718" stroke-dasharray="6 4" marker-end="url(#ah-residual)"/> |
| <polyline class="residual" points="320,718 270,718 270,996 320,996" stroke-dasharray="6 4" marker-end="url(#ah-residual)"/> |
| <g class=""><rect class="b c-io" x="320" y="108" width="330" height="32" rx="16"/><text class="box-label sm" x="485.0" y="122.0" text-anchor="middle">input_ids</text><text class="box-sub" x="485.0" y="137.0" text-anchor="middle">tokenize("Hey, how are you?") β [1, 6]</text></g> |
| <g class="ghost"><title>token 0: 'Hey'</title><rect class="b c-sub" x="320" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="345.0" y="165.0" text-anchor="middle">Hey</text><text class="box-sub" x="345.0" y="180.0" text-anchor="middle">0</text></g> |
| <g class="ghost"><title>token 1: ','</title><rect class="b c-sub" x="375" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="400.0" y="165.0" text-anchor="middle">,</text><text class="box-sub" x="400.0" y="180.0" text-anchor="middle">1</text></g> |
| <g class="ghost"><title>token 2: 'β£how'</title><rect class="b c-sub" x="431" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="456.0" y="165.0" text-anchor="middle">β£how</text><text class="box-sub" x="456.0" y="180.0" text-anchor="middle">2</text></g> |
| <g class="ghost"><title>token 3: 'β£are'</title><rect class="b c-sub" x="487" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="512.0" y="165.0" text-anchor="middle">β£are</text><text class="box-sub" x="512.0" y="180.0" text-anchor="middle">3</text></g> |
| <g class="ghost"><title>token 4: 'β£you'</title><rect class="b c-sub" x="543" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="568.0" y="165.0" text-anchor="middle">β£you</text><text class="box-sub" x="568.0" y="180.0" text-anchor="middle">4</text></g> |
| <g class="ghost"><title>token 5: '?'</title><rect class="b c-sub" x="599" y="154" width="50" height="26" rx="9"/><text class="box-label sm" x="624.0" y="165.0" text-anchor="middle">?</text><text class="box-sub" x="624.0" y="180.0" text-anchor="middle">5</text></g> |
| <g class="ghost"><rect class="b c-embed" x="320" y="198" width="330" height="45" rx="9"/><text class="box-label sm" x="485.0" y="218.5" text-anchor="middle">Token Embedding</text><text class="box-sub" x="485.0" y="233.5" text-anchor="middle">weight [128256 Γ 2560] β [1, 6, 2560]</text></g> |
| <g class="ghost"><rect class="b c-norm" x="320" y="279" width="330" height="28" rx="9"/><text class="box-label sm" x="485.0" y="291.0" text-anchor="middle">BitNetRMSNorm</text><text class="box-sub" x="485.0" y="306.0" text-anchor="middle">pre-attention [1, 6, 2560]</text></g> |
| <g class="ghost"><title>q_proj: Linear [2560β2560]</title><rect class="b c-proj" x="330" y="347" width="310" height="22" rx="9"/><text class="box-label sm" x="485.0" y="362.5" text-anchor="middle">q_proj [2560β2560]</text></g> |
| <g class="ghost"><title>k_proj: Linear [2560β640]</title><rect class="b c-proj" x="330" y="377" width="310" height="22" rx="9"/><text class="box-label sm" x="485.0" y="392.5" text-anchor="middle">k_proj [2560β640]</text></g> |
| <g class="ghost"><title>v_proj: Linear [2560β640]</title><rect class="b c-proj" x="330" y="407" width="310" height="22" rx="9"/><text class="box-label sm" x="485.0" y="422.5" text-anchor="middle">v_proj [2560β640]</text></g> |
| <g class="ghost"><title>o_proj: Linear [2560β2560]</title><rect class="b c-proj" x="330" y="437" width="310" height="22" rx="9"/><text class="box-label sm" x="485.0" y="452.5" text-anchor="middle">o_proj [2560β2560]</text></g> |
| <g class=""><title>attn_sub_norm: BitNetRMSNorm 2560</title><rect class="b c-norm ch-added" x="330" y="467" width="310" height="22" rx="9"/><text class="box-label sm" x="485.0" y="482.5" text-anchor="middle">attn_sub_norm RMSNorm 2560</text><circle cx="342" cy="479" r="5" fill="var(--added)"/></g> |
| <g class="ghost"><rect class="b c-sub" x="330" y="497" width="310" height="30" rx="9"/><text class="box-label sm" x="485.0" y="510.0" text-anchor="middle">scaled dot-product attention</text><text class="box-sub" x="485.0" y="525.0" text-anchor="middle">20 heads Β· head_dim 128 Β· GQA 20:5</text></g> |
| <g class=""><title>causal attention mask (qβ Γ kβ)</title><text class="box-sub" x="415" y="539">causal mask</text><rect class="mask-bg" x="415" y="545" width="140.0" height="140.0"/><rect class="mask-on" x="415.0" y="545.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="555.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="555.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="565.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="565.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="565.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="575.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="575.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="575.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="575.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="585.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="585.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="585.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="585.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="585.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="595.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="605.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="615.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="625.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="505.0" y="635.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="505.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="515.0" y="645.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="505.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="515.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="525.0" y="655.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="505.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="515.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="525.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="535.0" y="665.0" width="10.0" height="10.0"/><rect class="mask-on" x="415.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="425.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="435.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="445.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="455.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="465.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="475.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="485.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="495.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="505.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="515.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="525.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="535.0" y="675.0" width="10.0" height="10.0"/><rect class="mask-on" x="545.0" y="675.0" width="10.0" height="10.0"/><rect class="grid-frame" x="415" y="545" width="140.0" height="140.0"/></g> |
| <g class="ghost"><rect class="b c-rope" x="152" y="347" width="132" height="40" rx="9"/><text class="box-label sm" x="218.0" y="365.0" text-anchor="middle">RoPE</text><text class="box-sub" x="218.0" y="380.0" text-anchor="middle">rotary positions β Q, K</text></g> |
| <g class=""><title>residual add</title><circle class="b c-add " cx="485.0" cy="718" r="13"/><text class="glyph" x="485.0" y="724" text-anchor="middle">+</text></g> |
| <g class="ghost"><rect class="b c-norm" x="320" y="745" width="330" height="28" rx="9"/><text class="box-label sm" x="485.0" y="757.0" text-anchor="middle">BitNetRMSNorm</text><text class="box-sub" x="485.0" y="772.0" text-anchor="middle">pre-FFN [1, 6, 2560]</text></g> |
| <g class="ghost"><title>gate_proj: Linear [2560β6912]</title><rect class="b c-proj" x="332" y="813" width="306" height="22" rx="9"/><text class="box-label sm" x="485.0" y="828.5" text-anchor="middle">gate_proj [2560β6912]</text></g> |
| <g class="ghost"><title>up_proj: Linear [2560β6912]</title><rect class="b c-proj" x="332" y="843" width="306" height="22" rx="9"/><text class="box-label sm" x="485.0" y="858.5" text-anchor="middle">up_proj [2560β6912]</text></g> |
| <g class="ghost"><title>down_proj: Linear [6912β2560]</title><rect class="b c-proj" x="332" y="873" width="306" height="22" rx="9"/><text class="box-label sm" x="485.0" y="888.5" text-anchor="middle">down_proj [6912β2560]</text></g> |
| <g class="ghost"><title>act_fn: ReLUSquaredActivation</title><rect class="b c-act" x="332" y="903" width="306" height="22" rx="9"/><text class="box-label sm" x="485.0" y="918.5" text-anchor="middle">act_fn ReLUSquared</text></g> |
| <g class=""><title>ffn_sub_norm: BitNetRMSNorm 6912</title><rect class="b c-norm ch-added" x="332" y="933" width="306" height="22" rx="9"/><text class="box-label sm" x="485.0" y="948.5" text-anchor="middle">ffn_sub_norm RMSNorm 6912</text><circle cx="344" cy="945" r="5" fill="var(--added)"/></g> |
| <g class=""><title>residual add</title><circle class="b c-add " cx="485.0" cy="996" r="13"/><text class="glyph" x="485.0" y="1002" text-anchor="middle">+</text></g> |
| <g class="ghost"><rect class="b c-norm" x="320" y="1023" width="330" height="28" rx="9"/><text class="box-label sm" x="485.0" y="1035.0" text-anchor="middle">Final RMSNorm</text><text class="box-sub" x="485.0" y="1050.0" text-anchor="middle">[1, 6, 2560]</text></g> |
| <g class=""><title>BitNetForCausalLM</title><rect class="b c-head ch-over" x="320" y="1065" width="330" height="42" rx="9"/><text class="box-label sm" x="485.0" y="1084.0" text-anchor="middle">LM Head</text><text class="box-sub" x="485.0" y="1099.0" text-anchor="middle">Linear [2560β128256]</text><circle cx="332" cy="1077" r="5" fill="var(--over)"/></g> |
| <g class="ghost"><rect class="b c-soft" x="320" y="1121" width="330" height="26" rx="9"/><text class="box-label sm" x="485.0" y="1138.5" text-anchor="middle">Softmax</text></g> |
| <g class=""><rect class="b c-io" x="320" y="1161" width="330" height="30" rx="15"/><text class="box-label sm" x="485.0" y="1174.0" text-anchor="middle">logits</text><text class="box-sub" x="485.0" y="1189.0" text-anchor="middle">[1, 6, 128256]</text></g> |
| <rect class="panel" x="912" y="88" width="264" height="174" rx="8"/> |
| <text class="facts-k" x="926" y="112">model id</text> |
| <text class="facts-v" x="1162" y="112" text-anchor="end">microsoft/bitnet-b1.58-2B-4T</text> |
| <text class="facts-k" x="926" y="134">parent</text> |
| <text class="facts-v" x="1162" y="134" text-anchor="end">llama</text> |
| <text class="facts-k" x="926" y="156">classes</text> |
| <text class="facts-v" x="1162" y="156" text-anchor="end">6</text> |
| <text class="facts-k" x="926" y="178">overridden</text> |
| <text class="facts-v" x="1162" y="178" text-anchor="end">8</text> |
| <text class="facts-k" x="926" y="200">added</text> |
| <text class="facts-v" x="1162" y="200" text-anchor="end">0</text> |
| <text class="facts-k" x="926" y="222">new classes</text> |
| <text class="facts-v" x="1162" y="222" text-anchor="end">0</text> |
| <text class="facts-k" x="926" y="244">inherited as-is</text> |
| <text class="facts-v" x="1162" y="244" text-anchor="end">3</text> |
| <text class="legend-t" x="914" y="282" font-weight="700">legend</text> |
| <rect x="916" y="293" width="16" height="12" rx="2" fill="none" stroke="var(--added)" stroke-width="3"/> |
| <text class="legend-t" x="940" y="303">new submodule (vs parent)</text> |
| <rect x="916" y="311" width="16" height="12" rx="2" fill="none" stroke="var(--over)" stroke-width="3"/> |
| <text class="legend-t" x="940" y="321">changed / redefined</text> |
| <rect x="916" y="329" width="16" height="12" rx="2" fill="none" stroke="var(--deleted)" stroke-width="3"/> |
| <text class="legend-t" x="940" y="339">deleted</text> |
| <rect x="916" y="347" width="16" height="12" rx="2" fill="none" stroke="var(--grid)" stroke-width="3"/> |
| <text class="legend-t" x="940" y="357">inherited / copy-pasted</text> |
| <text class="legend-t" x="914" y="380" font-weight="700">changes by class</text> |
| <circle cx="920" cy="393" r="4" fill="var(--over)"/> |
| <text class="facts-v" x="932" y="396">BitNetAttention</text> |
| <text class="box-sub" x="932" y="409">ovr __init__,forward</text> |
| <circle cx="920" cy="421" r="4" fill="var(--over)"/> |
| <text class="facts-v" x="932" y="424">BitNetForCausalLM</text> |
| <text class="box-sub" x="932" y="437">ovr forward; 3 attr</text> |
| <circle cx="920" cy="449" r="4" fill="var(--over)"/> |
| <text class="facts-v" x="932" y="452">BitNetMLP</text> |
| <text class="box-sub" x="932" y="465">ovr __init__,forward</text> |
| </svg> |