Enforced rotation: more rigorous calculation of ref centers
[gromacs/adressmacs.git] / include / pull_rotation.h
blob63b74d8cb870ed8624975fa83ce8132c6431d55e
1 /*
2 *
3 * This source code is part of
4 *
5 * G R O M A C S
6 *
7 * GROningen MAchine for Chemical Simulations
8 *
9 * Written by David van der Spoel, Erik Lindahl, Berk Hess, and others.
10 * Copyright (c) 1991-2000, University of Groningen, The Netherlands.
11 * Copyright (c) 2001-2008, The GROMACS development team,
12 * check out http://www.gromacs.org for more information.
14 * This program is free software; you can redistribute it and/or
15 * modify it under the terms of the GNU General Public License
16 * as published by the Free Software Foundation; either version 2
17 * of the License, or (at your option) any later version.
19 * If you want to redistribute modifications, please consider that
20 * scientific software is very special. Version control is crucial -
21 * bugs must be traceable. We will be happy to consider code for
22 * inclusion in the official distribution, but derived work must not
23 * be called official GROMACS. Details are found in the README & COPYING
24 * files - if they are missing, get the official version at www.gromacs.org.
26 * To help us fund GROMACS development, we humbly ask that you cite
27 * the papers on the package - you can find them in the top README file.
29 * For more info, check our website at http://www.gromacs.org
31 * And Hey:
32 * Gallium Rubidium Oxygen Manganese Argon Carbon Silicon
35 /*! \file pull_rotation.h
37 * @brief Enforced rotation of protein parts or other groups of particles.
39 * This file contains routines that are used to enforce rotational motion
40 * upon a subgroup of particles.
44 #ifndef _rotation_h
45 #define _rotation_h
47 #ifdef HAVE_CONFIG_H
48 #include <config.h>
49 #endif
51 #include "vec.h"
52 #include "typedefs.h"
55 /*! \brief Initialize the enforced rotation groups.
57 * This routine does the memory allocation for various helper arrays, opens
58 * the output files etc.
60 * \param fplog General output file, normally md.log.
61 * \param ir Struct containing MD input parameters, among those
62 * also the enforced rotation parameters.
63 * \param nfile Number of entries in the fnm structure.
64 * \param fnm The filenames struct containing also the names
65 * of the rotation output files.
66 * \param cr Pointer to MPI communication data.
67 * \param x The positions of all MD particles.
68 * \param mtop Molecular topology.
69 * \param oenv Needed to open the rotation output xvgr file.
70 * \param Flags Flags passed over from main, used to determine
71 * whether or not we are doing a rerun.
73 extern void init_rot(FILE *fplog,t_inputrec *ir,int nfile,const t_filenm fnm[],
74 t_commrec *cr, rvec *x, gmx_mtop_t *mtop, const output_env_t oenv,
75 unsigned long Flags);
78 /*! \brief Calculation of the enforced rotation potential.
80 * This is the main enforced rotation module which is called during every time
81 * step. Here the rotation potential as well as the resulting forces are
82 * calculated.
84 * \param cr Pointer to MPI communication data.
85 * \param ir Struct containing MD input parameters, among those
86 * \param box Simulation box, needed to make group whole.
87 * \param x The positions of all the local particles.
88 * \param t Time.
89 * \param step The time step.
90 * \param wcycle During the potential calculation the wallcycles are
91 * counted. Later they enter the dynamic load balancing.
92 * \param bNS After domain decomposition / neighborsearching several
93 * local arrays have to be updated (masses, shifts)
95 extern void do_rotation(t_commrec *cr,t_inputrec *ir,matrix box,rvec x[],real t,
96 int step,gmx_wallcycle_t wcycle,bool bNS);
99 /*! \brief Add the enforced rotation forces to the official force array.
101 * Adds the forces from enforced rotation potential to the local forces and
102 * sums up the contributions to the rotation potential from all the nodes. Since
103 * this needs communication, this routine should be called after the SR forces
104 * have been evaluated (in order not to spoil cycle counts).
105 * This routine also outputs data to the various rotation output files (e.g.
106 * the potential, the angle of the group, torques and more).
108 * \param rot Pointer to all the enforced rotation data.
109 * \param f The local forces to which the rotational forces have
110 * to be added.
111 * \param cr Pointer to MPI communication data.
112 * \param step The time step, used for output.
113 * \param t Time, used for output.
115 extern real add_rot_forces(t_rot *rot, rvec f[], t_commrec *cr, int step, real t);
118 /*! \brief Close the enforced rotation output files.
120 * \param fplog General output file, normally md.log.
121 * \param rot Pointer to all the enforced rotation data.
123 extern void finish_rot(FILE *fplog,t_rot *rot);
126 #endif