[gmx-developers] Trade-offs between encapsulation and low level modifications of class variables.

Berk Hess hess at kth.se
Fri Oct 28 23:24:43 CEST 2016


Hi,

Have you seen my external pull potential functionality change 
(28013db1c1515f01c4d4acd64eb510ead4fef2db)?
I don't know if it's something like that that you would need, or you 
would rather have a general framework to modify mdp parameters on the fly.

Cheers,

Berk

On 10/28/2016 08:06 PM, David van der Spoel wrote:
> Hi,
>
> recently (over the last year) I have been working on the electric 
> field code as a template for other applied forces. Teemu has done tons 
> of work commenting, cleaning up and adding more patches with the 
> result that we now almost have a complete framework for reading e.g. 
> MDP and TPX files with the same code (correct me if I'm wrong), and a 
> JSON mdp file should be doable in the near future as well.
>
> In the process lots of encapsulation has been done of the type "bare 
> outside class interface with Impl_ for the details". Obviously this 
> has many advantages like decluttered interfaces and modularization.
>
> However, part of the rationale for my changes was to be able to modify 
> e.g. the electric field parameters from a program (not mdrun) and 
> re-evaluate the energy and dipole of a molecule, which would yield the 
> polarizability. The functions to do this are now not accessible 
> anymore, except by faking reading a new MDP input, and even that is 
> not possible anymore outside readir.cpp since the last few patches 
> (most of which I approved :) ).
>
> There may be similar cases, where one would like to change variables, 
> like steered MD, certain free energy schemes or analysis tools. I'm a 
> bit at a loss how to deal with this, would be great to have some 
> feedback on this.



More information about the gromacs.org_gmx-developers mailing list