aboutsummaryrefslogtreecommitdiff
path: root/example.cc
diff options
context:
space:
mode:
authorAdrian Kummerlaender2016-05-14 23:36:50 +0200
committerAdrian Kummerlaender2016-05-14 23:36:50 +0200
commitf7d5b04e07a874903969d8c55b78ab727d6a1769 (patch)
treeb3fb5142478af4d9fe87299acf5c0d17f94e1600 /example.cc
parentc7de3b623c77162dd1d06103dafcc216e56229d9 (diff)
downloadvoronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar.gz
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar.bz2
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar.lz
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar.xz
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.tar.zst
voronoi-f7d5b04e07a874903969d8c55b78ab727d6a1769.zip
Implement basic multi threading
Diffstat (limited to 'example.cc')
-rw-r--r--example.cc27
1 files changed, 22 insertions, 5 deletions
diff --git a/example.cc b/example.cc
index c60ee6a..d815e07 100644
--- a/example.cc
+++ b/example.cc
@@ -2,8 +2,9 @@
#include <cmath>
#include <algorithm>
+#include <thread>
-int minkowski_metric(float p, int refX, int refY, int x, int y) {
+int minkowski_metric(double p, int refX, int refY, int x, int y) {
return static_cast<int>(std::nearbyint(
std::pow(
std::pow(std::abs(refX - x), p) + std::pow(std::abs(refY - y), p),
@@ -20,8 +21,12 @@ int euclidean_metric(int refX, int refY, int x, int y) {
return minkowski_metric(2, refX, refY, x, y);
}
-int main(int, char*[]) {
- std::array<imgen::colored_vector, 9> ref{
+void generate_minkowski_voronoi(
+ const double lower,
+ const double upper,
+ const double epsilon
+) {
+ constexpr std::array<imgen::colored_vector, 9> ref{
imgen::colored_vector{ 0, 0, imgen::red() },
imgen::colored_vector{ 240, 200, imgen::green() },
imgen::colored_vector{-100, 230, imgen::blue() },
@@ -33,9 +38,9 @@ int main(int, char*[]) {
imgen::colored_vector{-240, -20, imgen::olive() }
};
- for ( float p = 0.6; p < 2.0; p = p + 0.005 ) {
+ for ( double p = lower; p < upper; p = p + epsilon ) {
imgen::write_ppm(
- "vonoroi_" + std::to_string(p) + ".ppm",
+ "voronoi_" + std::to_string(p) + ".ppm",
512,
512,
[&ref, p](std::ptrdiff_t x, std::ptrdiff_t y) -> imgen::color {
@@ -66,3 +71,15 @@ int main(int, char*[]) {
);
}
}
+
+int main(int, char*[]) {
+ std::thread worker1([](){ generate_minkowski_voronoi(0.8, 1.1, 0.002); });
+ std::thread worker2([](){ generate_minkowski_voronoi(1.102, 1.4, 0.002); });
+ std::thread worker3([](){ generate_minkowski_voronoi(1.402, 1.7, 0.002); });
+ std::thread worker4([](){ generate_minkowski_voronoi(1.702, 2.0, 0.002); });
+
+ worker1.join();
+ worker2.join();
+ worker3.join();
+ worker4.join();
+}