This repository has been archived on 2019-09-17. You can view files and clone it, but cannot push or open issues or pull requests.
Files
research-project/src/main.cpp

47 lines
1.3 KiB
C++

#include <algorithm>
#include <iostream>
#include <glog/logging.h>
#include "Options.hpp"
#include "Simulator.hpp"
using namespace std;
using namespace fmri;
int main(int argc, char *const argv[]) {
google::InitGoogleLogging(argv[0]);
Options options = Options::parse(argc, argv);
auto labels = options.labels();
auto dumper = options.imageDumper();
Simulator simulator(options.model(), options.weights(), options.means());
for (const auto &image : options.inputs()) {
const auto res = simulator.simulate(image);
LOG(INFO) << "Result for " << image << ":" << endl;
const auto& resultRow = res[res.size() - 1];
if (labels) {
vector<DType> weights(resultRow.data(), resultRow.data() + resultRow.numEntries());
auto scores = combine(weights, *labels);
sort(scores.begin(), scores.end(), greater<>());
for (unsigned int i = 0; i < scores.size() && i < 5; ++i) {
LOG(INFO) << scores[i].first << " " << scores[i].second << endl;
}
} else {
LOG(INFO) << "Best result: " << *(resultRow.data(), resultRow.data() + resultRow.numEntries()) << endl;
}
if (dumper) {
for (const auto& layer : res) {
dumper->dump(layer);
}
}
}
google::ShutdownGoogleLogging();
return 0;
}