#include <iostream>
#include <givaro/gfq.h>
#include <givaro/StaticElement.h>
{
typedef GFqDom<int64_t>
Field;
template<>
Field Element::_domain(2);
}
int main(int argc, char ** argv) {
uint64_t P = (argc>1 ? (uint64_t)atoi(argv[1]) : 5009U);
Element::setDomain(
Field(P) );
Element a(2),b(-29.8),c(33),d(Integer("123456789012345678901234567890"));
a = b; std::cerr << a << " = " << b << " mod " << P << ";" << std::endl;
a = b + c; std::cerr << a << " = " << b << " + " << c << " mod " << P << ";" << std::endl;
a = b - c; std::cerr << a << " = " << b << " - " << c << " mod " << P << ";" << std::endl;
a = b * c; std::cerr << a << " = " << b << " * " << c << " mod " << P << ";" << std::endl;
a = b / c; std::cerr << a << " = " << b << " / " << c << " mod " << P << ";" << std::endl;
std::cerr << d << " + " << a << " mod " << P << " = ";
d += a; std::cerr << d << ";" << std::endl;
std::cerr << d << " - " << a << " mod " << P << " = ";
d -= a; std::cerr << d << ";" << std::endl;
std::cerr << d << " * " << a << " mod " << P << " = ";
d *= a; std::cerr << d << ";" << std::endl;
std::cerr << d << " / " << a << " mod " << P << " = ";
d /= a; std::cerr << d << ";" << std::endl;
const Element zero(0);
std::cerr << a << " is non zero is " << (a != zero ) << std::endl;
std::cerr << a << " is non zero is " << (! Element::isZero(a)) << std::endl;
std::cerr << a << " is non zero is " << (! a.isZero()) << std::endl;
a = 0; std::cerr << a << " is zero is " << (a == zero ) << std::endl;
std::cerr << a << " is zero is " << Element::isZero(a) << std::endl;
std::cerr << a << " is zero is " << a.isZero() << std::endl;
const Field & F = Element::getDomain();
F.
write( std::cerr <<
"Test: within ") << std::endl;
return 0;
}
Namespace in which the whole Givaro library resides.
Definition: all_field.C:23