-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmainwindow.cpp
More file actions
146 lines (131 loc) · 4.97 KB
/
Copy pathmainwindow.cpp
File metadata and controls
146 lines (131 loc) · 4.97 KB
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "manova.h"
#include "anova.h"
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
ui->textBrowser_3->setText("Введите в белое поле данные для исcледования алгоритмом \n"
"Пример: если вам необходимо исследовать на зависимость три группы \n"
"1 группа : 1, 2.5, 3; 2 группа : 4, 5.2; 3 группа : 6, 7, 8.3, 9 \n"
"Необходимо ввести в поле данные в следующем виде: \n"
"((1, 2.5, 3), (4, 5.2), (6, 7, 8.3, 9))");
ui->textBrowser_4->setText("Введите в белое поле данные для исcледования алгоритмом \n"
"Пример: если вам необходимо исследовать на зависимость три группы \n"
"где рассматриваются две случайные величины ν и η \n"
"1 группа по ν: 1, 2.5, 3; 2 группа по ν: 4, 5.2; 3 группа по ν: 6, 7, 8.3, 9 \n"
"1 группа по η: 11.8, 12, 13; 2 группа по η: 14, 15; 3 группа по η: 16, 17, 18, 19 \n"
"Необходимо ввести в поле данные в следующем виде: \n"
"(((1, 11.8), (2.5, 12), (3, 13)), \n((4, 14), (5.2, 15)),\n((6, 16), (7, 17), (8.3, 18), (9, 19)))");
ui->lineEdit->setText("0.05");
ui->lineEdit_2->setText("0.05");
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::on_pushButton_clicked()
{
}
void MainWindow::on_pushButton_2_clicked()
{
ui->textBrowser_2->clear();
alpha = ui->lineEdit->text().toDouble();
s = ui->textEdit->toPlainText().toStdString();
s.erase(remove(s.begin(),s.end(),' '),s.end());//убираем пробелы
//парсинг
std::vector<std::vector<double>> v;
size_t count_open = 0;
std::string tmp = "";
std::vector<double> v_tmp;
for(size_t i = 0; i < s.size(); i++){
if(count_open==0 && s[i]=='('){
count_open++;
}else if(count_open==1 && s[i]=='('){
count_open++;
}
else if(count_open==2 && s[i]!=',' && s[i]!=')'){
tmp+=s[i];
}
else if(count_open==2 && s[i]==','){
v_tmp.push_back(std::stod(tmp));
tmp="";
}
else if(count_open==2 && s[i]==')'){
v_tmp.push_back(std::stod(tmp));
tmp="";
count_open--;
v.push_back(v_tmp);
v_tmp.resize(0);
}
else if(count_open==1 && s[i]==')'){
break;
}
}
//получаем результаты в файлых
ANOVA a(v, alpha);
a.analyse();
//выводим результаты из файлов в окно
std::ifstream anova_res("Anova_res.txt");
while(getline(anova_res, tmp)){
qs += QString::fromStdString(tmp+'\n');
}
ui->textBrowser_2->setText(qs);
qs = "";
s = "";
anova_res.close();
}
void MainWindow::on_pushButton_3_clicked()
{
alpha = ui->lineEdit_2->text().toDouble();
s = ui->textEdit_2->toPlainText().toStdString();
s.erase(remove(s.begin(),s.end(),' '),s.end());//убираем пробелы
//парсинг
std::vector<std::vector<std::vector<double>>> v;
std::vector<std::vector<double>> vv;
size_t count_open = 0;
std::string tmp = "";
std::vector<double> v_tmp;
for(size_t i = 0; i < s.size(); i++){
if(count_open<=2 && s[i]=='('){
count_open++;
}
else if(count_open==3 && s[i]!=',' && s[i]!=')'){
tmp+=s[i];
}
else if(count_open==3 && s[i]==','){
v_tmp.push_back(std::stod(tmp));
tmp="";
}
else if(count_open==3 && s[i]==')'){
v_tmp.push_back(std::stod(tmp));
tmp="";
count_open--;
vv.push_back(v_tmp);
v_tmp.resize(0);
}
else if(count_open==2 && s[i]==')'){
count_open--;
v.push_back(vv);
vv.resize(0);
}
else if(count_open==1 && s[i]==')'){
break;
}
}
//получаем результаты в файлых
MANOVA m(v, alpha);
m.analyse();
//выводим результаты из файлов в окно
std::ifstream manova_res("Manova_res.txt");
while(getline(manova_res, tmp)){
qs += QString::fromStdString(tmp+'\n');
}
ui->textBrowser->clear();
ui->textBrowser->setText(qs);
qs = "";
s = "";
manova_res.close();
}