[gmx-users] Principal axis (g_principal)

chris.neale at utoronto.ca chris.neale at utoronto.ca
Tue Nov 2 17:46:37 CET 2010


Dear Sarah,

I just ran into the same thing so I'm posting this as a very late  
response to your querry.

I think that g_principal prints the transpose of the principal axes  
matrix, which is the exact opposite of what one would expect.

(1) First, I define a system that is longest in Z, second longest in  
Y, and shortest in X:

cneale at iram:~$ cat a.gro
a
12
     1CL-     CL    1   0.000   0.000   0.000
     2CL-     CL    2   0.000   1.000   0.000
     3CL-     CL    3   0.000   2.000   0.000
     4CL-     CL    4   1.000   0.000   0.000
     5CL-     CL    5   1.000   1.000   0.000
     6CL-     CL    6   1.000   2.000   0.000
     7CL-     CL    7   0.000   0.000  10.000
     8CL-     CL    8   0.000   1.000  10.000
     9CL-     CL    9   0.000   2.000  10.000
    10CL-     CL   10   1.000   0.000  10.000
    11CL-     CL   11   1.000   1.000  10.000
    12CL-     CL   12   1.000   2.000  10.000
50 50 50
cneale at iram:~$ cat a.top
#include "ffoplsaa.itp"
#include "ions.itp"


[ system ]
; name
grid


[ molecules ]
; name        number
CL-  12

############

(2) Next I calculate the principal axes:


$ echo 0 |g_principal -f a.gro -s a.tpr >/dev/null 2>&1; cat axis1.dat  
axis2.dat axis3.dat
    0.0000000000        0.0000000000     0.0000000000     1.0000000000
    0.0000000000        0.0000000000     1.0000000000     0.0000000000
    0.0000000000        1.0000000000     0.0000000000     0.0000000000

############

(3) Finally, I rotate it by 90 deg and calculate the principal axes:

$ editconf -f a.gro -o b.gro -rotate 90 0 0 >/dev/null 2>&1; echo 0  
|g_principal -f b.gro -s a.tpr >/dev/null 2>&1; cat axis1.dat  
axis2.dat axis3.dat
    0.0000000000        0.0000000000     0.0000000000     1.0000000000
    0.0000000000        1.0000000000     0.0000000000     0.0000000000
    0.0000000000        0.0000000000     1.0000000000     0.0000000000

############

(4) I use VMD to confirm that the longest axis is in Y. Thus one must  
read the columns in axis1.dat as time1, X1, X2, X3 whereas one would  
intuit that they read as time1, X1, Y1, Z1.

I didn't test this extensively, but if my colleague determines that I  
am incorrect in what I have posted here then I will post that to this  
list.

If I am correct, then it would be very useful to get some #titles in  
the axisN.dat output files from g_principal.

Chris.


Dear gmx users,

I am doing several analyses (version 4.0.4) on my simulations with small
organic molecules inserting into a DMPC bilayer. Now I would like to calculate
whether the small molecule inserts into the membrane with a specific angle to
the membrane normal (or z-axis). I have used two approaches:

1) My molecule is a cyclohexene ring with two "para" substituents. I made an
index group with carbon number 3 and number 10 (in different groups) which
corresponds to the first substituent-atoms on each side of the ring. This
vector describes the shape of the molecule quite well. I then used g_bundle to
calculate the angle between this vector and the z-axis by echoing first the
C3-group and then the C10-group:

echo 0 1 | g_bundle -f xxx.xtc -s xxx.tpr -n xxx-vector.ndx -na 1 -z -ot
xxx-vector.xvg

This gives fairly reasonable results and angle distribution.

2) I also calculated the principal axis by g_principal where I echoed each
small molecule as a whole:

echo 0 | g_principal -f xxx.xtc -s xxx-1.tpr -n xxx-lim.ndx -a1
xxx-principal.dat -a2 xxx-axis2.dat -a3 xxx-axis3.dat

To get the angle between the principal axis and the z-axis one takes the arcos
the the z-component. This created quite a different and very broad angle
distribution.



This puzzled me very much since the difference between the C3-C10 vector and
the principal axis should not be that great.

I then used a small python program to calculate the principal axis of my
molecule and the result was again quite different than from  
g_principal. I have
tried to rotate each of my substituent groups by 120 degrees (creating 9
different conformations) and then calculate the difference in the principal
axis but this creates only a deviation of max. 16-17 degrees not at all
accounting for the very different angle distributions seen. I have not  
included
numbers but I can do so along with the python code. I would like to ask if
anyone can see any obvious mistakes or know of something special to be  
aware of
when using g_principal?



Thank you,

Sarah






More information about the gromacs.org_gmx-users mailing list