hslt: misc improved functionality:

texture formats
matrix 2x2 inversion special case (wasn't called before)
more meaningful flags on vertex.
metadata
johannes hanika 2014-11-03 17:40:20 +01:00 committed by Wenzel Jakob
parent 5d578e9c68
commit 6fb326038e
6 changed files with 52 additions and 12 deletions

View File

@ -75,7 +75,7 @@ struct RestoreMeasureHelper {
: vertex(vertex), measure(vertex->measure) { }
~RestoreMeasureHelper() { vertex->measure = measure; }
PathVertex *vertex;
uint8_t measure;
EMeasure measure;
};
MTS_NAMESPACE_END

View File

@ -91,7 +91,7 @@ struct MTS_EXPORT_BIDIR PathVertex {
*
* \sa EVertexType
*/
uint8_t type : 7;
EVertexType type : 7;
/**
* \brief Denotes whether this vertex \a only supports
@ -129,7 +129,7 @@ struct MTS_EXPORT_BIDIR PathVertex {
*
* \sa EMeasure
*/
uint8_t measure;
EMeasure measure : 8;
/**
* \brief When the current vertex supports sampling

View File

@ -96,6 +96,12 @@ struct Frame {
return v.z;
}
/** \brief Assuming that the given direction is in the local coordinate
* system, return the u and v coordinates of the vector 'v' */
inline static Vector2 uv(const Vector &v) {
return Vector2(v.x, v.y);
}
/** \brief Assuming that the given direction is in the local coordinate
* system, return the squared sine of the angle between the normal and v */
inline static Float sinTheta2(const Vector &v) {

View File

@ -37,7 +37,7 @@ public:
/**
* \brief Construct a new MxN matrix without initializing it.
*
* This construtor is useful when the matrix will either not
* This constructor is useful when the matrix will either not
* be used at all (it might be part of a larger data structure)
* or initialized at a later point in time. Always make sure
* that one of the two is the case! Otherwise your program will do
@ -291,7 +291,7 @@ public:
* and a permutation vector piv of length m so that A(piv,:) = L*U.
* If m < n, then L is m-by-m and U is m-by-n.
*
* The LU decompostion with pivoting always exists, even if the matrix is
* The LU decomposition with pivoting always exists, even if the matrix is
* singular, so the constructor will never fail.
* The primary use of the
*
@ -361,7 +361,7 @@ public:
T cholDet() const;
/// Check if the matrix is identically zeor
/// Check if the matrix is identically zero
inline bool isZero() const {
for (int i=0; i<M; ++i)
for (int j=0; j<N; ++j)
@ -489,7 +489,7 @@ public:
}
/// Compute the inverse (Faster than Matrix::invert)
FINLINE bool invert(Matrix2x2 &target) const {
FINLINE bool invert2x2(Matrix2x2 &target) const {
Float det = m[0][0]*m[1][1] - m[0][1]*m[1][0];
if (std::abs(det) <= RCPOVERFLOW)
return false;
@ -500,9 +500,25 @@ public:
target.m[1][0] = -m[1][0] * invDet;
return true;
}
FINLINE bool invert(Matrix2x2 &target) const {
return invert2x2(target);
}
/// Compute the inverse with det (Faster than Matrix::invert)
FINLINE bool invert2x2(Matrix2x2 &target, Float& det) const {
det = m[0][0]*m[1][1] - m[0][1]*m[1][0];
if(std::abs(det) <= RCPOVERFLOW)
return false;
Float invDet = 1/det;
target.m[0][0] = m[1][1] * invDet;
target.m[0][1] = -m[0][1] * invDet;
target.m[1][1] = m[0][0] * invDet;
target.m[1][0] = -m[1][0] * invDet;
return true;
}
/// Matrix-vector multiplication
inline Vector2 operator*(const Vector2 &v) const {
inline Vector2 operator*(const Vector2 &v) const {
return Vector2(
m[0][0] * v.x + m[0][1] * v.y,
m[1][0] * v.x + m[1][1] * v.y
@ -584,7 +600,7 @@ public:
}
/// Matrix-vector multiplication
inline Vector operator*(const Vector &v) const {
inline Vector operator*(const Vector &v) const {
return Vector(
m[0][0] * v.x + m[0][1] * v.y + m[0][2] * v.z,
m[1][0] * v.x + m[1][1] * v.y + m[1][2] * v.z,
@ -675,7 +691,7 @@ struct MTS_EXPORT_CORE Matrix4x4 : public Matrix<4, 4, Float> {
}
/// Matrix-vector multiplication
inline Vector4 operator*(const Vector4 &v) const {
inline Vector4 operator*(const Vector4 &v) const {
return Vector4(
m[0][0] * v.x + m[0][1] * v.y + m[0][2] * v.z + m[0][3] * v.w,
m[1][0] * v.x + m[1][1] * v.y + m[1][2] * v.z + m[1][3] * v.w,

View File

@ -165,7 +165,14 @@ struct RayDifferential : public Ray {
ryOrigin = o + (ryOrigin - o) * amount;
rxDirection = d + (rxDirection - d) * amount;
ryDirection = d + (ryDirection - d) * amount;
}
}
void scaleDifferentialUV(const Vector2 amountUV) {
rxOrigin = o + (rxOrigin - o) * amountUV.x;
ryOrigin = o + (ryOrigin - o) * amountUV.y;
rxDirection = d + (rxDirection - d) * amountUV.x;
ryDirection = d + (ryDirection - d) * amountUV.y;
}
inline void operator=(const RayDifferential &ray) {
o = ray.o;

View File

@ -362,7 +362,18 @@ void GLTexture::lookupGLConstants() {
return;
}
if (m_componentFormat == EFloat16) {
if (m_componentFormat == EUInt8) {
switch (m_pixelFormat) {
case ELuminance: m_internalFormat = GL_LUMINANCE8; break;
case ELuminanceAlpha: m_internalFormat = GL_LUMINANCE8_ALPHA8; break;
case ERGB: m_internalFormat = GL_RGB8; break;
case ERGBA: m_internalFormat = GL_RGBA8; break;
default:
Log(EError, "Unknown/unsupported pixel format!");
return;
}
}
else if (m_componentFormat == EFloat16) {
switch (m_pixelFormat) {
case ELuminance: m_internalFormat = GL_LUMINANCE16F_ARB; break;
case ELuminanceAlpha: m_internalFormat = GL_LUMINANCE_ALPHA16F_ARB; break;