summaryrefslogtreecommitdiff
path: root/geometry.py
diff options
context:
space:
mode:
Diffstat (limited to 'geometry.py')
-rw-r--r--geometry.py21
1 files changed, 4 insertions, 17 deletions
diff --git a/geometry.py b/geometry.py
index be31e4b..04be460 100644
--- a/geometry.py
+++ b/geometry.py
@@ -336,6 +336,9 @@ class Geometry(object):
set_material = module.get_function('set_material')
for i, material in enumerate(self.materials):
if material is None:
+ if color is False:
+ print 'warning: some triangles have no associated material.'
+
continue
refractive_index = np.interp(standard_wavelengths, material.refractive_index[:,0], material.refractive_index[:,1]).astype(np.float32)
@@ -363,22 +366,6 @@ class Geometry(object):
set_surface(np.int32(i), surface.absorption_gpu, surface.reflection_diffuse_gpu, surface.reflection_specular_gpu, block=(1,1,1), grid=(1,1))
- self.material1_index_tex = module.get_texref('material1_lookup')
- self.material2_index_tex = module.get_texref('material2_lookup')
- self.surface_index_tex = module.get_texref('surface_lookup')
-
- self.material1_index_gpu = cuda.to_device(self.material1_index)
- self.material2_index_gpu = cuda.to_device(self.material2_index)
- self.surface_index_gpu = cuda.to_device(self.surface_index)
-
- self.material1_index_tex.set_address(self.material1_index_gpu, self.material1_index.nbytes)
- self.material2_index_tex.set_address(self.material2_index_gpu, self.material2_index.nbytes)
- self.surface_index_tex.set_address(self.surface_index_gpu, self.surface_index.nbytes)
-
- self.material1_index_tex.set_format(cuda.array_format.SIGNED_INT32, 1)
- self.material2_index_tex.set_format(cuda.array_format.SIGNED_INT32, 1)
- self.surface_index_tex.set_format(cuda.array_format.SIGNED_INT32, 1)
-
vertices = np.empty(len(self.mesh.vertices), dtype=gpuarray.vec.float4)
vertices['x'] = self.mesh.vertices[:,0]
vertices['y'] = self.mesh.vertices[:,1]
@@ -393,7 +380,7 @@ class Geometry(object):
if color:
triangles['w'] = self.colors
else:
- triangles['w'] = (self.material1_index << 24) | (self.material2_index << 16) | (self.surface_index << 8)
+ triangles['w'] = ((self.material1_index & 0xff) << 24) | ((self.material2_index & 0xff) << 16) | ((self.surface_index & 0xff) << 8)
lower_bounds = np.empty(self.lower_bounds.shape[0], dtype=gpuarray.vec.float4)
lower_bounds['x'] = self.lower_bounds[:,0]