# Changelog All notable changes to this repository. Format loosely follows [Keep a Changelog](https://keepachangelog.com/en/1.1.0/). This repo holds a model card, an Ollama Modelfile, the HF Ollama-bridge `template` / `system` / `params` files, and the bundled Q4_K_M GGUF, so versions track the **tooling and documentation**, not the underlying base model. ## [Unreleased] ### Changed (sibling rename — Thanatos-27B → Thanatos-27B-Heretic) - **README "Related models" row** updated to point at `FoolDev/Thanatos-27B-Heretic` (the dense sibling renamed from `FoolDev/Thanatos-27B` on 2026-05-23 along with a base swap to `llmfan46/Qwen3.6-27B-uncensored-heretic-v2`, an uncensored Heretic-style abliteration of Qwen 3.6 27B). Description now notes the Heretic base, the uncensored property, and the old-path 307 redirect HF serves. ### Added - Root-level `template`, `system`, and `params` files for HF's Ollama bridge. The bridge generates Ollama manifests at request time from these three files (NOT from `Modelfile` — confirmed against https://huggingface.co/docs/hub/en/ollama). Without them, `ollama run hf.co/FoolDev/janus` got an auto-generated manifest with the broken `{{ if .Prompt }} .Prompt }}<|im_end|>` template (Ollama's faulty Go-template conversion of the GGUF's embedded jinja), corrupted stop tokens (`".Prompt }}<|im_end|>"` bleed), and no `.Tools` / `.ToolCalls` blocks — so the published Ollama tag advertised `completion` only and rejected any request with a `tools` array. The three files mirror the `Modelfile`'s `TEMPLATE` / `SYSTEM` / `PARAMETER` directives; both routes wire tool calling correctly. Edit them together when changing one. Verified by re-pulling the fresh tag: `ollama show hf.co/FoolDev/janus` now reports `completion`, `tools`, `thinking` and tool calls round-trip end-to-end through `/api/chat`. ### Changed - README "Tool / function calling" section: split into explicit Ollama-path and embedded-jinja-path subsections. Earlier wording conflated the two on-the-wire formats. The Ollama path (Modelfile `TEMPLATE` and the new `template` bridge file, both kept in sync) prompts JSON-in-XML — the form Ollama's tool-call extractor parses into a structured `tool_calls` array. The embedded-jinja path (llama.cpp, llama-cpp-python, LM Studio) reads the Qwen 3.6 native chat template baked into the GGUF, which prompts the verbose `` / `` form the model was trained on. Both are valid; the model adapts to whichever shape the system prompt prescribes. README now shows both formats side by side. - README "Quick start / Ollama" section: documents both pull paths (`hf.co/...` via bridge files vs `make ... -f Modelfile` locally) and explicitly notes that HF's bridge does not read `Modelfile`. - README "Hardware requirements" intro: re-framed the "~38 GB minimum" claim as "~38 GB at default `num_ctx 16384`" and documented that 32 GB hosts can fit the model by trimming context and batch size. - README "Quick start / Ollama" snippet: show both `ollama run hf.co/FoolDev/janus` and the explicit-tag form `ollama run hf.co/FoolDev/janus:Q4_K_M`. Same blob (the default tag maps to Q4_K_M), but parity with the 27B sibling — which lists both `:latest` and `:Q3_K_S` — and removes ambiguity for users scripting against an explicit quant tag. Verified the explicit tag resolves to the same manifest (model SHA `a076aa0d3a1a`, bridge blobs `22c7ade72045` / `84a1a6ac580b` / `f7b1992cf9c1`). ### Added (cont'd) - README `## TL;DR` section near the top of the model card, mirroring the 27B sibling. Two paths (HF Ollama bridge / local Modelfile build) with explicit tags and a one-line capability check. Notes the bridge ingests `template` / `system` / `params`, not `Modelfile`, so users skimming the top of the page won't form the wrong mental model of which file gets used when. - `CITATION.cff` for citation metadata (Apache-2.0, references the upstream Qwen3.6-35B-A3B base and the dense Janus-27B sibling). The 27B sibling has had this file since 0.5.0; adding here for parity so academic-style citations work across both repos. - `LICENSE` file containing the full Apache 2.0 text. The model card front-matter has always declared `license: apache-2.0` and the upstream Qwen 3.6 license inherits Apache-2.0, but until now the repo lacked the actual license text file. Same Apache 2.0 text shipped in the 27B sibling. - `scripts/check_bridge_sync.py` — regression guard for the `Modelfile` <-> `template` / `system` / `params` sync invariant. The two configurations are consumed by different code paths (`ollama create -f Modelfile` for local builds vs HF's Ollama bridge for `hf.co/...` pulls — HF does not read `Modelfile`), so drift between them re-introduces the bug fixed in commit 70ccef1 where `hf.co/FoolDev/janus` shipped a broken auto-generated template while local builds had the correct one. Script parses the Modelfile's `TEMPLATE` / `SYSTEM` / `PARAMETER` directives, loads the three bridge files, and fails on any mismatch with a per-key diff. Run on demand before pushing edits to either side of the configuration. The 27B sibling wires an equivalent script into a pre-commit hook (commit 5c67b08); this repo stays leaner and runs it manually. ### Fixed - README "Chat template" intro previously claimed all loaders handle the embedded jinja automatically. True for llama.cpp / LM Studio / llama-cpp-python; not true for Ollama, which needs an explicit override (the `Modelfile` TEMPLATE block locally, the root-level `template` file when serving via `hf.co/...`). - README "Tool / function calling" earlier said the XML form `` is "not what this model produces". That was wrong: the embedded GGUF jinja prompts exactly that form, and llama.cpp / LM Studio / llama-cpp-python users will see it. The "JSON-in-XML" claim only applies on the Ollama path because that's what the Modelfile TEMPLATE prompt instructs. ## [0.1.0] — initial public release ### Added - Model card with architecture overview, sampling defaults, hardware table, and `Modelfile` for `ollama create janus -f Modelfile`. - Bundled `Janus-35B-A3B.Q4_K_M.gguf` (~19 GB) via Git LFS so the HF "Use this model" widget surfaces a working `ollama run` snippet. - Tokyo Night themed banner (PNG sourced from the SVG). - Status badges for license, base model, architecture, quant. - Linked sibling `FoolDev/janus-27b` (dense Qwen 3.6 27B base) under Related models.