ICD-10 subgroup classifier — group H (Russian)

Multi-label classifier over 3-character ICD-10 subgroups inside chapter H.
Fine-tuned from ai-forever/ruBert-base on Russian clinical text.

Intended use / Назначение

  • EN: Decision-support signal for suggesting candidate ICD-10 subgroups from Russian clinical notes. Not a substitute for clinician judgment; not validated for autonomous diagnosis.
  • RU: Вспомогательный сигнал для предложения кандидатных 3-символьных кодов МКБ-10 по русскому клиническому тексту. Не заменяет врача и не предназначен для автономных клинических решений.

Training data / Обучающие данные

  • Source CSV: datasets/subgroups/group_H.csv
  • SHA-256: 509e8a459004209834aeaf838e026d86557ab5d12dc18b7c3ee02d5f1eabf037
  • Produced by ml/build_subgroup_datasets.ipynb (iterative multi-label stratification by parse_id).
  • Splits: train=236 · val=49 · test=49
  • Labels: 35 (ordered, includes H_OTHER for rare codes collapsed during dataset build).

Metrics (test split)

metric value
macro_f1 0.5052
micro_f1 0.5346
weighted_f1 0.5667
subset_accuracy 0.2245
hit@1 0.8163
hit@3 0.8776
recall@3 0.8622
mrr 0.8623

Full per-label breakdown in metrics.json.

Limitations / Ограничения

  • Russian only; heavy reliance on clinical abbreviations (АД, ТТГ, УЗИ, etc.).
  • Training text had PII redacted (*ДАТА*, *ГОРОД*, ...); model may behave differently on non-redacted input.
  • Small chapters (train rows < 250) were trained with heavy regularization; some labels may have low support.
  • Rare labels without positives in train are kept in the label map (see label_map.json → rare_label_ids) for interface stability but will effectively never fire.

Inference

from transformers import AutoTokenizer, AutoModelForSequenceClassification
import torch

repo = "Dmitry43243242/icd10-ru-subgroup-h"
tok = AutoTokenizer.from_pretrained(repo)
mdl = AutoModelForSequenceClassification.from_pretrained(repo)
mdl.eval()

text = "жалобы пациента..."
inp = tok(text, return_tensors="pt", truncation=True, max_length=512)
with torch.no_grad():
    probs = torch.sigmoid(mdl(**inp).logits)[0]
preds = [mdl.config.id2label[i] for i, p in enumerate(probs.tolist()) if p >= 0.5]
top3 = sorted(
    [(mdl.config.id2label[i], p) for i, p in enumerate(probs.tolist())],
    key=lambda x: -x[1],
)[:3]
print(preds, top3)

Citation / Ссылка

Built as part of the ai-app ICD-10 classification pipeline. Upstream model: ai-forever/ruBert-base (ai-forever).

Downloads last month
55
Safetensors
Model size
0.2B params
Tensor type
F32
·
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Model tree for Dmitry43243242/icd10-ru-subgroup-h

Finetuned
(43)
this model