So that was fun. Adding sphere surface coordinates to texture space converter. Used this “trivial” technique
Apart from that, I moved the code around and cleaned it slightly. that resulted in few additional frames per second. Each Sphere is semi-transparent with the same texture.
now what, normal mapping ?
[edit: 29 Jul 2013]
Apparently ther was a bug in my texturing. It is gone now 🙂
and night version,
There is a code that I used.
//intersection point, sphere
//algorithm from http://en.wikipedia.org/wiki/UV_mapping
float3 getTexelID(float3 point, sphere * ss)
float3 pole = (float3)(0.0f,1.0f,0.0f);
float3 equator = (float3)(1.0f,0.0f,0.0f);
float phi = 0.0f;
float theta = 0.0f;
float3 normal = point - ss->pos.xyz;
normal = normalize(normal);
phi = acos( -dot(normal, pole));
theta = acos( dot(normal, equator)/ sin( phi )) / ( 2 * 3.141592653589793 );
if ( dot((cross(pole, equator)), normal) > 0 )
U = theta;
U = 1 - theta;
float3 x = (float3)((float)V, (float)U, 0.0f);
finally I got some spare time to improve this baby.
It is a bit of improvement since the last time – 3rd bounce of rays were hacked into. Now the reflection looks far more realistic.
And here reflection of the reflection.. some artefacts here and there – but I can live with them for now.
oh and I need to fix timer for the frame – that is definietly not 0.31ms per frame – it takes about a second per frame. Still not that bad for the vanila implementation.
[Edit: late night]
Managed to add semi-transparent spheres! Rendering of the frame became extremely slow – had to reduce number of spheres on the scene.
Is it the right time to introduce optimisations?
I did a litte bit of research and it kept me wondering.. how about using spheres for voxels representation this time?
Lets try it out and see how much the GPU can take.
Grid of 10^3 Spheres – there is no acceleration architecture implemented yet – Octree for spheres? that feels odd..
Oh, btw. That’s raytraced.. so far quite interactive.
It uses OpenCL on Radeon 5700 HD – only primary rays so far on ambient material. Give it some time.
Simple directional light lighting system implemented.
Secondary bounces in place (depth of bounces set to two) – little bit of hackery had to be done since there is problem with recursion in OpenCL.
Every third sphere is ambient.
300 FPS when moves - Insane!
Small memory leak was driving me crazy; Debugging process was taking ages.. bored, frustrated and tired decided to play about with octrees depth and minimal/maximal number of elements in leaf.. Amazed by 300FPS discovered the stupid mistake of creating VBO each time the leaf is regenerated. Instant win; fix of memory leak and 10 times greater performance.
Who said that the mistakes are stupid?
1233560 cubes visible avg. FPS: 144.
Simple optimisation great performance boost! – Skip ALL the non-visible faces!
Progressive Grid of 256x256x256
Apparently I couldn’t resist. Last optimisation implemented.
Now seriously, report!
Perlin Noise in action
Since week all development stopped and now I am struggling with report. Just finished draft of first chapter.. it’s terrible.