Skip to main content

Software package for calculation and simulation of queuing systems

Project description

Системы массового обслуживания: Симуляция и численные методы 🔄

Queue

Python-библиотека для симуляции и анализа систем массового обслуживания (СМО) и сетей очередей.

PyPI version GitHub commit activity


📚 Документация

Подробная документация доступна:


🔍 Основные возможности

  • Симуляция: Моделирование различных типов систем массового обслуживания и сетей
  • Численные методы: Решение стационарных задач теории массового обслуживания
  • Метрики производительности: Анализ времени ожидания, времени пребывания, коэффициентов загрузки и многое другое
  • Широкая поддержка моделей: 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.pyH₂/M/c
    • most_queue/theory/fifo/hkhk_takahasi.pyH₂/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

most_queue-2.7.tar.gz (5.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

most_queue-2.7-py3-none-any.whl (217.4 kB view details)

Uploaded Python 3

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

Hashes for most_queue-2.7.tar.gz
Algorithm Hash digest
SHA256 1d104288f49a2da3010c57bfe5e7713fe0b8d00398e0fe86191ba81b099d6e9b
MD5 754307bd7c42cd27684308ac8dfd048b
BLAKE2b-256 d578645d5ca7c9ed50d2a8bbb9cfc499367a587c466edc9e7687d12ea2396c07

See more details on using hashes here.

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

Hashes for most_queue-2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 77648be8eeb1cbbaa66ff4ae55ede57fde0416c19ec4982ba76730a99f484bfb
MD5 4896bc0d3df05c26c23d8c7495833769
BLAKE2b-256 e4a3a330b54209678b7c1e590ebc136ee7a29775bef105765cf0c696ba0de204

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page