-
Notifications
You must be signed in to change notification settings - Fork 223
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Why matrices seems transposed and how to change it #84
Comments
Sorry I didn't respond to this. As the article says OpenGL claims computer science rows are columns So
Is interpreted as
Another way to write your code would be like this
I don't know if that helps visualize how OpenGL want's you to see it or not but above I declared four column looking things and then at the bottom I laid them left to right as columns. If you print Then the math works as you expect right? As for not being able to transpose the matrices I have no idea why they chose that except that OpenGL ES 2.0 was designed for fairly low powered machines. The transpose takes extra time so in the interest of pushing devs to write optimal code maybe they required it to be false. As for why it's there at all OpenGL ES 2.0 is based on or at least inspired by OpenGL (not ES) where that parameter already existed so rather than change the API to not have the parameter they left it there but require it to be false. Similar to the border parameter on |
First of all, thank you again for all the work you put in reading the WebGL fundation books, really useful. Thank to your sharing knowledge, I was able to build this tiny project to visualise a 3D mandelbrot fractal: Satisfying 😄. Back to your answer, I completely understand there's 2 way to interpret a 1D array as a 2D matrix: either the element are stored in a Row Major fashion or a Column Major fashion. The first time I've been sensitised to this fact was when I were using an old linear algebra library, LAPACK. The reason why OpenGL uses the Column Major layout rather than the Row Major layout is arbitrary I think (or maybe impose by hardware and the way hardware works is arbitrary (until hardware will be AI driven designed))... But OpenGL, or at least WebGL, is able to transpose a matrix before to send it to the GPU. Even if they say that the In my little fractal project, I set the (the implementation is not the cleanest possible one, but still, it's shareable) I do every matrix computation in the Row Major fashion and it works. Sure I pay an extra cost due to the transpose at each frame computation, but for me it's reasonable and now it's easier follow the computation. This issue should be closed from my side. |
you're using WebGL2 which allows transpose be true. In WebGL1 it would generate an error I'm also not sure what you mean by "it's easier to follow the computation" To put another way, from the math POV, each column is a vector. So, just like the article points out, in C++ you'd do this
and you'd could build columns
and them make a matrix from those columns
and you can pass that matrix directly into GL
And AFAIK it works as expected, the mathy way, including in GLSL
Those all work exactly how math people expect them to work. No reason to set transpose to true so I'm not convinced the reason it works this way in GL is arbitrary. The only issue come up if you write them as a 4x4 matrix
That looks wrong to a math person's eyes. Further, there are hardware issues. The math person wants to be able to pull out columns. Let's say you want the z-axis
just works. vs if things are transposed you'd have to do grab every 4th float. That would be horribly slow. you're free to do what you want but If you're setting transpose to true you're basically going against the tide of the entire graphics industry. There's nothing wrong with that except possible that you'll get used to a non-standard way and find all other examples and people's code to be confusing. |
I understand your answer, I think that I just get used to weird habit. For example, when I see a matrix like I use to implement it as:
And when I implement matrix multiplication, I use to implement it and think about it as shown in this picture: For me it's easier to think about implementation if 1D arrays are Row Major. I well understood that with this representation there is the downside that to retrieve retrieve a column you have to pick numbers every 4th float. And of course the cost of the transposition before to send it to the GPU. Sad to know that generally code are implement Column Major manner. Thank you for your answer. |
This is not a bug report, sorry.
This issue maybe related to #33
First of all, thank you for WebGL foundation, 1 and 2, awesome!
I have read many times the article 2D matrices as well as matrix vs math and I think I finally figure out why there is this baffling issue around matrices.
In the 2D matrices article, you show in detail the way matrices store their component (conversion from 1D array to matrix interpretation) and you also show the matrix multiplication to use to make it works.
As I'm a math person, as you warned in matrix vs math article, the matrices handling seems confusing to me. In fact I'd rather say, it seems like everything gets transposed. And the way the multiplication between matrices is defined make it works if the 2 input matrices are transposed and store the result in the transpose way, it's coherent. (I made the computation of the projection matrix from 2D matrices article by hand to convince myself (and check the results by printing some value from m3.multiplication function).)
Then I check the way the computed matrix is provided to a shader:
The second argument of this function is the
transpose
option. From the MDN web docs:I don't understand why the documentation tells that the option must be false!?!
Eventually if it is possible to send the computed matrix in a transpose way to the GPU (maybe manually if the WebGL function doesn't do it for us), every computation on the CPU side can be done as usual, in the math way (and avoid me some headache).
It should really reconcile the math people with matrices manipulation in the excellent WebGL foundation.
PS: I know it's certainly impossible to change the way all the articles are written and the implementation associated with them to. But I think that you can still mention this trick somewhere 😉
The text was updated successfully, but these errors were encountered: