1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
|
// General vectors of modular integers.
#ifndef _CL_GV_MODINTEGER_H
#define _CL_GV_MODINTEGER_H
#include "cl_modinteger.h"
#include "cl_GV_integer.h"
#include "cl_io.h"
// A vector of modular integers (over the same modular integer ring)
// is just a normal vector of integers, with maxbits() operation.
#ifdef HAVE_TEMPLATE_NULL
template <>
#endif
struct cl_heap_GV<_cl_MI> : cl_heap {
cl_GV_inner<_cl_MI> v;
// here room for the elements
};
typedef cl_heap_GV<_cl_MI> cl_heap_GV_MI;
struct cl_GV_MI : public cl_GV<_cl_MI,cl_GV_any> {
public:
// Constructors.
cl_GV_MI ();
cl_GV_MI (const cl_GV_MI&);
// Create a vector of modular integers.
cl_GV_MI (uintL len, cl_heap_modint_ring* R);
// Assignment operators.
cl_GV_MI& operator= (const cl_GV_MI&);
// Number m of bits allowed per element (-1 if unconstrained).
sintL maxbits () const
{
return ((const cl_heap_GV_I *) pointer)->maxbits();
}
};
inline cl_GV_MI::cl_GV_MI (const cl_GV_MI& x) : cl_GV<_cl_MI,cl_GV_any> (as_cl_private_thing(x)) {}
CL_DEFINE_ASSIGNMENT_OPERATOR(cl_GV_MI,cl_GV_MI)
inline cl_GV_MI::cl_GV_MI ()
: cl_GV<_cl_MI,cl_GV_any> ((cl_heap_GV_MI*) (cl_heap_GV_I*) cl_null_GV_I) {}
inline cl_GV_MI::cl_GV_MI (uintL len, cl_heap_modint_ring* R)
: cl_GV<_cl_MI,cl_GV_any> ((cl_heap_GV_MI*) cl_make_heap_GV_I(len,R->bits)) {}
// Copy a vector.
inline cl_GV_MI copy (const cl_GV_MI& vector)
{
return The(cl_GV_MI) (copy((const cl_GV_I&) vector));
}
#endif /* _CL_GV_MODINTEGER_H */
|