Software package for calculation and simulation of queuing systems
Project description
Системы массового обслуживания: Симуляция и численные методы 🔄
Python-библиотека для симуляции и анализа систем массового обслуживания (СМО) и сетей очередей.
📚 Документация
Подробная документация доступна:
- 📖 Полная документация (Русский) — Полное руководство на русском языке с подробными туториалами, примерами и теорией
- 🚀 Быстрый старт — Начните работу за несколько минут
- 📘 Основные концепции — Основы теории массового обслуживания
- 🎮 Руководство по симуляции — Имитационное моделирование
- 🧮 Руководство по расчетам — Численные методы
- 📊 Каталог моделей — Поддерживаемые модели СМО
- 🌐 Сети очередей — Сети СМО
- ⭐ Приоритетные системы — Системы с приоритетами
- 💡 Примеры использования — Практические примеры
🔍 Основные возможности
- Симуляция: Моделирование различных типов систем массового обслуживания и сетей
- Численные методы: Решение стационарных задач теории массового обслуживания
- Метрики производительности: Анализ времени ожидания, времени пребывания, коэффициентов загрузки и многое другое
- Широкая поддержка моделей: FIFO, приоритеты, прогулки, отрицательные заявки, fork-join, сети и многое другое
📦 Установка
pip install most-queue
Или установка из репозитория:
git clone https://github.com/xabarov/most-queue.git
cd most-queue
pip install -e .
Требования: Python >= 3.9
📰 Новости
- Февраль 2026 — Добавлены расчеты по методу Такахаси–Таками для FIFO-моделей H₂/M/c и H₂/H₂/c:
most_queue/theory/fifo/gmc_takahasi.py— H₂/M/cmost_queue/theory/fifo/hkhk_takahasi.py— H₂/H₂/c- Улучшено API:
H2MnCalc.set_sources()иMGnCalc.set_servers()теперь принимаютH2Paramsнапрямую (без повторного фиттинга), аHkHkNCalcкорректно работает с complex-fit для (CV<1).
- 2025 — Для метода расчета многоканальной СМО с разогревом, охлаждением и задержкой начала охлаждения опубликована статья (реализация:
most_queue/theory/vacations/mgn_with_h2_delay_cold_warm.py):- Лохвицкий, В. А. Численный расчет многоканальной системы массового обслуживания с разогревом, охлаждением и задержкой начала охлаждения / В. А. Лохвицкий, Р. С. Хабаров, Е. Л. Яковлев // Авиакосмическое приборостроение. – 2025. – № 1. – С. 44–57. – DOI 10.25791/aviakosmos.1.2025.1456. – EDN OVJXK
🎉 Версия 2.6
Основные изменения:
- Рефакторинг модулей
simиtheory: Улучшена архитектура и структура кода для лучшей поддерживаемости и расширяемости - Полная документация: Добавлена подробная документация на русском языке с руководствами по симуляции, расчетам, моделям и сетям очередей
- Единый API: Унифицированный интерфейс для работы с симуляцией и численными методами
- Улучшенная терминология: Обновлена терминология (СМО с прогулками вместо отпусков)
🚀 Быстрый старт
Базовый пример: M/M/1 система
from most_queue.sim.base import QsSim
# Создание симулятора
qs = QsSim(num_of_channels=1)
# Настройка потока поступления (пуассоновский с интенсивностью λ = 0.5)
qs.set_sources(0.5, "M")
# Настройка обслуживания (экспоненциальное с интенсивностью μ = 1.0)
qs.set_servers(1.0, "M")
# Запуск симуляции
results = qs.run(10000)
# Получение результатов
print(f"Среднее время ожидания: {results.w[0]:.4f}")
print(f"Среднее время пребывания: {results.v[0]:.4f}")
print(f"Коэффициент загрузки: {results.utilization:.4f}")
Численный расчет
from most_queue.theory.fifo.mmnr import MMnrCalc
# Создание калькулятора
calc = MMnrCalc(n=1)
calc.set_sources(l=0.5)
calc.set_servers(mu=1.0)
# Выполнение расчета
results = calc.run()
print(f"Среднее время ожидания: {results.w[0]:.4f}")
См. Руководство по быстрому старту для дополнительных примеров.
📚 Структура проекта
Most-Queue состоит из двух основных модулей:
most_queue.sim— Программы симуляции систем массового обслуживанияmost_queue.theory— Численные методы для расчета моделей теории массового обслуживания
🧪 Поддерживаемые модели
FIFO системы
- M/M/c, M/M/c/r — Многоканальные системы с пуассоновским потоком
- M/G/1, M/G/c — Системы с произвольным распределением времени обслуживания
- GI/M/1, GI/M/c — Системы с общим потоком поступления
- H₂/M/c — Гиперэкспоненциальный поток поступления, метод Такахаси-Таками (§7.6.1)
- M/D/c, E_k/D/c — Системы с детерминированным обслуживанием
- M/H₂/c — Метод Такахаси-Таками с гиперэкспоненциальным обслуживанием
- H₂/H₂/c — Метод Такахаси-Таками для гиперэкспоненциального потока и обслуживания
Примечание про H₂ и (CV<1): реальное H₂-распределение имеет (CV\ge 1), но для численных методов допускается complex-fit (комплексные параметры аппроксимации). Симулятор QsSim не генерирует H₂ с комплексными параметрами, поэтому сравнение “теория vs симуляция” возможно только когда параметры вещественные.
Системы с приоритетами
- M/G/1/PR, M/G/1/NP — Одноканальные с прерываемым/непрерываемым приоритетом
- M/G/c/PR, M/G/c/NP — Многоканальные с приоритетами
- M/Ph/c/PR — Фазовое распределение обслуживания с приоритетами
Специализированные системы
- Прогулки — Системы с прогулками серверов и прогревом
- Отрицательные заявки — Модели RCS и disaster
- Fork-Join — Системы параллельной обработки
- Пакетное поступление — Системы M^x/M/1
- Нетерпеливые заявки — Системы с уходом клиентов
- Engset — Закрытые системы с конечным числом источников
- Сети — Открытые и закрытые сети очередей
См. Каталог моделей для полного списка и деталей.
📌 Области применения
- Облачные вычисления: Моделирование масштабируемости и производительности инфраструктуры
- Call-центры: Оптимизация штата и времени ожидания клиентов
- Транспорт: Улучшение транспортных потоков и логистики
- Сетевой трафик: Анализ и прогнозирование потоков данных
- Производство: Оптимизация производственных линий
- Здравоохранение: Планирование ресурсов больниц
См. Примеры использования для практических кейсов.
📖 Most-Queue 2.0 API
Единый API для симуляции и расчета:
# Численный расчет
calc = MGnCalc(n=NUM_OF_CHANNELS)
calc.set_sources(l=ARRIVAL_RATE)
calc.set_servers(b=b)
calc_results = calc.run()
# Симуляция
qs = QsSim(NUM_OF_CHANNELS)
qs.set_sources(ARRIVAL_RATE, "M")
qs.set_servers(gamma_params, "Gamma")
sim_results = qs.run(NUM_OF_JOBS)
📁 Ресурсы
- Тесты — Примеры с сравнением теоретических и симуляционных результатов
- Туториалы — Jupyter-ноутбуки с пошаговыми руководствами
- Документация — Подробная документация на русском языке
🔍 Ключевые слова для поиска
- Теория массового обслуживания
- Симуляция
- Численные методы
- Сети очередей
- Анализ производительности
- Облачные вычисления
- Оптимизация call-центров
- Транспортные системы
- Сетевой трафик
- Python-пакет
👥 Участие в разработке
Мы приветствуем ваш вклад!
- Откройте issue для сообщений об ошибках или предложений
- Отправьте pull request для улучшений функциональности
- Контакты: xabarov1985@gmail.com
📄 Лицензия
См. файл LICENSE для деталей.
Для подробной документации, примеров и туториалов см. docs/README.md
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file most_queue-2.7.tar.gz.
File metadata
- Download URL: most_queue-2.7.tar.gz
- Upload date:
- Size: 5.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d104288f49a2da3010c57bfe5e7713fe0b8d00398e0fe86191ba81b099d6e9b
|
|
| MD5 |
754307bd7c42cd27684308ac8dfd048b
|
|
| BLAKE2b-256 |
d578645d5ca7c9ed50d2a8bbb9cfc499367a587c466edc9e7687d12ea2396c07
|
File details
Details for the file most_queue-2.7-py3-none-any.whl.
File metadata
- Download URL: most_queue-2.7-py3-none-any.whl
- Upload date:
- Size: 217.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
77648be8eeb1cbbaa66ff4ae55ede57fde0416c19ec4982ba76730a99f484bfb
|
|
| MD5 |
4896bc0d3df05c26c23d8c7495833769
|
|
| BLAKE2b-256 |
e4a3a330b54209678b7c1e590ebc136ee7a29775bef105765cf0c696ba0de204
|