<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW - ES3-CTS.gtf.GL3Tests.shadow.shadow_execution_vert fails"
href="https://bugs.freedesktop.org/show_bug.cgi?id=91114#c19">Comment # 19</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW - ES3-CTS.gtf.GL3Tests.shadow.shadow_execution_vert fails"
href="https://bugs.freedesktop.org/show_bug.cgi?id=91114">bug 91114</a>
from <span class="vcard"><a class="email" href="mailto:kevin.rogovin@intel.com" title="Kevin Rogovin <kevin.rogovin@intel.com>"> <span class="fn">Kevin Rogovin</span></a>
</span></b>
<pre>Hi,
At Tapani's request, I've done some digging into this and the code to lower
textureGrad for cube maps is much wronger than just adjusting rho by a
constant.
Lets do the case where the face used is the Z_MAX face, i.e. r>0 and has
largest absolute value. The then texel coordinates are:
u = L * 0.5 * ( s/r + 1)
v = L * 0.5 * ( t/r + 1)
where L is the dimension of the cube-map. The gradient of u is then given by:
grad(u) = 0.5 * L * ( grad(s)/r - (s/(r*r))*grad(r) )
then rho is given by:
rho = abs(grad(u)) + abs(grad(v))
= 0.5 * L * ( |grad(s)/r - (s/(r*r))*grad(r)| + |grad(t)/r -
(t/(r*r))*grad(r)| )
The current code has (after the -1 is taken into account on the log2)
rho = 0.5 * L * ( |grad s| + |grad t| + |grad r|)
which is only correct (in this case) when grad(r) is zero and r=1.
To fix the rho computation (or the LOD) requires first finding which face the
thing is on, and from there develop grad(u), grad(v) correctly. There will be,
sadly six cases. This can be reduces to 3 cases. Indeed, lets say the face was
from Z-negative, then we have:
u = L * 0.5 * s/(-r)
thus grad(u) = - 0.5 * L * ( grad(s)/r - (s/(r*r))*grad(r) )
which is the same as the Z_MAX but negated. The magnitude is unaffected though.
Thus to compute the correct jazz, one has really just 3 cases: X-FACE, Y-FACE,
Z-FACE.
Tapani told me this little nugget (found on the map page for texureGrad
(<a href="https://www.opengl.org/sdk/docs/man/">https://www.opengl.org/sdk/docs/man/</a>) :
"For the cube version, the partial derivatives of P are assumed to be in the
coordinate system used before texture coordinates are projected onto the
appropriate cube face."
That sentence confirms the requirement to use the calculus quotient rule.
-Kevin</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the QA Contact for the bug.</li>
</ul>
</body>
</html>