You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

58 lines
1.9 KiB

25 years ago
25 years ago
25 years ago
25 years ago
25 years ago
25 years ago
25 years ago
  1. // General vectors of complex numbers.
  2. #ifndef _CL_GV_COMPLEX_H
  3. #define _CL_GV_COMPLEX_H
  4. #include "cln/number.h"
  5. #include "cln/GV_number.h"
  6. #include "cln/complex_class.h"
  7. #include "cln/io.h"
  8. namespace cln {
  9. // A vector of complex numbers is just a normal vector of numbers.
  10. typedef cl_heap_GV<cl_N> cl_heap_GV_N;
  11. struct cl_GV_N : public cl_GV<cl_N,cl_GV_number> {
  12. public:
  13. // Constructors.
  14. cl_GV_N ();
  15. cl_GV_N (const cl_GV_N&);
  16. explicit cl_GV_N (std::size_t len);
  17. // Assignment operators.
  18. cl_GV_N& operator= (const cl_GV_N&);
  19. // Private pointer manipulations.
  20. cl_GV_N (cl_heap_GV_N* p) : cl_GV<cl_N,cl_GV_number> (p) {}
  21. cl_GV_N (cl_private_thing p) : cl_GV<cl_N,cl_GV_number> (p) {}
  22. };
  23. inline cl_GV_N::cl_GV_N (const cl_GV_N& x) : cl_GV<cl_N,cl_GV_number> (as_cl_private_thing(x)) {}
  24. CL_DEFINE_ASSIGNMENT_OPERATOR(cl_GV_N,cl_GV_N)
  25. inline cl_GV_N::cl_GV_N (std::size_t len)
  26. : cl_GV<cl_N,cl_GV_number> ((cl_heap_GV_N*) cl_make_heap_GV_number(len)) {}
  27. inline cl_GV_N::cl_GV_N ()
  28. : cl_GV<cl_N,cl_GV_number> ((cl_heap_GV_N*) (cl_heap_GV_number*) cl_null_GV_number) {}
  29. // Copy a vector.
  30. inline const cl_GV_N copy (const cl_GV_N& vector)
  31. {
  32. return The(cl_GV_N) (copy((const cl_GV_number&) vector));
  33. }
  34. // Output.
  35. inline void fprint (std::ostream& stream, const cl_GV_N& x)
  36. {
  37. extern cl_print_flags default_print_flags;
  38. extern void print_vector (std::ostream& stream, const cl_print_flags& flags, void (* fun) (std::ostream&, const cl_print_flags&, const cl_number&), const cl_GV_number& vector);
  39. extern void print_complex (std::ostream& stream, const cl_print_flags& flags, const cl_N& z);
  40. print_vector(stream, default_print_flags,
  41. (void (*) (std::ostream&, const cl_print_flags&, const cl_number&))
  42. (void (*) (std::ostream&, const cl_print_flags&, const cl_N&))
  43. &print_complex,
  44. x);
  45. }
  46. CL_DEFINE_PRINT_OPERATOR(cl_GV_N)
  47. } // namespace cln
  48. #endif /* _CL_GV_COMPLEX_H */