4 * This source code is part of
8 * GROningen MAchine for Chemical Simulations
11 * Copyright (c) 1991-2001, University of Groningen, The Netherlands
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * If you want to redistribute modifications, please consider that
18 * scientific software is very special. Version control is crucial -
19 * bugs must be traceable. We will be happy to consider code for
20 * inclusion in the official distribution, but derived work must not
21 * be called official GROMACS. Details are found in the README & COPYING
22 * files - if they are missing, get the official version at www.gromacs.org.
24 * To help us fund GROMACS development, we humbly ask that you cite
25 * the papers on the package - you can find them in the top README file.
27 * For more info, check our website at http://www.gromacs.org
35 static char *SRCID_complex_h
= "$Id$";
48 typedef t_complex cvec
[DIM
];
50 static t_complex cnul
= { 0.0, 0.0 };
52 static t_complex
rcmul(real r
,t_complex c
)
62 static t_complex
rcexp(real r
)
73 static t_complex
cadd(t_complex a
,t_complex b
)
83 static t_complex
csub(t_complex a
,t_complex b
)
93 static t_complex
cmul(t_complex a
,t_complex b
)
97 c
.re
= a
.re
*b
.re
- a
.im
*b
.im
;
98 c
.im
= a
.re
*b
.im
+ a
.im
*b
.re
;
103 static t_complex
conjugate(t_complex c
)
113 static t_complex
cdiv(t_complex teller
,t_complex noemer
)
115 t_complex res
,anoemer
;
117 anoemer
= cmul(conjugate(noemer
),noemer
);
118 res
= cmul(teller
,conjugate(noemer
));
120 return rcmul(1.0/anoemer
.re
,res
);