Архитектура

speech-swift организован как модульный Swift-пакет с общими протоколами, независимыми модулями моделей и единым CLI. Весь инференс выполняется на устройстве через MLX (Metal GPU) или CoreML (Neural Engine).

Граф зависимостей модулей

                    ┌──────────┐
                    │ AudioCLI │  (точка входа)
                    └────┬─────┘
                         │
                  ┌──────┴──────┐
                  │ AudioCLILib │  (команды)
                  └──────┬──────┘
                         │
       ┌─────────┬───────┼───────┬──────────┬──────────────┐
       │         │       │       │          │              │
  ┌────┴───┐ ┌──┴──┐ ┌──┴──┐ ┌─┴────┐ ┌───┴────┐ ┌──────┴───────┐
  │Qwen3ASR│ │Qwen3│ │Cosy │ │Perso-│ │Speech- │ │  Speech-     │
  │Parakeet│ │ TTS │ │Voice│ │naPlex│ │  VAD   │ │Enhancement   │
  └────┬───┘ └──┬──┘ └──┬──┘ └──┬───┘ └───┬───┘ └──────┬───────┘
       │        │       │       │         │             │
       └────────┴───────┼───────┴─────────┘             │
                        │                               │
                 ┌──────┴──────┐                        │
                 │ Qwen3Common │  (общие слои)          │
                 └──────┬──────┘                        │
                        │                               │
                 ┌──────┴──────┐                        │
                 │ AudioCommon │ ◄──────────────────────┘
                 └─────────────┘  (протоколы, аудио I/O)

Бэкенды инференса

БэкендОборудованиеМодели
MLX Metal GPU Qwen3-ASR, Qwen3-TTS, CosyVoice3, Qwen3.5-Chat, PersonaPlex, Omnilingual ASR (300M / 1B / 3B / 7B), Pyannote, Silero VAD, WeSpeaker
CoreML Neural Engine Энкодер Qwen3-ASR (гибрид), Parakeet TDT, потоковый Parakeet EOU, Omnilingual ASR 300M, Kokoro-82M, Qwen3.5-Chat (опционально), диаризация Sortformer, DeepFilterNet3, Silero VAD (опционально), WeSpeaker (опционально)
Accelerate CPU (SIMD) Предобработка аудио (STFT, мел, FFT), обработка сигналов

Формат весов моделей

MLX-модели используют формат safetensors с 4-битной или 8-битной квантизацией (размер группы 64). CoreML-модели используют скомпилированный формат .mlmodelc. Скрипты конвертации в scripts/ конвертируют из чекпоинтов PyTorch.

МодельПараметрыКвантизацияРазмер на диске
Qwen3-ASR 0.6B (MLX)~600M4-bit / 8-bit680 МБ / 1.0 ГБ
Qwen3-ASR 0.6B (CoreML)~186M (энкодер)INT8~180 МБ
Qwen3-ASR 1.7B (MLX)~1.7B4-bit / 8-bit2.1 ГБ / 3.2 ГБ
Parakeet-TDT 0.6B (CoreML)~600MINT8500 МБ
Parakeet-EOU 120M (CoreML)~120MINT8~120 МБ
Omnilingual-ASR-CTC 300M (CoreML)326MINT8312 МБ
Omnilingual-ASR-CTC 300M (MLX)326M4-bit / 8-bit193 МБ / 342 МБ
Omnilingual-ASR-CTC 1B (MLX)1.01B4-bit / 8-bit549 МБ / 1006 МБ
Omnilingual-ASR-CTC 3B (MLX)~3B4-bit / 8-bit1.71 ГБ / 3.16 ГБ
Omnilingual-ASR-CTC 7B (MLX)~7B4-bit / 8-bit3.55 ГБ / 6.63 ГБ
Qwen3-ForcedAligner 0.6B (MLX)~600M4-bit / 8-bit979 МБ / 1.4 ГБ
Qwen3-ForcedAligner 0.6B (CoreML)~600MINT4 / INT8630 МБ / 1.0 ГБ
Qwen3-TTS 0.6B (MLX)~600M4-bit / 8-bit1.7 ГБ / 2.4 ГБ
Qwen3-TTS 1.7B (MLX)~1.7B4-bit / 8-bit3.2 ГБ / 4.8 ГБ
CosyVoice3 0.5B (MLX)~500M4-bit LLM~1.2 ГБ
Kokoro-82M (CoreML)82MINT8 (1 bucket)~89 МБ
Qwen3.5-Chat 0.8B (MLX)~800MINT4418 МБ
Qwen3.5-Chat 0.8B (CoreML)~800MINT8981 МБ
PersonaPlex 7B (MLX)~7B4-bit / 8-bit4.9 ГБ / 9.1 ГБ
Pyannote VAD (MLX)~1.49Mfloat32~5.7 МБ
Silero VAD v5~309Kfloat32~1.2 МБ (MLX и CoreML)
WeSpeaker ResNet34~6.6Mfloat32~25 МБ (MLX и CoreML)
Sortformer (CoreML)float16~50 МБ
DeepFilterNet3 (CoreML)~2.1MFP16~4.2 МБ

Оптимизации производительности

Обработка аудио

Весь аудио I/O использует PCM Float32. Внутренний ресемплинг выполняет конвертацию форматов:

МодельОжидаемая частотаФормат
Qwen3-ASR16 кГцМоно Float32
Qwen3-TTS24 кГц на выходеМоно Float32
CosyVoice324 кГц на выходеМоно Float32
Kokoro-82M24 кГц на выходеМоно Float32
PersonaPlex24 кГц I/OМоно Float32
Pyannote VAD16 кГцМоно Float32
Silero VAD16 кГцМоно Float32
WeSpeaker16 кГцМоно Float32
DeepFilterNet348 кГцМоно Float32

Структура исходников

Sources/
  AudioCommon/            Общие протоколы, аудио I/O, загрузчик HuggingFace,
                          SentencePieceModel (ридер protobuf)
  MLXCommon/              Утилиты MLX: загрузка весов, хелперы QuantizedLinear,
                          хелпер SDPA multi-head attention, metal budget
  Qwen3Common/            Общие компоненты моделей (KV cache, RoPE, квантизация)
  Qwen3ASR/               Qwen3-ASR распознавание речи
  ParakeetASR/            Parakeet TDT распознавание речи (CoreML)
  ParakeetStreamingASR/   Parakeet EOU 120M потоковая диктовка (CoreML)
  OmnilingualASR/         Meta wav2vec2 + CTC, 1 672 языка
                          (CoreML 300M + MLX 300M / 1B / 3B / 7B)
  Qwen3TTS/               Qwen3-TTS синтез речи
  CosyVoiceTTS/           CosyVoice3 синтез речи
  KokoroTTS/              Kokoro-82M синтез речи (CoreML)
  Qwen3Chat/              Qwen3.5-0.8B on-device LLM-чат (MLX + CoreML)
  PersonaPlex/            PersonaPlex речь в речь
  SpeechVAD/              VAD (Silero + Pyannote), диаризация, эмбеддинги спикеров
  SpeechEnhancement/      DeepFilterNet3 подавление шума (CoreML)
  AudioCLILib/            Реализации команд CLI
  AudioCLI/               Точка входа CLI

scripts/              Конвертация моделей (PyTorch → MLX/CoreML), бенчмаркинг
Tests/                Юнит- и интеграционные тесты
Examples/             Демо-приложения (PersonaPlexDemo, SpeechDemo)