iDevGames Forums
Help converting normals from global space to tangent space - Printable Version

+- iDevGames Forums (http://www.idevgames.com/forums)
+-- Forum: Development Zone (/forum-3.html)
+--- Forum: Graphics & Audio Programming (/forum-9.html)
+--- Thread: Help converting normals from global space to tangent space (/thread-2700.html)



Help converting normals from global space to tangent space - Muthaias - Mar 27, 2008 04:42 PM

Hi, I'm developing a simple normal map generator. One that takes two meshes, one lowpoly and one highpoly and creates a normal map for the lowpoly. (Yes I know that there exists such things already, but I'm doing it just for the kicks Rasp)

The result when rendering a global space normal map is quite satisfying but when it comes to the tangent space one it get's worse. I can't seem to get a grip on how to generate a tangent space normal map using the smoothed normals of the lowpoly model. I can however generate one that looks decent for the hard normals but such a normal map just isn't good enough for anything Rasp

This is how I was thinking when using the hard normals:
[Image: tsmormalilluwe6.jpg]
Where all the vectors are normalized and the two tangents are parallell to their corresponding edge of the triangle. The normal is ofcourse the hard normal of the triangle. (The T is the transformation matrix which I would use to transform the global space normals to tanget space.)

For the smoothed normals I was thinking of generating a matrix for every pixel of the global space map where I use the interpolated smoothed normal as the normal and the same tangents and uv vectors as before. I would like some input on that method before implementing it though.

Any input is greatly appreciated.


Help converting normals from global space to tangent space - sohta - Mar 29, 2008 10:58 PM

Someone correct me if I am wrong, but shouldn't your three axises form an orthonormal coordinate system?


Help converting normals from global space to tangent space - Muthaias - Mar 30, 2008 08:24 AM

I think, you are right about that.

I've actually thought about making the vectors orthonormal but it feels like the results would differ quite a bit depending on which vector I choose as the first and second base vector.

Perhaps I'm just making a faulty assumption.


Help converting normals from global space to tangent space - OneSadCookie - Mar 30, 2008 11:16 AM

If they're not orthonormal the matrix won't be (purely) a rotation matrix.


Help converting normals from global space to tangent space - sohta - Mar 30, 2008 01:08 PM

Alright, it's been a while since I did any of that stuff, but here goes:

IIRC, your tangent vector is the direction that will match the u axis of your texture coordinate minus its projection on the normal vector (normalizing the end result). Your "second tangent" (normally referred to as the binormal) has to be the cross product of the tangent and the normal (in order to preserve the orthonormality). You have the choice of precalculating that value, or generate it in your shader (depending on where your bottleneck is).


Help converting normals from global space to tangent space - CarbonX - Mar 30, 2008 02:24 PM

Found this article on devBump, might help you out

Article


Help converting normals from global space to tangent space - Muthaias - Apr 1, 2008 06:28 AM

Sohta: Yeah... that sounds like a reasonable plan. One thing I got to thinking about, when I was just about to try it, was this.

To get the tangent which is pointing in the direction of the U-coordinate one could use the inverse of my matrix T and use it on the vector [1, 0, 0]. After that, if one has a matrix for every pixel you would use inv(T) on the vector [0, 0, 1].
Using a perfectly constructed UV-map one would get the bitangent using inv(T) on [0, 1, 0]. (This would result in the a transformation of the I-matrix which again iresults in inv(T).)

So I was thinking, is it really the correct way to actually build a orthonormal matrix? Wouldn't a transformation matrix be more "correct" if one wants to convert to a local coordinate system?


Thanks for the input Smile