this all makes sense yes.
I am just not that is the most intuitive way to work
What is a more intuitive alternative. The current setup It works quite
a bit like the code for creating a centroid.
I would suggest adding functions for an external coordinate set and
get transformation of RigidBodies as the internal coordinate system
is an implementation detail.
I don't know what such would mean. Could you clarify?
If someone gives you a bunch of particles, there isn't really a single
natural reference point. Different choices makes sense depending on
what you are doing with them. The code currently uses the standard way
of defining the position and orientation from physics when using rigid
bodies.
I do agree that it probably makes sense to add a transform function
for rigid bodies to go with the one for IMP.atom.Hierarchy.
On May 25, 2009, at 4:30 PM, Daniel Russel wrote:
As with any thing you want to use that is an offset from a value,
you need to keep track of the offset and subtract it when you set
the value. For ease with rigid bodies, compute the centroid in the
rigid body frame (or apply the inverse transform to map a point in
external coordinates) and then rotate the internal coordinates and
subtract them before setting when you want to set the
translational part of the coordinats later. Make sense?
If you don't care what centroid you use, just use the rigid body
center (since it is currently a unwejghted centroid and will at
most change to a weighted centroid).
This is how I solved it now - but I would like to change the
centroid of the rigid body after an optimization stage since it is
part of a bigger optimization protocol.
On May 25, 2009, at 1:54 PM, Daniel Russel wrote:
Assuming you want to transform, say, the input pdb, then just get
the transformation immediately following creation and compose
with that (since the initial transform has not moved the object).