-
Notifications
You must be signed in to change notification settings - Fork 0
/
Logger.cpp
49 lines (39 loc) · 1.03 KB
/
Logger.cpp
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
#include "Logger.h"
#include <filesystem>
using namespace std;
Logger::Logger(string i)
{
experimental::filesystem::path wey(path + i + extension);
file = new ofstream(wey);
}
Logger::~Logger()
{
file->close();
delete file;
}
void operator<<(Logger& left, Creature right) {
(*(left.file)) << "(" << right.x << ";" << right.y << ")\n";
}
void Logger::store(size_t i, size_t m, vector<Creature> guys) {
string name = to_string(i) + "_" + to_string(m);
double max = -INFINITY;
Creature best_boy;
double sum = 0;
Logger log(name);
for (int j = 0; j < guys.size(); ++j) {
double fit = guys[j].getHonestFit();
sum += fit;
if (max < fit) {
max = fit;
best_boy = guys[j];
}
}
sum /= guys.size();
cout << "Iterration: " << name << "\n";
cout << "Creatures: " << guys.size() << "\n";
for (auto guy : guys) {
cout << guy << "[" << guy.getHonestFit() << "]" << "\n";
log << guy;
}
cout << "\n Max: [" << max << "] at " << best_boy << "\t " << "Middle: " << sum << "\n\n";
}