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.

54 lines
1.8 KiB

25 years ago
25 years ago
25 years ago
25 years ago
25 years ago
25 years ago
  1. // Simple vectors of complex numbers.
  2. #ifndef _CL_SV_COMPLEX_H
  3. #define _CL_SV_COMPLEX_H
  4. #include "cln/number.h"
  5. #include "cln/SV_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_SV<cl_N> cl_heap_SV_N;
  11. struct cl_SV_N : public cl_SV<cl_N,cl_SV_number> {
  12. public:
  13. // Constructors.
  14. cl_SV_N () : cl_SV<cl_N,cl_SV_number> ((cl_heap_SV_N*) (cl_heap_SV_number*) cl_null_SV_number) {};
  15. cl_SV_N (const cl_SV_N&);
  16. explicit cl_SV_N (std::size_t len) : cl_SV<cl_N,cl_SV_number> ((cl_heap_SV_N*) cl_make_heap_SV_number(len)) {};
  17. // Assignment operators.
  18. cl_SV_N& operator= (const cl_SV_N&);
  19. // Private pointer manipulations.
  20. cl_SV_N (cl_heap_SV_N* p) : cl_SV<cl_N,cl_SV_number> (p) {}
  21. cl_SV_N (cl_private_thing p) : cl_SV<cl_N,cl_SV_number> (p) {}
  22. };
  23. inline cl_SV_N::cl_SV_N (const cl_SV_N& x) : cl_SV<cl_N,cl_SV_number> (as_cl_private_thing(x)) {}
  24. CL_DEFINE_ASSIGNMENT_OPERATOR(cl_SV_N,cl_SV_N)
  25. // Copy a simple vector.
  26. inline const cl_SV_N copy (const cl_SV_N& vector)
  27. {
  28. return The(cl_SV_N) (copy((const cl_SV_number&) vector));
  29. }
  30. // Output.
  31. inline void fprint (std::ostream& stream, const cl_SV_N& x)
  32. {
  33. extern cl_print_flags default_print_flags;
  34. 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_SV_number& vector);
  35. extern void print_complex (std::ostream& stream, const cl_print_flags& flags, const cl_N& z);
  36. print_vector(stream, default_print_flags,
  37. (void (*) (std::ostream&, const cl_print_flags&, const cl_number&))
  38. (void (*) (std::ostream&, const cl_print_flags&, const cl_N&))
  39. &print_complex,
  40. x);
  41. }
  42. CL_DEFINE_PRINT_OPERATOR(cl_SV_N)
  43. } // namespace cln
  44. #endif /* _CL_SV_COMPLEX_H */