Some bug fixes.

This commit is contained in:
castano@gmail.com 2011-10-12 00:01:58 +00:00
parent 0b3959e1a1
commit fa0800a24a

View File

@ -52,7 +52,7 @@ static float solidAngleTerm(uint x, uint y, float inverseEdgeLength) {
nvDebugCheck(v >= -1.0f && v <= 1.0f); nvDebugCheck(v >= -1.0f && v <= 1.0f);
#if 1 #if 1
// Exact solid angle: // Exact solid angle: @@ Not really exact when using seamless filtering...
float x0 = u - inverseEdgeLength; float x0 = u - inverseEdgeLength;
float y0 = v - inverseEdgeLength; float y0 = v - inverseEdgeLength;
float x1 = u + inverseEdgeLength; float x1 = u + inverseEdgeLength;
@ -78,13 +78,13 @@ static Vector3 texelDirection(uint face, uint x, uint y, int edgeLength, bool se
float u, v; float u, v;
if (seamless) { if (seamless) {
// Transform x,y to [-1, 1] range, match up edges exactly. // Transform x,y to [-1, 1] range, match up edges exactly.
u = float(x) * 2 / (edgeLength - 1) - 1.0f; u = float(x) * 2.0f / (edgeLength - 1) - 1.0f;
v = float(y) * 2 / (edgeLength - 1) - 1.0f; v = float(y) * 2.0f / (edgeLength - 1) - 1.0f;
} }
else { else {
// Transform x,y to [-1, 1] range, offset by 0.5 to point to texel center. // Transform x,y to [-1, 1] range, offset by 0.5 to point to texel center.
u = (float(x) + 0.5f) * (2 / edgeLength) - 1.0f; u = (float(x) + 0.5f) * (2.0f / edgeLength) - 1.0f;
v = (float(y) + 0.5f) * (2 / edgeLength) - 1.0f; v = (float(y) + 0.5f) * (2.0f / edgeLength) - 1.0f;
} }
nvDebugCheck(u >= -1.0f && u <= 1.0f); nvDebugCheck(u >= -1.0f && u <= 1.0f);
nvDebugCheck(v >= -1.0f && v <= 1.0f); nvDebugCheck(v >= -1.0f && v <= 1.0f);
@ -137,7 +137,7 @@ TexelTable::TexelTable(uint edgeLength, bool seamless) : size(edgeLength) {
for (uint y = 0; y < hsize; y++) { for (uint y = 0; y < hsize; y++) {
for (uint x = 0; x < hsize; x++) { for (uint x = 0; x < hsize; x++) {
solidAngleArray[y * hsize + x] = solidAngleTerm(hsize+x, hsize+y, edgeLength); solidAngleArray[y * hsize + x] = solidAngleTerm(hsize+x, hsize+y, 1.0f/edgeLength);
} }
} }
@ -388,8 +388,8 @@ CubeSurface CubeSurface::irradianceFilter(int size, bool seamless) const
// For each texel of the input cube. // For each texel of the input cube.
const uint edgeLength = m->edgeLength; const uint edgeLength = m->edgeLength;
for (uint f = 0; f < 6; f++) { for (uint f = 0; f < 6; f++) {
for (int y = 0; y < edgeLength; y++) { for (uint y = 0; y < edgeLength; y++) {
for (int x = 0; x < edgeLength; x++) { for (uint x = 0; x < edgeLength; x++) {
Vector3 dir = m->texelTable->direction(f, x, y); Vector3 dir = m->texelTable->direction(f, x, y);
float solidAngle = m->texelTable->solidAngle(f, x, y); float solidAngle = m->texelTable->solidAngle(f, x, y);
@ -416,9 +416,9 @@ CubeSurface CubeSurface::irradianceFilter(int size, bool seamless) const
// Warp uv coordinate from [-1, 1] to // Warp uv coordinate from [-1, 1] to
float warp(float u, int size) { /*float warp(float u, int size) {
} }*/