Some debugging.

This commit is contained in:
castano 2011-10-04 06:10:34 +00:00
parent d8aec20022
commit cbf4b2e3bf
3 changed files with 33 additions and 16 deletions

View File

@ -47,7 +47,7 @@ ELSE(NVTT_SHARED)
ADD_LIBRARY(nvtt ${NVTT_SRCS}) ADD_LIBRARY(nvtt ${NVTT_SRCS})
ENDIF(NVTT_SHARED) ENDIF(NVTT_SHARED)
TARGET_LINK_LIBRARIES(nvtt ${LIBS} nvcore nvmath nvimage squish) TARGET_LINK_LIBRARIES(nvtt ${LIBS} nvcore nvmath nvimage nvthread squish)
INSTALL(TARGETS nvtt INSTALL(TARGETS nvtt
RUNTIME DESTINATION bin RUNTIME DESTINATION bin

View File

@ -414,6 +414,7 @@ Vector3 CubeSurface::Private::applyCosinePowerFilter(const Vector3 & filterDir,
} }
// @@ We could do a less conservative test and test the face frustum against the cone... // @@ We could do a less conservative test and test the face frustum against the cone...
// Or maybe easier: the face quad against the cone.
// Compute bounding box of cone intersection against face. // Compute bounding box of cone intersection against face.
// The intersection of the cone with the face is an elipse, we want the extents of that elipse. // The intersection of the cone with the face is an elipse, we want the extents of that elipse.
@ -465,21 +466,24 @@ Vector3 CubeSurface::Private::applyCosinePowerFilter(const Vector3 & filterDir,
// This is elegant and all that, but the problem is that the projection is not always an ellipse, but often a parabola. // This is elegant and all that, but the problem is that the projection is not always an ellipse, but often a parabola.
// A parabola has infinite bounds, so this approach is not very practical. Ugh. // A parabola has infinite bounds, so this approach is not very practical. Ugh.
if (false) { if (false) {
nvCheck(cosineFaceAngle >= 0.0f); //nvCheck(cosineFaceAngle >= 0.0f); @@ Not true for wide angles.
// Focal point in cartessian coordinates: // Focal point in cartessian coordinates:
Vector3 F = Vector3(dot(faceU[f], filterDir), dot(faceV[f], filterDir), cosineFaceAngle); Vector3 F = Vector3(dot(faceU[f], filterDir), dot(faceV[f], filterDir), cosineFaceAngle);
// Focal point in polar coordinates: // Focal point in polar coordinates:
Vector2 Fp = toPolar(F); Vector2 Fp = toPolar(F);
nvCheck(Fp.y >= 0.0f); nvCheck(Fp.y >= 0.0f); // top
nvCheck(Fp.y <= PI/2); // horizon
// If this is an ellipse, then we can handle it. // If this is an ellipse:
if (Fp.y - coneAngle > 0 && Fp.y + coneAngle < PI) { if (Fp.y + coneAngle < PI/2) {
nvCheck(Fp.y - coneAngle > -PI/2);
// Major axis endpoints: // Major axis endpoints:
Vector2 Fa1 = toPlane(Fp.x, Fp.y + coneAngle); Vector2 Fa1 = toPlane(Fp.x, Fp.y - cosineFaceAngle); // near endpoint.
Vector2 Fa2 = toPlane(Fp.x, Fp.y - coneAngle); Vector2 Fa2 = toPlane(Fp.x, Fp.y + cosineFaceAngle); // far endpoint.
nvCheck(length(Fa1) <= length(Fa2));
// Ellipse center: // Ellipse center:
Vector2 Fc = (Fa1 + Fa2) * 0.5f; Vector2 Fc = (Fa1 + Fa2) * 0.5f;
@ -490,18 +494,29 @@ Vector3 CubeSurface::Private::applyCosinePowerFilter(const Vector3 & filterDir,
// Focal point: // Focal point:
Vector2 F1 = toPlane(Fp.x, Fp.y); Vector2 F1 = toPlane(Fp.x, Fp.y);
// Focal point relative to center: // If we project Fa1, Fa2, Fc, F1 onto the filter direction, then:
Vector2 F1c = F1 - Fc; float da1 = dot(Fa1, F.xy()) / fabs(cosineFaceAngle);
float d1 = dot(F1, F.xy()) / fabs(cosineFaceAngle);
float dc = dot(Fc, F.xy()) / fabs(cosineFaceAngle);
float da2 = dot(Fa2, F.xy()) / fabs(cosineFaceAngle);
//nvDebug("%f <= %f <= %f <= %f (%d: %f %f | %f %f)\n", da1, d1, dc, da2, f, F.x, F.y, Fp.y - coneAngle, Fp.y + coneAngle);
//nvCheck(da1 <= d1 && d1 <= dc && dc <= da2);
// Translate focal point relative to center:
F1 -= Fc;
// Focal distance: // Focal distance:
//float f = length(F1c); // @@ Overriding f! //float f = length(F1); // @@ Overriding f!
// Minor radius: // Minor radius:
//float b = sqrtf(a*a - f*f); //float b = sqrtf(a*a - f*f);
// Second order quadric coefficients: // Second order quadric coefficients:
float A = a*a - F1c.x * F1c.x; float A = a*a - F1.x * F1.x;
float B = a*a - F1c.y * F1c.y; nvCheck(A >= 0);
float B = a*a - F1.y * F1.y;
nvCheck(B >= 0);
// Floating point bounds: // Floating point bounds:
float u0 = clamp(Fc.x - sqrtf(B), -1.0f, 1.0f); float u0 = clamp(Fc.x - sqrtf(B), -1.0f, 1.0f);

View File

@ -12,16 +12,18 @@ ADD_TEST(NVTT.TestSuite.Waterloo.nocuda nvtestsuite -path ${NV_SOURCE_DIR}/data/
ADD_TEST(NVTT.TestSuite.Epic.nocuda nvtestsuite -path ${NV_SOURCE_DIR}/data/testsuite -set 2 -nocuda -out output-nocuda-epic) ADD_TEST(NVTT.TestSuite.Epic.nocuda nvtestsuite -path ${NV_SOURCE_DIR}/data/testsuite -set 2 -nocuda -out output-nocuda-epic)
IF (CUDA_FOUND) IF (CUDA_FOUND)
ADD_EXECUTABLE(driverapitest driverapi.cpp) ADD_EXECUTABLE(driverapitest driverapi.cpp)
TARGET_LINK_LIBRARIES(driverapitest nvcore nvmath nvimage) TARGET_LINK_LIBRARIES(driverapitest nvcore nvmath nvimage)
ENDIF (CUDA_FOUND) ENDIF (CUDA_FOUND)
ADD_EXECUTABLE(imperativeapi imperativeapi.cpp) ADD_EXECUTABLE(imperativeapi imperativeapi.cpp)
TARGET_LINK_LIBRARIES(imperativeapi nvcore nvmath nvimage nvtt) TARGET_LINK_LIBRARIES(imperativeapi nvcore nvmath nvimage nvtt)
ADD_EXECUTABLE(process_alpha_map process_alpha_map.cpp) ADD_EXECUTABLE(process_alpha_map process_alpha_map.cpp)
TARGET_LINK_LIBRARIES(process_alpha_map TARGET_LINK_LIBRARIES(process_alpha_map nvcore nvmath nvimage nvtt)
nvcore nvmath nvimage nvtt)
ADD_EXECUTABLE(cubemaptest cubemaptest.cpp)
TARGET_LINK_LIBRARIES(cubemaptest nvcore nvmath nvimage nvtt)
INSTALL(TARGETS nvtestsuite DESTINATION bin) INSTALL(TARGETS nvtestsuite DESTINATION bin)