My old project for strange attractors
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

123 lines
2.8 KiB

#include "Logger.hpp"
#include <iostream>
#include <ctime>
#include <valarray>
#include <cstring>
#include "Attractor.hpp"
#include "Canvas.hpp"
#include "Projector.hpp"
#include "canvae/Raw.hpp"
#include "ostream_helpers.h"
#include "defines.hpp"
int verbose;
void showHelpText() {
14 years ago
std::cout <<
"Awesome Attractor, version " __DATE__ "\n"
"Usage: AwesomeAttractor [OPTION]... FILE\n"
"Optons:\n"
" -h, --help Shows this help\n"
" -q quiet mode\n"
" -v verbose mode\n"
" -V loud mode\n"
" -W N Sets width of output image to N\n"
" -H N Sets height of output image to N\n"
" -I N Sets number of iterations to N\n"
<< std::endl;
exit(0);
}
int main(int argc, char* argv[]) {
14 years ago
verbose = 0;
std::string attractorFile = DEFAULT_ATTRACTOR_FILE;
unsigned int iterations = DEFAULT_ITERATIONS;
unsigned int width = DEFAULT_WIDTH;
unsigned int height = DEFAULT_HEIGHT;
if(argc <= 1) {
14 years ago
showHelpText();
}
for(int i = 1; i < argc; ++i) {
if(strcmp(argv[i], "-v") == 0) {
14 years ago
verbose = 1;
} else if(strcmp(argv[i], "-q") == 0) {
14 years ago
verbose = -1;
} else if(strcmp(argv[i], "--help") == 0) {
14 years ago
showHelpText();
14 years ago
} else if(strcmp(argv[i], "-h") == 0) {
showHelpText();
} else if(strcmp(argv[i], "-V") == 0) {
14 years ago
verbose = 3;
14 years ago
} else if(strcmp(argv[i], "-W") == 0) {
14 years ago
width = atoi(argv[++i]);
14 years ago
} else if(strcmp(argv[i], "-H") == 0) {
14 years ago
height = atoi(argv[++i]);
14 years ago
} else if(strcmp(argv[i], "-I") == 0) {
14 years ago
iterations = atoi(argv[++i]);
} else {
attractorFile = argv[i];
}
}
LogInfo("Awesome Attractor, version %s\n", __DATE__);
14 years ago
// initialising stuff
Attractor myAttractor(attractorFile);
14 years ago
/*unsigned int sizes[] = {128, 128, 128};
Canvas* canvas = new Raw(3, sizes);
14 years ago
projection.canvas = canvas;*/
14 years ago
myAttractor.init_range();
14 years ago
//projection.output();
14 years ago
LogInfo("\nRendering\n");
14 years ago
clock_t start, end;
start = clock();
for(unsigned int j = 1; j <= 100; ++j) {
for(unsigned int i = 0; i <= iterations; i++) {
14 years ago
myAttractor.iterate();
myAttractor.plot();
}
if(verbose >= 0) {
std::cout << "\r" << j << "% done" << std::flush;
14 years ago
}
}
end = clock();
14 years ago
double totalIterations = 100.0*iterations;
double totalTime = ((double)(end-start)/(double)(CLOCKS_PER_SEC));
LogInfo("\nTotal clock time: %f\n", totalTime);
LogMoreInfo("Average iterations per second: %f\n\n", totalIterations/totalTime);
14 years ago
// saving output
char filename[50];
time_t t = time(0);
struct tm* lt = localtime(&t);
int r = rand() % 10;
sprintf(filename, "render/attractor_%04d-%02d-%02d_%02d-%02d-%02d-%01d.raw", lt->tm_year + 1900, lt->tm_mon + 1, lt->tm_mday, lt->tm_hour, lt->tm_min, lt->tm_sec, r);
14 years ago
start = clock();
14 years ago
//canvas->output_file(filename);
14 years ago
end = clock();
14 years ago
totalTime = ((double)(end-start)/(double)(CLOCKS_PER_SEC));
14 years ago
LogInfo("Total clock time for writing png: %f\n", totalTime);
14 years ago
return 0;
}