-
Notifications
You must be signed in to change notification settings - Fork 195
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
Model neutral SO3 parametrizations - semantics of parameter #52
Comments
Here is a way out of all of this: A parameterization must define the semantics of two things:
Everything else is governed by the rules of a rotation matrix. I think we should disallow constructors from storage and from scalars and have all construction handled by either (a) conversion from another SO3 type, or (b) factory functions that make the above very clear. Then, as we implement this new interface, we should come up with a way to document these factories such that there is no ambiguity. I'm open for suggestions on how to call these functions.
|
Documentation of these functions should always include a few numerical examples of converting to a rotation matrix and back. |
I guess then, every constructor function should also have a retrieval function:
|
I would not make these retrieval functions return the Storage type, but just define them directly. |
No this is no way out of it at all :)! I vote for the versions as motivated by active physical intuition, and the usual right hand convention : |
Ah, you are thinking of construction time - I'm fine with factories there. I was more talking about memory interpretation! For example, when a rot vector has three doubles stored, we need to implement its apply method somehow! - for that this was supposed to be. |
Could we please have a separate issue about construction? This is really a separate problem. Unless we don't agree and have multiple parametrizations. But then we have recreated kindr with active and passive, but with less systematic names. |
The user should be discouraged from thinking about what is being stored underneath. |
Hm, ok. Then we can quickly agree :). But don't forget that people need to know the memory interpretation sometimes. And the whole functional interface is otherwise arbitrary. Imagine for example:
|
After we have fixed that, we can easily write those factories, but they are actually on a different layer towards modeling because they will be an interface starting to talk about frames and usage! The lowest layer does not need to do that. It is enough to define the apply methods or the conversions to matrix and fix the matrix application to simple matrix product. I would not even put them into the so3 folder. But have them in a different part of the library - the factory based interface to modeling. It would basically consist of these factories and would not provide model based type safety. An alternative on the same layer would be to have types referring to frames and active and passive usage, that would provide a similar service and would also be model-type safe. |
I strongly disagree with this:
I really liked kindr because when you read the code, you can exactly tell what is going on by only looking at the type of the rotation object. I would strongly prefer to have different types rather than functions.
|
I can probably acquiesce on the type names but not on the constructor.
Question: Now that we are using rotation matrix semantics, what is the difference between a |
As expected, on this layer it is hard to agree and I would really suggest having multiple! This looks like two interfaces layers basically containing almost nothing (in terms of code). Only factory methods calling storage constructors (paul's) or constructors calling storage constructors (Christian's). |
This is exactly why I propose to not touch modeling with the core of the library, we currently try to start with! And it is, why I started this issue. Please try to understand what this issue was originally meant to be about and for the model affine interface please consider having multiple interfaces. We won't agree there! And we can even treat/sell as research to compare those and to fully understand what an independent core is / could be. |
I guess we still have a misunderstanding. Maybe we should talk on Monday. I would have said that we use the "passive" view since we all work with that operation. My understanding would have been: [0, 0, -1]' = DirectionCosineMatrix([1, 0, 0; 0 0, 1; 0 -1 0]).apply([0, 1, 0]') |
The problem here is that to do that you need to start talking about multiple frames. Otherwise it makes no sense. I would try to work in one space only: in the tuple space of Vec3. There one would not know about anything like DirectCosineMatrix but there one would already know how a 3x3 proper orthogonal matrix (=SO3) operates (by matrix multiplication) and one would know how a unit-quaternion rotates (after deciding one the mult) - and by identifying action one would already be able to convert between matrix and quat. The only open question would be what is an AngleAxis and an EulerAngles parametrization of the same actions. This is apriory arbitrary as these physically motivated constructions have no relation to Vec3, without introducing frames - which we wouldn't. The only thing we have in that setting is to look at the apply or convert formulas. And there when you use the passive concepts you always include an unnecessary inversion somehow. Just exactly as when one thinks of how to apply an Passive Angel Axis - you first think of the physical intuition, which is active, and then you invert to have it passive. But why have that in a context where it is arbitrary because there are no frames? This one can also find in the final formulas: think of rotation vector to matrix. If you use passive rotation vector definition for a Vec3,
(^x is the map to the skew symmetric matrices) |
Hannes, I 100% agree with you! |
I also agree with this concept. I'm just wondering how you can realize this. I will wait for the prototype. |
I guess we can easy agree on:
, with * is the matrix product.
But what is with (it is basically the question about active and passive but for the definitions of parameters fo SO3)
AngleAxis(90deg, x).apply(y)
or RotVec(90deg * x).apply(y)EulerAnglesXYZ(90deg, 0, 0).apply(y)
RotQuatRealFirst(sqrt(1/2), sqrt(1/2), 0, 0).apply(y)
(should also be a 90deg turn around the x-axis)The text was updated successfully, but these errors were encountered: