[gmx-users] Re: Calculate individual force between each atom pair

Erik Lindahl lindahl at cbr.su.se
Mon May 21 09:55:57 CEST 2007


Hi,

On May 20, 2007, at 11:50 PM, WU Yanbin wrote:

>   Thanks for the suggestions.
>   I have traced the calling sequence from do_force() to calculate  
> LJ forces: do_force() -->force() -->do_nonbonded(). But in  
> do_nonbonded() function of nonbonded.c file, if for general  
> processor, it should have call gmx_nb_generic_kernel() function but  
> this line is in fact commented and the implimentation of  
> gmx_nb_generic_kernel() can not be found. My gromacs version is v3.3.
>   So is there previous implementation of this function? I can write  
> it myself but the efficiency will be much lower. Any suggestions?  
> Thanks in advance.

No, the "generic" loop is actually something new we haven't  
implemented yet (well, only partly at least).

The idea is to have three levels of optimization, depending both on  
the architecture and how complicated/custom interactions you want to do.


1. For common simulation setups on common hardware you will run the  
manually tuned assembly kernels.
2. When that isn't possible, we have a wider selection of  
automatically generated kernels in C/Fortran (the nb_kernel  
directory). These are somewhat optimized for different hardware when  
it comes to prefetching, the 1/sqrt(x) calls, but do not use any  
inline assembly.
3. If you want to do esoteric interactions such as multipoles or hack  
your own functional form, we intend to have a "generic" C-language  
kernel with a switch statement for the type of interaction inside the  
innermost loop. This is not good for performance, but it should be  
straightforward both to understand and hack, not to mention it can be  
faster than using tables for the interactions.

For reference, have a look at the 1,4-interactions routine to see  
what it would look like.

Cheers,

Erik





More information about the gromacs.org_gmx-users mailing list