Merge branch 'master' of git@git.gromacs.org:gromacs
[gromacs/rigid-bodies.git] / include / shellfc.h
blob0a6c8f4823a67a7f22fbf59cb37a733bb4e1d778
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 #ifdef HAVE_CONFIG_H
36 #include<config.h>
37 #endif
39 #include "typedefs.h"
41 #ifdef __cplusplus
42 extern "C" {
43 #endif
45 /* Initialization function, also predicts the initial shell postions.
46 * If x!=NULL, the shells are predict for the global coordinates x.
48 extern gmx_shellfc_t init_shell_flexcon(FILE *log,
49 gmx_mtop_t *mtop,int nflexcon,
50 rvec *x);
52 /* Get the local shell with domain decomposition */
53 extern void make_local_shells(t_commrec *cr,t_mdatoms *md,
54 gmx_shellfc_t shfc);
56 /* Optimize shell positions */
57 extern int relax_shell_flexcon(FILE *log,t_commrec *cr,bool bVerbose,
58 gmx_large_int_t mdstep,t_inputrec *inputrec,
59 bool bDoNS,int force_flags,
60 bool bStopCM,
61 gmx_localtop_t *top,
62 gmx_mtop_t *mtop,
63 gmx_constr_t constr,
64 gmx_enerdata_t *enerd,t_fcdata *fcd,
65 t_state *state,rvec f[],
66 tensor force_vir,
67 t_mdatoms *md,
68 t_nrnb *nrnb,gmx_wallcycle_t wcycle,
69 t_graph *graph,
70 gmx_groups_t *groups,
71 gmx_shellfc_t shfc,
72 t_forcerec *fr,
73 bool bBornRadii,
74 double t,rvec mu_tot,
75 int natoms,bool *bConverged,
76 gmx_vsite_t *vsite,
77 FILE *fp_field);
80 #ifdef __cplusplus
82 #endif