File indexing completed on 2026-05-19 08:08:33
0001
0002
0003 #ifndef _CL_SV_COMPLEX_H
0004 #define _CL_SV_COMPLEX_H
0005
0006 #include "cln/number.h"
0007 #include "cln/SV_number.h"
0008 #include "cln/complex_class.h"
0009 #include "cln/io.h"
0010
0011 namespace cln {
0012
0013
0014
0015 typedef cl_heap_SV<cl_N> cl_heap_SV_N;
0016
0017 struct cl_SV_N : public cl_SV<cl_N,cl_SV_number> {
0018 public:
0019
0020 cl_SV_N () : cl_SV<cl_N,cl_SV_number> ((cl_heap_SV_N*) (cl_heap_SV_number*) cl_null_SV_number) {};
0021 cl_SV_N (const cl_SV_N&);
0022 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)) {};
0023
0024 cl_SV_N& operator= (const cl_SV_N&);
0025
0026 cl_SV_N (cl_heap_SV_N* p) : cl_SV<cl_N,cl_SV_number> (p) {}
0027 cl_SV_N (cl_private_thing p) : cl_SV<cl_N,cl_SV_number> (p) {}
0028 };
0029 inline cl_SV_N::cl_SV_N (const cl_SV_N& x) : cl_SV<cl_N,cl_SV_number> (as_cl_private_thing(x)) {}
0030 CL_DEFINE_ASSIGNMENT_OPERATOR(cl_SV_N,cl_SV_N)
0031
0032
0033 inline const cl_SV_N copy (const cl_SV_N& vector)
0034 {
0035 return The(cl_SV_N) (copy((const cl_SV_number&) vector));
0036 }
0037
0038
0039 inline void fprint (std::ostream& stream, const cl_SV_N& x)
0040 {
0041 extern cl_print_flags default_print_flags;
0042 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);
0043 extern void print_complex (std::ostream& stream, const cl_print_flags& flags, const cl_N& z);
0044 print_vector(stream, default_print_flags,
0045 (void (*) (std::ostream&, const cl_print_flags&, const cl_number&))
0046 (void (*) (std::ostream&, const cl_print_flags&, const cl_N&))
0047 &print_complex,
0048 x);
0049 }
0050 CL_DEFINE_PRINT_OPERATOR(cl_SV_N)
0051
0052 }
0053
0054 #endif