Загрузка данных


#include <iostream>
#include <fstream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
#include <algorithm>
#include <windows.h>
using namespace std;

int main() {

    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    setlocale(LC_ALL, "Russian");

    srand(time(0));


    const int ln11 = 12;
    const int ln12 = 7;
    const int ln21 = 16;


    const int lk11 = 12, lk12 = 16, lk13 = 7;
    const int lk21 = 12, lk22 = 11;
    const int lk31 = 13, lk32 = 9;

    const int max_time = 1000;


    int k11[2000] = {0}, k12[2000] = {0}, k13[2000] = {0};
    int k21[2000] = {0}, k22[2000] = {0};
    int k31[2000] = {0}, k32[2000] = {0};


    int n11[2000][ln11] = {0};
    int n12[2000][ln12] = {0};
    int n21[2000][ln21] = {0};


    int INz[2000][3] = {0};
    int OUTz[2000][2] = {0};
    int LOSTz[2000][8] = {0};

    int inz = 0, outz = 0, lostz = 0;


    int time_in_h11[10000] = {0};
    int time_in_h12[10000] = {0};
    int time_in_h21[10000] = {0};


    int ist1 = rand() % 10 + 1;
    int ist2 = rand() % 10 + 1;
    int ist3 = rand() % 10 + 1;

    int t = 1;


    while (t <= max_time) {

        if (k31[t - 1] != k31[t] && k31[t - 1] != 0) {
            outz++;
            OUTz[t][0] = k31[t - 1];
        }
        if (k32[t - 1] != k32[t] && k32[t - 1] != 0) {
            outz++;
            OUTz[t][1] = k32[t - 1];
        }


        if (k21[t - 1] != k21[t] && k21[t - 1] != 0) {
            if (k31[t] == 0) {
                for (int i = t; i < t + lk31; i++) k31[i] = k21[t - 1];
            } else if (k32[t] == 0) {
                for (int i = t; i < t + lk32; i++) k32[i] = k21[t - 1];
            } else {
                lostz++;
                LOSTz[t][0] = k21[t - 1];
            }
        }


        if (k22[t - 1] != k22[t] && k22[t - 1] != 0) {
            if (k31[t] == 0) {
                for (int i = t; i < t + lk31; i++) k31[i] = k22[t - 1];
            } else if (k32[t] == 0) {
                for (int i = t; i < t + lk32; i++) k32[i] = k22[t - 1];
            } else {
                lostz++;
                LOSTz[t][1] = k22[t - 1];
            }
        }


        if (k21[t] == 0 && n21[t][0] != 0) {
            for (int i = t; i < t + lk21; i++) k21[i] = n21[t][0];
            for (int i = 0; i < ln21 - 1; i++) n21[t][i] = n21[t][i + 1];
            n21[t][ln21 - 1] = 0;
        }

        if (k22[t] == 0 && n21[t][0] != 0) {
            for (int i = t; i < t + lk22; i++) k22[i] = n21[t][0];
            for (int i = 0; i < ln21 - 1; i++) n21[t][i] = n21[t][i + 1];
            n21[t][ln21 - 1] = 0;
        }


        if (k11[t - 1] != k11[t] && k11[t - 1] != 0) {
            if (n21[t][ln21 - 1] != 0) {
                k11[t] = k11[t - 1];
            } else {
                for (int i = 0; i < ln21; i++) {
                    if (n21[t][i] == 0) {
                        n21[t][i] = k11[t - 1];
                        break;
                    }
                }
            }
        }


        if (k12[t - 1] != k12[t] && k12[t - 1] != 0) {
            if (n21[t][ln21 - 1] != 0) {
                lostz++;
                LOSTz[t][2] = k12[t - 1];
            } else {
                for (int i = 0; i < ln21; i++) {
                    if (n21[t][i] == 0) {
                        n21[t][i] = k12[t - 1];
                        break;
                    }
                }
            }
        }


        if (k13[t - 1] != k13[t] && k13[t - 1] != 0) {
            if (n21[t][ln21 - 1] != 0) {
                lostz++;
                LOSTz[t][3] = k13[t - 1];
            } else {
                for (int i = 0; i < ln21; i++) {
                    if (n21[t][i] == 0) {
                        n21[t][i] = k13[t - 1];
                        break;
                    }
                }
            }
        }


        if (k11[t] == 0 && n11[t][0] != 0) {
            for (int i = t; i < t + lk11; i++) k11[i] = n11[t][0];
            for (int i = 0; i < ln11 - 1; i++) n11[t][i] = n11[t][i + 1];
            n11[t][ln11 - 1] = 0;
        }


        if (k12[t] == 0 && n12[t][0] != 0) {
            for (int i = t; i < t + lk12; i++) k12[i] = n12[t][0];
            for (int i = 0; i < ln12 - 1; i++) n12[t][i] = n12[t][i + 1];
            n12[t][ln12 - 1] = 0;
        }


        if (k13[t] == 0 && n12[t][0] != 0) {
            for (int i = t; i < t + lk13; i++) k13[i] = n12[t][0];
            for (int i = 0; i < ln12 - 1; i++) n12[t][i] = n12[t][i + 1];
            n12[t][ln12 - 1] = 0;
        }


        if (ist1 == 0) {
            inz++;
            INz[t][0] = inz;
            if (n11[t][ln11 - 1] != 0) {
                lostz++;
                LOSTz[t][4] = INz[t][0];
            } else {
                for (int i = 0; i < ln11; i++) {
                    if (n11[t][i] == 0) {
                        n11[t][i] = INz[t][0];
                        break;
                    }
                }
            }
            ist1 = rand() % 10 + 1;
        }


        if (ist2 == 0) {
            inz++;
            INz[t][1] = inz;
            if (k12[t] != 0) {
                lostz++;
                LOSTz[t][5] = INz[t][1];
            } else {
                for (int i = t; i < t + lk12; i++) k12[i] = INz[t][1];
            }
            ist2 = rand() % 10 + 1;
        }


        if (ist3 == 0) {
            inz++;
            INz[t][2] = inz;
            if (n12[t][ln12 - 1] != 0) {
                lostz++;
                LOSTz[t][6] = INz[t][2];
            } else {
                for (int i = 0; i < ln12; i++) {
                    if (n12[t][i] == 0) {
                        n12[t][i] = INz[t][2];
                        break;
                    }
                }
            }
            ist3 = rand() % 10 + 1;
        }

        int dt = min({ist1, ist2, ist3});
        int t1;

        for (t1 = t + 1; t1 <= t + dt; t1++) {

            for (int i = 0; i < ln11; i++) n11[t1][i] = n11[t][i];
            for (int i = 0; i < ln12; i++) n12[t1][i] = n12[t][i];
            for (int i = 0; i < ln21; i++) n21[t1][i] = n21[t][i];


            ist1--;
            ist2--;
            ist3--;

            if ((k31[t1 - 1] != k31[t1] && k31[t1 - 1] != 0) ||
                (k32[t1 - 1] != k32[t1] && k32[t1 - 1] != 0) ||
                (k21[t1 - 1] != k21[t1] && k21[t1 - 1] != 0) ||
                (k22[t1 - 1] != k22[t1] && k22[t1 - 1] != 0) ||
                (k11[t1 - 1] != k11[t1] && k11[t1 - 1] != 0) ||
                (k12[t1 - 1] != k12[t1] && k12[t1 - 1] != 0) ||
                (k13[t1 - 1] != k13[t1] && k13[t1 - 1] != 0)) {
                break;
            }
        }

        t = t1;


        for (int i = 0; i < ln11; i++) n11[t][i] = n11[t - 1][i];
        for (int i = 0; i < ln12; i++) n12[t][i] = n12[t - 1][i];
        for (int i = 0; i < ln21; i++) n21[t][i] = n21[t - 1][i];
    }


    int idle_time_k11 = 0, idle_time_k12 = 0, idle_time_k13 = 0;
    int idle_time_k21 = 0, idle_time_k22 = 0;
    int idle_time_k31 = 0, idle_time_k32 = 0;
    int idle_count_k11 = 0, idle_count_k12 = 0, idle_count_k13 = 0;
    int idle_count_k21 = 0, idle_count_k22 = 0;
    int idle_count_k31 = 0, idle_count_k32 = 0;

    for (int step = 1; step <= max_time; step++) {
        if (k11[step] == 0) {
            idle_time_k11++;
            if (step == 1 || k11[step - 1] != 0) idle_count_k11++;
        }
        if (k12[step] == 0) {
            idle_time_k12++;
            if (step == 1 || k12[step - 1] != 0) idle_count_k12++;
        }
        if (k13[step] == 0) {
            idle_time_k13++;
            if (step == 1 || k13[step - 1] != 0) idle_count_k13++;
        }
        if (k21[step] == 0) {
            idle_time_k21++;
            if (step == 1 || k21[step - 1] != 0) idle_count_k21++;
        }
        if (k22[step] == 0) {
            idle_time_k22++;
            if (step == 1 || k22[step - 1] != 0) idle_count_k22++;
        }
        if (k31[step] == 0) {
            idle_time_k31++;
            if (step == 1 || k31[step - 1] != 0) idle_count_k31++;
        }
        if (k32[step] == 0) {
            idle_time_k32++;
            if (step == 1 || k32[step - 1] != 0) idle_count_k32++;
        }

        for (int i = 0; i < ln11; i++) {
            if (n11[step][i] != 0) time_in_h11[n11[step][i]]++;
        }
        for (int i = 0; i < ln12; i++) {
            if (n12[step][i] != 0) time_in_h12[n12[step][i]]++;
        }
        for (int i = 0; i < ln21; i++) {
            if (n21[step][i] != 0) time_in_h21[n21[step][i]]++;
        }
    }

    double avg_idle_phase1 = (double)(idle_time_k11 + idle_time_k12 + idle_time_k13) /
                              (idle_count_k11 + idle_count_k12 + idle_count_k13);
    double avg_idle_phase2 = (double)(idle_time_k21 + idle_time_k22) /
                              (idle_count_k21 + idle_count_k22);
    double avg_idle_phase3 = (double)(idle_time_k31 + idle_time_k32) /
                              (idle_count_k31 + idle_count_k32);

    double sum_h11 = 0, sum_h12 = 0, sum_h21 = 0;
    int count_h11 = 0, count_h12 = 0, count_h21 = 0;

    for (int id = 1; id <= inz; id++) {
        if (time_in_h11[id] > 0) {
            sum_h11 += time_in_h11[id];
            count_h11++;
        }
        if (time_in_h12[id] > 0) {
            sum_h12 += time_in_h12[id];
            count_h12++;
        }
        if (time_in_h21[id] > 0) {
            sum_h21 += time_in_h21[id];
            count_h21++;
        }
    }

    double avg_wait_h11 = (count_h11 > 0) ? sum_h11 / count_h11 : 0.0;
    double avg_wait_h12 = (count_h12 > 0) ? sum_h12 / count_h12 : 0.0;
    double avg_wait_h21 = (count_h21 > 0) ? sum_h21 / count_h21 : 0.0;


    cout << "================================================================" << endl;
    cout << "РЕЗУЛЬТАТЫ МОДЕЛИРОВАНИЯ (Асинхронный циклический алгоритм. Вариант 12)" << endl;
    cout << "================================================================" << endl;
    cout << fixed << setprecision(2);
    cout << "1. Всего пришло заявок: " << inz << endl;
    cout << "2. Обработано заявок: " << outz << endl;
    cout << "3. Было утеряно заявок: " << lostz << endl;
    cout << "   (Осталось в системе: " << (inz - outz - lostz) << ")" << endl;
    cout << "4. Среднее время простоя каналов по фазам:" << endl;
    cout << "   - Фаза 1 (К11, К12, К13): " << avg_idle_phase1 << " тактов" << endl;
    cout << "   - Фаза 2 (К21, К22): " << avg_idle_phase2 << " тактов" << endl;
    cout << "   - Фаза 3 (К31, К32): " << avg_idle_phase3 << " тактов" << endl;
    cout << "5. Среднее время простоя заявок в накопителях:" << endl;
    cout << "   - Накопитель Н11: " << avg_wait_h11 << " тактов" << endl;
    cout << "   - Накопитель Н12: " << avg_wait_h12 << " тактов" << endl;
    cout << "   - Накопитель Н21: " << avg_wait_h21 << " тактов" << endl;
    cout << "================================================================" << endl;

    ofstream myfile("async_cyclic.txt");
    myfile << "\xEF\xBB\xBF";

    for (int t_idx = 1; t_idx <= max_time; t_idx++) {

        myfile << INz[t_idx][0] << "\t" << INz[t_idx][1] << "\t" << INz[t_idx][2] << "\t";


        for (int i = 0; i < ln11; i++) myfile << n11[t_idx][i] << ",";
        myfile << "\t";


        myfile << k11[t_idx] << "\t";


        for (int i = 0; i < ln12; i++) myfile << n12[t_idx][i] << ",";
        myfile << "\t";


        myfile << k12[t_idx] << "\t" << k13[t_idx] << "\t";


        for (int i = 0; i < ln21; i++) myfile << n21[t_idx][i] << ",";
        myfile << "\t";


        myfile << k21[t_idx] << "\t" << k22[t_idx] << "\t";


        myfile << k31[t_idx] << "\t" << k32[t_idx] << "\t";


        myfile << OUTz[t_idx][0] << "," << OUTz[t_idx][1] << "\t";


        for (int i = 0; i < 8; i++) {
            myfile << LOSTz[t_idx][i];
            if (i < 7) myfile << ",";
        }

        myfile << endl;
    }
    myfile.close();

    cout << "\nРезультаты сохранены в файл async_cyclic.txt" << endl;
    system("pause");

    return 0;
}