clray

changeset 4:3c95d568d3c7

wow a ball
author John Tsiombikas <nuclear@member.fsf.org>
date Thu, 15 Jul 2010 07:37:05 +0300 (2010-07-15)
parents 88ac4eb2d18a
children 9f0ddb701882
files rt.cl src/rt.cc
diffstat 2 files changed, 50 insertions(+), 29 deletions(-) [+]
line diff
     1.1 --- a/rt.cl	Tue Jul 13 03:38:29 2010 +0300
     1.2 +++ b/rt.cl	Thu Jul 15 07:37:05 2010 +0300
     1.3 @@ -7,7 +7,8 @@
     1.4  struct Sphere {
     1.5  	float4 pos;
     1.6  	float radius;
     1.7 -	float4 color;
     1.8 +	float4 kd, ks;
     1.9 +	float spow, kr, kt;
    1.10  };
    1.11  
    1.12  struct Light {
    1.13 @@ -21,34 +22,44 @@
    1.14  struct SurfPoint {
    1.15  	float t;
    1.16  	float3 pos, norm;
    1.17 +	global const struct Sphere *obj;
    1.18  };
    1.19  
    1.20  #define EPSILON 1e-6
    1.21  
    1.22 -bool intersect(struct Ray ray, __global const struct Sphere *sph, struct SurfPoint *sp);
    1.23 +float4 shade(struct Ray ray, struct SurfPoint sp);
    1.24 +bool intersect(struct Ray ray, global const struct Sphere *sph, struct SurfPoint *sp);
    1.25  
    1.26 -__kernel void render(__global float4 *fb,
    1.27 -		__global const struct RendInfo *rinf,
    1.28 -		__global const struct Sphere *sphlist,
    1.29 -		__global const struct Light *lights,
    1.30 -		__global const struct Ray *primrays)
    1.31 +
    1.32 +kernel void render(global float4 *fb,
    1.33 +		global const struct RendInfo *rinf,
    1.34 +		global const struct Sphere *sphlist,
    1.35 +		global const struct Light *lights,
    1.36 +		global const struct Ray *primrays)
    1.37  {
    1.38  	int idx = get_global_id(0);
    1.39  
    1.40  	struct Ray ray = primrays[idx];
    1.41 -	struct SurfPoint sp;
    1.42 +	struct SurfPoint sp, sp0;
    1.43  
    1.44 -	if(intersect(ray, sphlist, &sp)) {
    1.45 -		fb[idx] = (float4)(1, 0, 0, 1);
    1.46 -	} else {
    1.47 -		fb[idx] = (float4)(0, 0, 0, 1);
    1.48 +	sp0.t = FLT_MAX;
    1.49 +
    1.50 +	for(int i=0; i<rinf->num_sph; i++) {
    1.51 +		if(intersect(ray, sphlist, &sp) && sp.t < sp0.t) {
    1.52 +			sp0 = sp;
    1.53 +		}
    1.54  	}
    1.55  
    1.56 -	fb[idx] = primrays[idx].dir * 0.5 + 0.5;
    1.57 +	fb[idx] = shade(ray, sp0);
    1.58 +}
    1.59 +
    1.60 +float4 shade(struct Ray ray, struct SurfPoint sp)
    1.61 +{
    1.62 +	return sp.obj->kd;
    1.63  }
    1.64  
    1.65  bool intersect(struct Ray ray,
    1.66 -		__global const struct Sphere *sph,
    1.67 +		global const struct Sphere *sph,
    1.68  		struct SurfPoint *sp)
    1.69  {
    1.70  	float3 dir = ray.dir.xyz;
     2.1 --- a/src/rt.cc	Tue Jul 13 03:38:29 2010 +0300
     2.2 +++ b/src/rt.cc	Thu Jul 15 07:37:05 2010 +0300
     2.3 @@ -13,7 +13,9 @@
     2.4  	cl_float4 pos;
     2.5  	cl_float radius;
     2.6  
     2.7 -	cl_float4 color;
     2.8 +	cl_float4 kd, ks;
     2.9 +	cl_float spow;
    2.10 +	cl_float kr, kt;
    2.11  } __attribute__((packed));
    2.12  
    2.13  struct Ray {
    2.14 @@ -31,21 +33,27 @@
    2.15  static CLProgram *prog;
    2.16  static int global_size;
    2.17  
    2.18 +static Sphere sphlist[] = {
    2.19 +	{{0, 0, 8, 1}, 1.0, {0.7, 0.2, 0.15, 1}, {1, 1, 1, 1}, 60, 0, 0},
    2.20 +	{{-0.2, 0.4, 5, 1}, 0.25, {0.2, 0.9, 0.3, 1}, {1, 1, 1, 1}, 40, 0, 0}
    2.21 +};
    2.22 +
    2.23 +static Light lightlist[] = {
    2.24 +	{{-10, 10, -20, 1}, {1, 1, 1, 1}}
    2.25 +};
    2.26 +
    2.27 +static RendInfo rinf;
    2.28 +
    2.29 +
    2.30  bool init_renderer(int xsz, int ysz, float *fb)
    2.31  {
    2.32 -	Sphere sphlist[] = {
    2.33 -		{{0, 0, 10, 1}, 1.0, {1, 0, 0, 1}}
    2.34 -	};
    2.35 -	Light lightlist[] = {
    2.36 -		{{-10, 10, -20, 1}, {1, 1, 1, 1}}
    2.37 -	};
    2.38 -	RendInfo rinf = {
    2.39 -		xsz, ysz,
    2.40 -		sizeof sphlist / sizeof *sphlist,
    2.41 -		sizeof lightlist / sizeof *lightlist,
    2.42 -		6
    2.43 -	};
    2.44 -	
    2.45 +	// render info
    2.46 +	rinf.xsz = xsz;
    2.47 +	rinf.ysz = ysz;
    2.48 +	rinf.num_sph = sizeof sphlist / sizeof *sphlist;
    2.49 +	rinf.num_lights = sizeof lightlist / sizeof *lightlist;
    2.50 +	rinf.max_iter = 6;
    2.51 +
    2.52  	/* calculate primary rays */
    2.53  	prim_rays = new Ray[xsz * ysz];
    2.54  
    2.55 @@ -105,7 +113,9 @@
    2.56  	float py = 1.0 - ((float)y / (float)h) * ysz;
    2.57  	float pz = 1.0 / tan(0.5 * vfov);
    2.58  
    2.59 -	pz *= 1000.0;
    2.60 +	px *= 100.0;
    2.61 +	py *= 100.0;
    2.62 +	pz *= 100.0;
    2.63  
    2.64  	Ray ray = {{0, 0, 0, 1}, {px, py, pz, 1}};
    2.65  	return ray;