cpp/main.cpp
2024-11-09 17:59:37 +01:00

43 lines
1014 B
C++

#include <iostream>
#include <unordered_map>
#include <random>
#include "io.h"
#include "sims.h"
#include "motions/base.h"
#include "motions/bimodalangle.h"
#include "motions/isosmallangle.h"
#include "motions/random.h"
#include "motions/tetrahedral.h"
#include "times/delta.h"
#include "times/lognormal.h"
int main (const int argc, char *argv[]) {
Arguments args;
try {
args = parse_args(argc, argv);
} catch (std::runtime_error& error) {
std::cerr << error.what() << std::endl;
return 1;
}
std::unordered_map parameter { read_parameter(args.parameter_file) };
std::random_device rd;
std::mt19937_64 rng(rd());
Motion *motion = Motion::createFromInput(args.motion_type, rng);
auto dist = DeltaDistribution(rng);
// auto dist = LogNormalDistribution(1, 2, rng); // arguments: tau_max, sigma
if (args.spectrum) {
run_spectrum(parameter, *motion, dist);
}
if (args.ste) {
run_ste(parameter, *motion, dist);
}
}