// // bluenoise — create a N×N blue noise kernel // // Copyright © 2016—2017 Sam Hocevar // // This program is free software. It comes without any warranty, to // the extent permitted by applicable law. You can redistribute it // and/or modify it under the terms of the Do What the Fuck You Want // to Public License, Version 2, as published by the WTFPL Task Force. // See http://www.wtfpl.net/ for more details. // #if HAVE_CONFIG_H # include "config.h" #endif #include using namespace lol; int main(int argc, char **argv) { UNUSED(argc, argv); ivec2 const size(64); auto const &kernel = image::BlueNoiseKernel(size, ivec2(8)); image im(size.xy); array2d &data = im.Lock2D(); for (int j = 0; j < size.y; ++j) for (int i = 0; i < size.x; ++i) data[i][j] = vec4(vec3(kernel[i][j]), 1.0f); im.Unlock2D(data); im.Save("bluenoise.png"); return 0; }