Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2026-05-19 08:08:30

0001 // General vectors of real numbers.
0002 
0003 #ifndef _CL_GV_REAL_H
0004 #define _CL_GV_REAL_H
0005 
0006 #include "cln/number.h"
0007 #include "cln/GV_complex.h"
0008 #include "cln/real_class.h"
0009 #include "cln/io.h"
0010 
0011 namespace cln {
0012 
0013 // A vector of real numbers is just a normal vector of numbers.
0014 
0015 typedef cl_heap_GV<cl_R> cl_heap_GV_R;
0016 
0017 struct cl_GV_R : public cl_GV<cl_R,cl_GV_N> {
0018 public:
0019     // Constructors.
0020     cl_GV_R ();
0021     cl_GV_R (const cl_GV_R&);
0022     explicit cl_GV_R (std::size_t len);
0023     // Assignment operators.
0024     cl_GV_R& operator= (const cl_GV_R&);
0025     // Private pointer manipulations.
0026     cl_GV_R (cl_heap_GV_R* p) : cl_GV<cl_R,cl_GV_N> (p) {}
0027     cl_GV_R (cl_private_thing p) : cl_GV<cl_R,cl_GV_N> (p) {}
0028 };
0029 inline cl_GV_R::cl_GV_R (const cl_GV_R& x) : cl_GV<cl_R,cl_GV_N> (as_cl_private_thing(x)) {}
0030 CL_DEFINE_ASSIGNMENT_OPERATOR(cl_GV_R,cl_GV_R)
0031 inline cl_GV_R::cl_GV_R (std::size_t len)
0032     : cl_GV<cl_R,cl_GV_N> ((cl_heap_GV_R*) cl_make_heap_GV_number(len)) {}
0033 inline cl_GV_R::cl_GV_R ()
0034     : cl_GV<cl_R,cl_GV_N> ((cl_heap_GV_R*) (cl_heap_GV_number*) cl_null_GV_number) {}
0035 
0036 // Copy a vector.
0037 inline const cl_GV_R copy (const cl_GV_R& vector)
0038 {
0039     return The(cl_GV_R) (copy((const cl_GV_N&) vector));
0040 }
0041 
0042 // Output.
0043 inline void fprint (std::ostream& stream, const cl_GV_R& x)
0044 {
0045     extern cl_print_flags default_print_flags;
0046     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);
0047     extern void print_real (std::ostream& stream, const cl_print_flags& flags, const cl_R& z);
0048     print_vector(stream, default_print_flags,
0049                  (void (*) (std::ostream&, const cl_print_flags&, const cl_number&))
0050                  (void (*) (std::ostream&, const cl_print_flags&, const cl_R&))
0051                  &print_real,
0052                  x);
0053 }
0054 CL_DEFINE_PRINT_OPERATOR(cl_GV_R)
0055 
0056 }  // namespace cln
0057 
0058 #endif /* _CL_GV_REAL_H */