Hi Justin, (comment to Berk below)
thanks for pointing out the g_wham problem. I am personally ok here as
I use a non-gromacs wham program.
Hi Berk,
unless I misunderstood, your suggestion does not yield the gromacs 3
behaviour that I am trying to reproduce with gromacs 4.
If I simply misunderstood your suggestion, can you please be a little
more explicit? What I want to do is to harmonically restrain the COM
of group 1 to be X nm more negative along Z than the COM of group 0.
It is important that this still works when the value for X is smaller
than the standard deviation of the sampled values such that the
distribution does not become bimodal.
Here is the test using pull_geometry=direction, and I note that this
is exactly the same behaviour that I observed and posted in my last
email while using pull_geometry=distance in combination with pull_vec.
pull = umbrella
pull_geometry = direction
pull_dim = N N Y
pull_start = no
pull_nstxout = 10
pull_nstfout = 10
pull_ngroups = 1
pull_group0 = POPC
pull_pbcatom0 = 0
pull_group1 = Protein
pull_pbcatom1 = 0
pull_init1 = 4.75
pull_rate1 = 0
pull_k1 = 500.0
pull_vec1 = 0 0 -1
coord.xvg:
1669.4000 4.97979 -4.68988
force.xvg:
1669.4000 30.0622
Where the force should be -30.062 (assuming that I understand
everything correctly).
coord.xvg:
2.9600 5.16151 -5.14321
force.xvg
2.9600 -196.603
Where the force should be +196.603 (assuming that I understand
everything correctly).
pull = umbrella
pull_geometry = direction
pull_dim = N N Y
pull_start = no
pull_nstxout = 10
pull_nstfout = 10
pull_ngroups = 1
pull_group0 = POPC
pull_pbcatom0 = 0
pull_group1 = Protein
pull_pbcatom1 = 0
pull_init1 = 4.75
pull_rate1 = 0
pull_k1 = 500.0
pull_vec1 = 0 0 1
coord.xvg:
0.5200 5.17421 5.00621
force.xvg:
0.5200 -128.107
Where this is what I intend to occur (i.e. working as I desire it to).
coord.xvg:
1649.4000 4.99895 4.69239
force.xvg:
1649.4000 28.807
Where this is what I intend to occur (i.e. working as I desire it to).
Thank you,
Chris.
--- original message --
Hi,
You should use pull_geometry=direction.
distances don't get negative.
Berk
Date: Sat, 14 Nov 2009 09:21:39 -0500
From: chris.neale at utoronto.ca
To: gmx-users at gromacs.org
Subject: [gmx-users] pull code with defined negative relative displacements
Hello, I am re-running some of our gromacs 3 simulations using gromacs
4, and as far as I can tell the gromacs 4 pull code, while very nicely
enhanced from gromacs 3, has also lost some functionality.
I am calculating the PMF of a peptide across a bilayer and, to
simplify the issue, what I can't figure out how to do with gromacs 4
is to pull group1 to a position 1 nm more negative along the z-axis
than group 0 (the bilayer in this case) for some replicas and to 1
nm more positive along the z-axis than group 0 in others. I'll
focus on the negative displacement here as it is the one that is
giving me problems.
This used to be possible with the following gromacs 3 pull.ppa options:
runtype = umbrella
reftype = com
pulldim = N N Y
reference_group = group0
group_1 = group1
K1 = 500
Pos1 = 0 0 -1.0
Sure, I could start group1 in the correct negative-z displacement from
group0 and use pull_init1=+1.0, but this will not work when, for
instance, I want to restrain it to -0.1 nm (using pull_init1=+0.1),
where the sampling will infrequently jump back and forth about z=0.
Just to be sure, I tried for gromacs 4 are the following pull code
.mdp options:
pull = umbrella
pull_geometry = distance
pull_dim = N N Y
pull_start = no
pull_ngroups = 1
pull_group0 = group0
pull_group1 = group1
pull_init1 = -1.0
pull_rate1 = 0
pull_k1 = 500.0
where mdrun complains:
"Pull reference distance for group 1 is negative (-1.000000)"
and it is pretty obvious why this doesn't work since it is asking for
a negative displacement. Nevertheless, I tried it and pull_init1
appears to get set to zero.
I also attempted the following.
pull = umbrella
pull_geometry = distance
pull_dim = N N Y
pull_start = no
pull_ngroups = 1
pull_group0 = group0
pull_group1 = group1
pull_init1 = 1.0
pull_rate1 = 0
pull_k1 = 500.0
pull_vec1 = 0 0 -1
where I would then use
pull_init1 = 1.0
pull_vec1 = 0 0 1
for the positive side of the bilayer.
However, when I look at the forces, I am getting the negative of
what I should get when pull_vec1 = 0 0 -1.
coord.xvg:
610.0000 4.9343 -1.02019
660.0001 4.91454 -0.949747
force.xvg:
610.0000 -10.0932
660.0001 25.1265
Although I am getting exactly what I should get when pull_vec1 = 0 0
1 (for intended positive displacements).
coord.xvg:
660.0001 4.9014 1.16304
force.xvg:
660.0001 -81.5201
Any ideas are greatly appreciated. I can probably mod the code for my
needs, but a standard gromacs binary is always preferable.
Thank you,
Chris.
--
gmx-users mailing list gmx-users@gromacs.org
http://lists.gromacs.org/mailman/listinfo/gmx-users
Please search the archive at http://www.gromacs.org/search before posting!
Please don't post (un)subscribe requests to the list. Use the
www interface or send it to gmx-users-requ...@gromacs.org.
Can't post? Read http://www.gromacs.org/mailing_lists/users.php