summaryrefslogtreecommitdiff
path: root/src/type/doubleComplex.h
blob: a8934b5027d33c60aed3c1834d3707a0e0f9f60b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 *  Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
 *  Copyright (C) 2006-2008 - INRIA - Bruno JOFRET
 *
 *  This file must be used under the terms of the CeCILL.
 *  This source file is licensed as described in the file COPYING, which
 *  you should have received as part of this distribution.  The terms
 *  are also available at
 *  http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
 *
 */

#ifndef __DOUBLECOMPLEX_H__
#define __DOUBLECOMPLEX_H__

#ifdef __STDC_VERSION__
#  ifndef STDC
#    define STDC
#  endif
#  if __STDC_VERSION__ >= 199901L
#    ifndef STDC99
#      define STDC99
#    endif
#  endif
#endif

#include <stdlib.h>
#include <stdbool.h>

#ifndef STDC99
/*
** Hand made Double Complex definition
** {
*/
struct  double_complex
{
  double real;
  double imag;
};

typedef struct double_complex doubleComplex;
/*
** }
*/
#else
/*
** Standard C99 Complex
** {
*/
#include <complex.h>

typedef double complex doubleComplex;
/*
** }
*/
#endif

double		zreals(doubleComplex);
double		zimags(doubleComplex);
doubleComplex	DoubleComplex(double, double);
doubleComplex*	DoubleComplexMatrix(double*, double*, int);
bool		zisreals(doubleComplex);
bool		zisimags(doubleComplex);

doubleComplex	zadds(doubleComplex, doubleComplex);
doubleComplex	zdiffs(doubleComplex, doubleComplex);
doubleComplex	ztimess(doubleComplex, doubleComplex);
doubleComplex	zdevides(doubleComplex, doubleComplex);
#endif /* !__DOUBLECOMPLEX_H__ */