sandbox/Antoonvh/raycaster.c
Adaptive Ray caster
This program sends pixel coordinates to stdout, reads the
correspoding RGB codes from stdin
, and writes a ppm image
to stderr
.
#include "utils.h"
scalar ref[], r[], g[], b[], * rgb = {r, g, b};
void refine_ref (Point point, scalar s) {
foreach_child()
[] = nodata;
s}
int maxlevel = 9;
double tol = 5;
int main(int argc, char ** argv) {
if (argc > 1)
= atoi(argv[1]);
maxlevel if (argc > 2)
= atof(argv[2]);
tol int Ni = 1 << maxlevel;
(1 << (maxlevel - 2));
init_grid .refine = refine_ref;
refforeach()
[] = nodata;
refint count = 1;
while (count > 0) {
= 0;
count foreach(reduction(+:count))
if (ref[] == nodata)
++;
count(&count, 1, sizeof(int), stdout);
fwrite fflush (stdout);
int s = sizeof(double);
if (count > 0) {
foreach_leaf() { //Z-order sequence
if (ref[] == nodata) {
(&x, s, 1, stdout);
fwrite (&y, s, 1, stdout);
fwrite }
}
fflush (stdout);
foreach_leaf() { //Identical Z-order sequence
if (ref[] == nodata) {
for (scalar s in rgb) {
unsigned char c;
(STDIN_FILENO, &c, 1);
read [] = c;
s}
}
[] = 0.;
ref}
boundary (rgb);
int d = min (depth() + 1, maxlevel);
while(adapt_wavelet ({r,g,b}, (double[]){tol, tol, tol}, d, 99).nf);
}
}
fprintf (stderr, "P6\n%d %d\n%d\n", Ni, Ni, 255);
for (int j = 0; j < Ni; j++) {
double yp = L0 - (j + 0.5)*L0/Ni;
for (int i = 0; i < Ni; i++) {
double xp = X0 + (i + 0.5)*L0/Ni;
unsigned char px[3];
= locate (xp, yp); Point point

‘level’ undeclared (first use in this function); did you mean
‘maxlevel’?
if (level == maxlevel) {
[0] = r[];
px[1] = g[];
px[2] = b[];
px} else {

invalid use of undefined type ’struct _interpolate’
[0] = interpolate_linear (point, (struct _interpolate){r, xp, yp}); px

invalid use of undefined type ’struct _interpolate’
[1] = interpolate_linear (point, (struct _interpolate){g, xp, yp}); px

invalid use of undefined type ’struct _interpolate’
[2] = interpolate_linear (point, (struct _interpolate){b, xp, yp});
px}
(px, 1, 3, stderr);
fwrite }
}
fflush (stderr);
}