Fixed segfaults with empty selections.
[gromacs/qmmm-gamess-us.git] / include / shellfc.h
blobe3f8eb77af9d1a77d475b63849466a21b69e73ab
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 /* Initialization function, also predicts the initial shell postions.
42 * If x!=NULL, the shells are predict for the global coordinates x.
44 extern gmx_shellfc_t init_shell_flexcon(FILE *log,
45 gmx_mtop_t *mtop,int nflexcon,
46 rvec *x);
48 /* Get the local shell with domain decomposition */
49 extern void make_local_shells(t_commrec *cr,t_mdatoms *md,
50 gmx_shellfc_t shfc);
52 /* Optimize shell positions */
53 extern int relax_shell_flexcon(FILE *log,t_commrec *cr,bool bVerbose,
54 gmx_large_int_t mdstep,t_inputrec *inputrec,
55 bool bDoNS,int force_flags,
56 bool bStopCM,
57 gmx_localtop_t *top,
58 gmx_mtop_t *mtop,
59 gmx_constr_t constr,
60 gmx_enerdata_t *enerd,t_fcdata *fcd,
61 t_state *state,rvec f[],
62 tensor force_vir,
63 t_mdatoms *md,
64 t_nrnb *nrnb,gmx_wallcycle_t wcycle,
65 t_graph *graph,
66 gmx_groups_t *groups,
67 gmx_shellfc_t shfc,
68 t_forcerec *fr,
69 bool bBornRadii,
70 double t,rvec mu_tot,
71 int natoms,bool *bConverged,
72 gmx_vsite_t *vsite,
73 FILE *fp_field);