summaryrefslogtreecommitdiff
path: root/src/type/doubleComplex.h
blob: 5434a4f2b6c4d04a973a59280b9e728e013e26d6 (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
70
71
72
73
/*
 *  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>
#ifndef _MSC_VER
#include <stdbool.h>
#endif

#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);
void		zreala(doubleComplex *in, int size, double *out);
void		zimaga(doubleComplex *in, int size, double *out);
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__ */