1 // This may look like C code, but it is really -*- C++ -*-
3 Copyright (C) 1988 Free Software Foundation
4 written by Doug Lea (dl@rocky.oswego.edu)
6 This file is part of GNU CC.
8 GNU CC is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY. No author or distributor
10 accepts responsibility to anyone for the consequences of using it
11 or for whether it serves any particular purpose or works at all,
12 unless he says so in writing. Refer to the GNU CC General Public
13 License for full details.
15 Everyone is granted permission to copy, modify and redistribute
16 GNU CC, but only under the conditions described in the
17 GNU CC General Public License. A copy of this license is
18 supposed to have been given to you along with GNU CC so you
19 can know your rights and responsibilities. It should be in a
20 file named COPYING. Among other things, the copyright notice
21 and this notice must be preserved on all copies.
37 #ifdef __ATT_complex__
52 Complex(const Complex
& y
);
53 Complex(double r
, double i
=0);
57 Complex
& operator = (const Complex
& y
);
59 Complex
& operator += (const Complex
& y
);
60 Complex
& operator += (double y
);
61 Complex
& operator -= (const Complex
& y
);
62 Complex
& operator -= (double y
);
63 Complex
& operator *= (const Complex
& y
);
64 Complex
& operator *= (double y
);
66 Complex
& operator /= (const Complex
& y
);
67 Complex
& operator /= (double y
);
69 void error(const char* msg
) const;
75 extern void default_Complex_error_handler(const char*);
76 extern one_arg_error_handler_t Complex_error_handler
;
78 extern one_arg_error_handler_t
79 set_Complex_error_handler(one_arg_error_handler_t f
);
82 // non-inline functions
84 Complex
operator / (const Complex
& x
, const Complex
& y
);
85 Complex
operator / (const Complex
& x
, double y
);
86 Complex
operator / (double x
, const Complex
& y
);
88 Complex
cos(const Complex
& x
);
89 Complex
sin(const Complex
& x
);
91 Complex
cosh(const Complex
& x
);
92 Complex
sinh(const Complex
& x
);
94 Complex
exp(const Complex
& x
);
95 Complex
log(const Complex
& x
);
97 Complex
pow(const Complex
& x
, long p
);
98 Complex
pow(const Complex
& x
, const Complex
& p
);
99 Complex
pow(const Complex
& x
, double y
);
100 Complex
sqrt(const Complex
& x
);
102 istream
& operator >> (istream
& s
, Complex
& x
);
103 ostream
& operator << (ostream
& s
, const Complex
& x
);
105 // other functions defined as inlines
107 int operator == (const Complex
& x
, const Complex
& y
);
108 int operator == (const Complex
& x
, double y
);
109 int operator != (const Complex
& x
, const Complex
& y
);
110 int operator != (const Complex
& x
, double y
);
112 Complex
operator - (const Complex
& x
);
113 Complex
conj(const Complex
& x
);
114 Complex
operator + (const Complex
& x
, const Complex
& y
);
115 Complex
operator + (const Complex
& x
, double y
);
116 Complex
operator + (double x
, const Complex
& y
);
117 Complex
operator - (const Complex
& x
, const Complex
& y
);
118 Complex
operator - (const Complex
& x
, double y
);
119 Complex
operator - (double x
, const Complex
& y
);
120 Complex
operator * (const Complex
& x
, const Complex
& y
);
121 Complex
operator * (const Complex
& x
, double y
);
122 Complex
operator * (double x
, const Complex
& y
);
124 double real(const Complex
& x
);
125 double imag(const Complex
& x
);
126 double abs(const Complex
& x
);
127 double norm(const Complex
& x
);
128 double arg(const Complex
& x
);
130 Complex
polar(double r
, double t
= 0.0);
132 #if defined(__OPTIMIZE__) || defined(USE_LIBGXX_INLINES)
136 inline double Complex::real() const { return re
; }
137 inline double Complex::imag() const { return im
; }
139 inline Complex::Complex() {}
140 inline Complex::Complex(const Complex
& y
) :re(y
.real()), im(y
.imag()) {}
141 inline Complex::Complex(double r
, double i
) :re(r
), im(i
) {}
143 inline Complex::~Complex() {}
145 inline Complex
& Complex::operator = (const Complex
& y
)
147 re
= y
.real(); im
= y
.imag(); return *this;
150 inline Complex
& Complex::operator += (const Complex
& y
)
152 re
+= y
.real(); im
+= y
.imag(); return *this;
155 inline Complex
& Complex::operator += (double y
)
157 re
+= y
; return *this;
160 inline Complex
& Complex::operator -= (const Complex
& y
)
162 re
-= y
.real(); im
-= y
.imag(); return *this;
165 inline Complex
& Complex::operator -= (double y
)
167 re
-= y
; return *this;
170 inline Complex
& Complex::operator *= (const Complex
& y
)
172 double r
= re
* y
.real() - im
* y
.imag();
173 im
= re
* y
.imag() + im
* y
.real();
178 inline Complex
& Complex::operator *= (double y
)
180 re
*= y
; im
*= y
; return *this;
186 inline int operator == (const Complex
& x
, const Complex
& y
)
188 return x
.real() == y
.real() && x
.imag() == y
.imag();
191 inline int operator == (const Complex
& x
, double y
)
193 return x
.imag() == 0.0 && x
.real() == y
;
196 inline int operator != (const Complex
& x
, const Complex
& y
)
198 return x
.real() != y
.real() || x
.imag() != y
.imag();
201 inline int operator != (const Complex
& x
, double y
)
203 return x
.imag() != 0.0 || x
.real() != y
;
206 inline Complex
operator - (const Complex
& x
)
208 return Complex(-x
.real(), -x
.imag());
211 inline Complex
conj(const Complex
& x
)
213 return Complex(x
.real(), -x
.imag());
216 inline Complex
operator + (const Complex
& x
, const Complex
& y
)
218 return Complex(x
.real() + y
.real(), x
.imag() + y
.imag());
221 inline Complex
operator + (const Complex
& x
, double y
)
223 return Complex(x
.real() + y
, x
.imag());
226 inline Complex
operator + (double x
, const Complex
& y
)
228 return Complex(x
+ y
.real(), y
.imag());
231 inline Complex
operator - (const Complex
& x
, const Complex
& y
)
233 return Complex(x
.real() - y
.real(), x
.imag() - y
.imag());
236 inline Complex
operator - (const Complex
& x
, double y
)
238 return Complex(x
.real() - y
, x
.imag());
241 inline Complex
operator - (double x
, const Complex
& y
)
243 return Complex(x
- y
.real(), -y
.imag());
246 inline Complex
operator * (const Complex
& x
, const Complex
& y
)
248 return Complex(x
.real() * y
.real() - x
.imag() * y
.imag(),
249 x
.real() * y
.imag() + x
.imag() * y
.real());
252 inline Complex
operator * (const Complex
& x
, double y
)
254 return Complex(x
.real() * y
, x
.imag() * y
);
257 inline Complex
operator * (double x
, const Complex
& y
)
259 return Complex(x
* y
.real(), x
* y
.imag());
262 inline double real(const Complex
& x
)
267 inline double imag(const Complex
& x
)
272 inline double abs(const Complex
& x
)
274 return hypot(x
.real(), x
.imag());
277 inline double norm(const Complex
& x
)
279 return (x
.real() * x
.real() + x
.imag() * x
.imag());
282 inline double arg(const Complex
& x
)
284 return atan2(x
.imag(), x
.real());
287 inline Complex
polar(double r
, double t
)
289 return Complex(r
* cos(t
), r
* sin(t
));