Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Yska

Моделирование

15.01.2014, 01:07. Показов 499. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Преподаватель дал написать задачку из статейки, чтоб сверить результаты полученные программой и полученые во время исследование системы обслуживания.

Постановка задачи: В настоящей работе рассматривается одноканальная система обслуживания M/D/1 с временем обслуживания tau > 0, временем пребывания на орбите T = 2*tau, входящим потоком Пуассона заявок с параметром lambda > 0. По правилам обслуживания в системе может быть не более двух заявок. Заявки принимаются в систему только в следующих случаях: 1) система свободна, и поступившая заявка начинает немедленно обслуживаться линией в течении времени tau > 0; 2) в системе находится одна заявка, обслуживаемая линией, при этом поступающая заявка отправляется на орбиту, и после пребывания на орбите длительностью T = 2*tau ей гарантированон немедленно начало обслуживания; 3) в системе находится одна заявка на орбите, и если в момент поступления очередной заявки оставшееся время время пребывания на орбите не меньше tau, то она немедленно принимается к обслуживанию, в противном случае она покидает систему (теряется).
Если в системе находятся две заявки (одна на орбите, а другая на линии обслуживания), то очередная заявка входящего потока также покидает систему (теряется.)

Я написал, но результаты не совпадают.

Вот хочу спросить совета, по поводу правильно ли я реализовал алгоритм? Потому что есть вероятность что формула полученная в статье не верна, а алгоритм как раз таки работает на отлично.

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
#include "stdafx.h"
#include <iostream>
#include <math.h>
#include <time.h>
using namespace std;
 
int main()
{
    int number_of_experiments, countY, countN, summ = 0, summN = 0; // количество опытов, количество обслуженных заявок, количество потеряных заявок
    double  time_to_work, arrival_intensity, tau;// время на работу, интенсивность поступления, тау(время обслуживания)
    double release_time_line, time_of_admission, orbit_time, orbit_for_while; // время освобождения линии, время поступления, орбитное время, орбитное для цикла while
    cout << "Plese enter the number of experiments: " << endl;
    cin >> number_of_experiments;
    cout << "Please enter time to work: " << endl;
    cin >> time_to_work;
    cout << "Please enter arrival intensity :" << endl;
    cin >> arrival_intensity;
    cout << "Please enter tau(service time): " << endl;
    cin >> tau;
    srand(time(NULL));
    for (int j = 1; j <= number_of_experiments; j++){
        release_time_line = 0; // время освобождения линии
        time_of_admission = 0; // время поступления
        orbit_time = 0; // орбитное время
        orbit_for_while = 0;
        countY = 0; countN = 0; // количество обслуженных заявок, количество потеряных заявок
        while(time_of_admission < time_to_work) {
            if(orbit_time == 0) {
                if(release_time_line <= time_of_admission) {
                    release_time_line = time_of_admission + tau;
                    countY = countY + 1;
                    time_of_admission = time_of_admission - (1/arrival_intensity)*log(0.0001 * ((rand() % 10000)+1));
                } else {
                    orbit_time = time_of_admission + 2*tau;
                    time_of_admission = time_of_admission - (1/arrival_intensity)*log(0.0001 * ((rand() % 10000)+1));
                }
            } else {
                if(release_time_line <= time_of_admission) {
                    if((orbit_time - time_of_admission) >= tau) {
                        release_time_line = time_of_admission + tau;
                        countY = countY + 1;
                        time_of_admission = time_of_admission - (1/arrival_intensity)*log(0.0001 * ((rand() % 10000)+1));
                    } else {
                        release_time_line = orbit_time + tau;
                        countY = countY + 1;
                        orbit_for_while = orbit_time;
                        orbit_time = 0;
                        while(orbit_for_while > time_of_admission) {
                            countN = countN + 1;
                            time_of_admission = time_of_admission - (1/arrival_intensity)*log(0.0001 * ((rand() % 10000)+1));
                        }
                    }
                } else {
                    countN = countN + 1;
                    time_of_admission = time_of_admission - (1/arrival_intensity)*log(0.0001 * ((rand() % 10000)+1));
                }
            }
        }
        summN = summN + countN;
        summ = summ + countY + countN;
    }
    cout << "result program: " << double(summN)/summ << endl;
    cout << "result formula: " << (2*tau*arrival_intensity*exp(arrival_intensity*tau)+exp(arrival_intensity*tau)+0.5*exp(arrival_intensity*tau)-0.5*exp(-(arrival_intensity*tau))-1-2*arrival_intensity*tau)/(3*exp(arrival_intensity*tau)+2*arrival_intensity*tau*exp(arrival_intensity*tau)-2-2*arrival_intensity*tau) << endl;
    system("pause");
    return 0;
}
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.01.2014, 01:07
Ответы с готовыми решениями:

Моделирование COM
Здорова! Нужно написать модель COM, простой пример, создать класс, и интерфейсы. Просто чтобы разобраться как что работает. Вообще COM...

Моделирование
Доброе время суток) Помогите смоделировать программу на Си Суть такова: Робот без участия человека ищет выход из лабиринта;...

Моделирование калькулятора
Помогите с программой. Приложение принимает от пользователя строку с арифметическим выражением (перегрузка операции &lt;&lt;), содержащим...

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

Моделирование СМО
#include&lt;stdio.h&gt; // Функции потокового ввода - вывода #include&lt;conio.h&gt; // Формирование экракна ...

Нейрокомпьютерное моделирование
Доброго времени суток задали задание по нейрокомпьютерному моделированию. Тема контрольной работы: «Механизмы усиления и торможения...

Моделирование 3D объектов
Доброго всем дня. Я новичок в программировании ... поэтому если кому то мой вопрос покажется глупым - не глумится ... Озы С++...

мат.моделирование
Ребят, надо создать математическую модель для след задачи: Принимая, что плотность морской воды увеличивается с глубиной h (км), по...

Комп. моделирование
Дана задача: Торпеда, снабженная разгонным двигателем, нацеливается с подводной лодки на стоящий вертикально над ней надводный...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru