1 // General vectors of complex numbers.
3 #ifndef _CL_GV_COMPLEX_H
4 #define _CL_GV_COMPLEX_H
7 #include "cl_GV_number.h"
8 #include "cl_complex_class.h"
11 // A vector of complex numbers is just a normal vector of numbers.
13 typedef cl_heap_GV<cl_N> cl_heap_GV_N;
15 struct cl_GV_N : public cl_GV<cl_N,cl_GV_number> {
19 cl_GV_N (const cl_GV_N&);
20 explicit cl_GV_N (uintL len);
21 // Assignment operators.
22 cl_GV_N& operator= (const cl_GV_N&);
23 // Private pointer manipulations.
24 cl_GV_N (cl_heap_GV_N* p) : cl_GV<cl_N,cl_GV_number> (p) {}
25 cl_GV_N (cl_private_thing p) : cl_GV<cl_N,cl_GV_number> (p) {}
27 inline cl_GV_N::cl_GV_N (const cl_GV_N& x) : cl_GV<cl_N,cl_GV_number> (as_cl_private_thing(x)) {}
28 CL_DEFINE_ASSIGNMENT_OPERATOR(cl_GV_N,cl_GV_N)
29 inline cl_GV_N::cl_GV_N (uintL len)
30 : cl_GV<cl_N,cl_GV_number> ((cl_heap_GV_N*) cl_make_heap_GV_number(len)) {}
31 inline cl_GV_N::cl_GV_N ()
32 : cl_GV<cl_N,cl_GV_number> ((cl_heap_GV_N*) (cl_heap_GV_number*) cl_null_GV_number) {}
35 inline const cl_GV_N copy (const cl_GV_N& vector)
37 return The(cl_GV_N) (copy((const cl_GV_number&) vector));
41 inline void fprint (cl_ostream stream, const cl_GV_N& x)
43 extern cl_print_flags cl_default_print_flags;
44 extern void print_vector (cl_ostream stream, const cl_print_flags& flags, void (* fun) (cl_ostream, const cl_print_flags&, const cl_number&), const cl_GV_number& vector);
45 extern void print_complex (cl_ostream stream, const cl_print_flags& flags, const cl_N& z);
46 print_vector(stream, cl_default_print_flags,
47 (void (*) (cl_ostream, const cl_print_flags&, const cl_number&))
48 (void (*) (cl_ostream, const cl_print_flags&, const cl_N&))
52 CL_DEFINE_PRINT_OPERATOR(cl_GV_N)
54 #endif /* _CL_GV_COMPLEX_H */