Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 10.04.2021
Сообщений: 75
1

Моделирование многоканальных СМО методом последовательной проводки заявок

19.11.2022, 16:38. Показов 535. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задание:
Тип СМО - 2 канала
Выбор заявок из очереди - в порядке поступления
Выбор канала - Мин.время освобождения
Интервал поступления - равномерный закон распределения с мат.ожиданием = 5мин и сигмой=0.5
Время ожидания - бесконечно
Время обслуживания - нормальный закон распределения с мат.ожиданием = 10мин и сигмой=2

Посчитать Среднее время ожидания и среднее время простоя канала.



Задание нетяжелое, но я при реализации запуталась и никак не могу распутаться...

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include "stdafx.h" 
#include "conio.h"
#include "locale.h"
#include "stdlib.h"
#include "time.h"
#include "math.h"
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(0,"RUSSIAN");
    srand(time(NULL));
 
    const int N=12;
    int n, i,j,k, m=2, nk; 
    float Mn=5,sigma=0.5, Mn1=10,sigma1=0.5, a,b,a1,b1, fi, min, Sum_og, Sum_pr, x[N],
        Tsv[2]; //время освобождения канала
 
    printf("Количество заявок = ");
    scanf("%d", &n);
    float *t=new float  [n];    //момент прихода очередной заявки
    float *T_n=new float[n];    //момента начала обслуживания заявки
    float *tau=new float[n];    //время через которое приходит заявка
    float *T_obs=new float[n];  //время обслуживания заявки
    float *T_pr=new float[n];    //время простоя первого канала
    //float *T_pr2=new float[n];    //время простоя второго канала
    float *T_og=new float [n];      //время ожидания заявки
    
    //Высчитываем границы (время через которое прийдет след. заявка)
    a=(Mn/N - sqrtf(3)*sigma/N);
    b=(Mn/N + sqrtf(3)*sigma/N);
    printf("Границы прихода след.заявки: [%.2f, %.2f]\n", a, b);
 
    //Высчитываем границы (время сколько она будет обслуживаться)
    a1=(Mn1/N - sqrtf(3)*sigma1/N);
    b1=(Mn1/N + sqrtf(3)*sigma1/N);
    printf("Границы обслуживания: [%.2f, %.2f]\n\n", a1, b1);
    
    Tsv[0]=0; Tsv[1]=0; min=10000; Sum_og=0, Sum_pr=0;
    for(i=0; i<n; i++){ //цикл по заявкам
        fi=0+(float)rand()*(1-0)/RAND_MAX;
        tau[i]=a+(b-a)*fi;//время через которое приходит заявка
        if(i==0) t[i]=0;    //момент прихода первой заявки
        else t[i]=t[i-1]+tau[i];
        
        for(j=0; j<m; j++){ //цикл по каналам
            if(Tsv[j]<min){ //определяем какой из каналов освободился раньше
                min=Tsv[j];
                nk=j;
            }
        }
        printf("%d\n", nk);
        
        //проверяем имеются ли свободные каналы
        if(t[i]<min){//все каналы заняты (момент начала обслуживания равен минимальному моменту освобождения)
            T_pr[i]=0;
            T_og[i]=t[i]-Tsv[i]; //время ожидания заявки
            Sum_og+=T_og[i];
            T_n[i]=min;
        } 
        else { //если есть свободные каналы
            T_og[i]=0;
            T_pr[i]=t[i]-Tsv[i];
            Sum_pr+=T_pr[i];
            T_n[i]=t[i];//(момент начала равен моменту прихода заявки)
        }   
        T_obs[i]=0;
        for(k=0; k<N; k++){
            fi=0+(float)rand()*(1-0)/RAND_MAX;
            x[k]=(a1+(b1-a1)*fi);
            T_obs[i]+=x[k];  //нормальный закон распределения
            
        }
        Tsv[nk]=T_n[i]+T_obs[i];
        //printf("%f  %f\n", Tsv[0], Tsv[1]);
    }
    
    delete []t, delete []tau, delete []T_obs, delete []T_n, delete []T_og, delete []T_pr; //delete []T_pr2;
    getch();
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.11.2022, 16:38
Ответы с готовыми решениями:

Моделирование многоканальных систем
Исследовать характеристики (время ожидания, средняя и максимальная длина очереди) модели Задания 2 при разном числе 2. Задание 2 SYST ...

Работа СМО с экспоненциальным законом поступления заявок
Помогите, пожалуйста, разобраться с кодом. Все понятно, кроме вот этих значений: 0,2/1,5, 0,3/1,6 и т.д. Условие задачи: ...

Ограничение на количество поступающих заявок. Замкнутая СМО
Подскажите пожалуйста как смоделировать замкнутую систему с ограничением кол-ва заявок (10) и использованием двух блоков GENERATE.

2
 Аватар для Kuzia domovenok
4264 / 3323 / 925
Регистрация: 25.03.2012
Сообщений: 12,523
Записей в блоге: 1
19.11.2022, 19:55 2
структуры изучи, наконец!
0
 Аватар для SmallEvil
3791 / 2717 / 765
Регистрация: 29.06.2020
Сообщений: 9,986
19.11.2022, 20:10 3

Не по теме:

Цитата Сообщение от ne_master Посмотреть сообщение
int _tmain
Пусть сначала точку входа в программу изучит.



Добавлено через 1 минуту

Не по теме:

Цитата Сообщение от ne_master Посмотреть сообщение
delete []t, delete []tau, delete []T_obs, delete []T_n, delete []T_og, delete []T_pr; //delete []T_pr2;
Я под столом . :D

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.11.2022, 20:10
Помогаю со студенческими работами здесь

Генератор заявок Пуассона в системе массвого обслуживания (СМО)
Здравствуйте. Столкнулся с проблемой написания алгоритма генератора заявок на основе пуассоновского потока. В исходных данных указано:...

Одноканальная СМО с обслуживанием заявок в случайном порядке с равной вероятностью
Одноканальная СМО с обслуживанием заявок в случайном порядке с равной вероятностью. Почему то значения в отчете TAB2 все по нулям p.s...

Найти вероятность того, что за время t [мин] в СМО поступит более k заявок
В систему массового обслуживания (СМО) поступает в среднем λ заявок . Найти вероятность того, что за время t в СМО поступит более k...

Найти вероятность того, что за время t [мин] в СМО поступит ровно k заявок
В систему массового обслуживания (СМО) поступает в среднем λ заявок . найти вероятность того, что за время t в СМО поступит: а) ровно k...

Система Массового Обслуживания. Сколько заявок выполняется одновременно в СМО с бесконечной очередью? (Одноканальная)
(Как подсказали, будет меньше единицы, подсказал сам тот, кто дал задачу. Это больше на мат. статистику задача. ) Значения, которые я...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Вопросы на собеседовании по Android
mobDevWorks 14.03.2025
По данным статистики, Android занимает более 70% мирового рынка мобильных операционных систем, что делает платформу привлекательной как для начинающих разработчиков, так и для опытных профессионалов. . . .
Лучшие игровые движки для Python
py-thonny 14.03.2025
Python обеспечивает разработчиков игр мощными движками и фреймворками, которые позволяют воплотить практически любую идею — от простой аркады до визуального романа с разветвленным сюжетом. Главное. . .
Бессерверный JavaScript: Разработка масштабируемых API с AWS Lambda
run.dev 14.03.2025
Но что такое бессерверные вычисления на самом деле? По сути, это модель облачных вычислений, где разработчик фокусируется исключительно на создании бизнес-логики, не тратя время на настройку. . .
Безопасность кода в C++26: Менеджеры ресурсов и висячие ссылки
NullReferenced 14.03.2025
C++ всегда был языком, предоставляющим разработчикам большие возможности и гибкость, но вместе с тем требующим ответственности. Одной из самых коварных проблем даже для опытных программистов остаются. . .
smart-agent proper interface settings (2025)
jigi33 14.03.2025
Smart-agent proper interface settings (mart 2025). (see screenshots to look at "Etalon" ARM)
Продвинутые настройки JVM
Javaican 14.03.2025
Стандартные параметры запуска JVM хороши для повседневной разработки, но совершенно недостаточны для высоконагруженных систем. Представьте, что вы запускаете финансовую платформу, обрабатывающую. . .
CI/CD для приложений Java с Azure DevOps и Docker
Mr. Docker 14.03.2025
Разработка современных Java-приложений немыслима без системы непрерывной интеграции и доставки (CI/ CD). Azure DevOps в сочетании с Docker предоставляет мощный инструментарий для создания таких. . .
Разработка на PHP и интернет вещей (IoT)
Jason-Webb 14.03.2025
Интернет вещей (IoT) произвел настоящую революцию в способах взаимодействия устройств с окружающим миром. В эпоху, когда холодильники сами заказывают молоко, а термостаты учатся вашим привычкам,. . .
Node.js 20: Новые возможности и улучшения производительно­сти
Reangularity 14.03.2025
Что же принёс нам релиз Node. js 20? В первую очередь, это существенные улучшения в производительности. Движок V8 получил серьёзные оптимизации, благодаря чему JavaScript-код выполняется заметно. . .
Безопасность кластеров Apache Kafka
Javaican 14.03.2025
Apache Kafka стал одним из ключевых компонентов современных архитектур, обрабатывающих потоки данных в режиме реального времени. Его используют тысячи компаний от стартапов до технологических. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru