Skip to content

Commit

Permalink
const_cast missing
Browse files Browse the repository at this point in the history
faster empty init
  • Loading branch information
jgdumas committed Jan 26, 2024
1 parent 79e72bf commit b8f2d4c
Show file tree
Hide file tree
Showing 6 changed files with 104 additions and 92 deletions.
10 changes: 5 additions & 5 deletions linbox/algorithms/gauss/gauss-nullspace.inl
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
* Copyright (C) LinBox 2008
*
* Written by Jean-Guillaume Dumas <Jean-Guillaume.Dumas@imag.fr>
* Time-stamp: <12 Dec 23 13:13:38 Jean-Guillaume.Dumas@imag.fr>
* Time-stamp: <26 Jan 24 16:05:55 Jean-Guillaume.Dumas@imag.fr>
*
*
* ========LICENCE========
Expand Down Expand Up @@ -104,11 +104,11 @@ namespace LinBox

Permutation<Field> P(field(),(int)Nj);

// A.write( std::cerr << "A:=", Tag::FileFormat::Maple ) << ';' << std::endl;
// A.write( std::cerr << "A:=", Tag::FileFormat::Maple ) << ';' << std::endl;
this->InPlaceLinearPivoting(Rank, Det, A, P, Ni, Nj );

// P.write( std::cerr << "P:=", Tag::FileFormat::Maple ) << ';' << std::endl;
// A.write( std::cerr << "Ua:=", Tag::FileFormat::Maple ) << ';' << std::endl;
// P.write( std::cerr << "P:=", Tag::FileFormat::Maple ) << ';' << std::endl;
// A.write( std::cerr << "Ua:=", Tag::FileFormat::Maple ) << ';' << std::endl;

for(size_t i=0; i< Ni; ++i) {
if (A[i].size() == 0) {
Expand All @@ -123,7 +123,7 @@ namespace LinBox
}
}

// A.write( std::cerr << "Ub:=", Tag::FileFormat::Maple ) << ';' << std::endl;
// A.write( std::cerr << "Ub:=", Tag::FileFormat::Maple ) << ';' << std::endl;

return this->nullspacebasis(x, Rank, A, P);
}
Expand Down
8 changes: 4 additions & 4 deletions linbox/matrix/sparsematrix/sparse-ell-matrix.h
Original file line number Diff line number Diff line change
Expand Up @@ -1210,10 +1210,10 @@ namespace LinBox
_colid_beg = iter._colid_beg ;
_colid_it = iter._colid_it ;
_data_it = iter._data_it ;
_data_beg = iter._data_beg ;
_data_end = iter._data_end ;
_field = iter._field ;
_ld = iter._ld ;
const_cast<data_it>(_data_beg) = iter._data_beg ;
const_cast<data_it>(_data_end) = iter._data_end ;
const_cast<Field &>(_field) = iter._field ;
const_cast<size_t&>(ld) = iter._ld ;
_row = iter._row ;

return *this;
Expand Down
18 changes: 9 additions & 9 deletions linbox/matrix/sparsematrix/sparse-ellr-matrix.h
Original file line number Diff line number Diff line change
Expand Up @@ -1102,11 +1102,11 @@ namespace LinBox
_Iterator &operator = (const _Iterator &iter)
{
_data_it = iter._data_it ;
_data_beg = iter._data_beg ;
_data_end = iter._data_end ;
_field = iter._field ;
_rowid = iter._rowid;
_ld = iter._ld ;
const_cast<element_iterator>(_data_beg) = iter._data_beg ;
const_cast<element_iterator>(_data_end)= iter._data_end ;
const_cast<Field &>(_field) = iter._field ;
const_cast<std::vector<size_t>&>(_rowid) = iter._rowid;
const_cast<size_t&>(ld) = iter._ld ;
_row = iter._row ;

return *this;
Expand Down Expand Up @@ -1252,10 +1252,10 @@ namespace LinBox
_colid_beg = iter._colid_beg ;
_colid_it = iter._colid_it ;
_data_it = iter._data_it ;
_data_beg = iter._data_beg ;
_data_end = iter._data_end ;
_field = iter._field ;
_ld = iter._ld ;
const_cast<data_it>(_data_beg) = iter._data_beg ;
const_cast<data_it>(_data_end) = iter._data_end ;
const_cast<Field &>(_field) = iter._field ;
const_cast<size_t&>(ld)= iter._ld ;
_row = iter._row ;

return *this;
Expand Down
11 changes: 8 additions & 3 deletions linbox/ring/ntl/ntl-lzz_p.h
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ namespace Givaro
* @param x reference to Integer to contain output (reference returned).
* @param y constant reference to field element.
*/
template <>
template <>
Integer& Caster(Integer& x, const NTL::zz_p& y)
{
return x = int64_t(rep(y));
Expand Down Expand Up @@ -130,7 +130,7 @@ namespace LinBox
typedef NTL::zz_p Element ;
typedef Givaro::UnparametricOperations<Element> Father_t ;
typedef UnparametricRandIter<NTL::zz_p> RandIter;

const Element zero,one,mOne ;


Expand All @@ -145,6 +145,11 @@ namespace LinBox
,zero( NTL::to_zz_p(0)),one( NTL::to_zz_p(1)),mOne(-one)
{}

Element &init (Element &x) const
{
return x = NTL::to_zz_p(0);
}

Element& init(Element& x, const double& y) const
{
double z = fmod(y,(double)Element::modulus());
Expand All @@ -153,7 +158,7 @@ namespace LinBox
return x = NTL::to_zz_p(static_cast<long>(z)); //rounds towards 0
}

Element &init (Element &x, const integer &y=0) const
Element &init (Element &x, const integer &y) const
{
NTL::ZZ tmp= NTL::to_ZZ(std::string(y).data());
return x = NTL::to_zz_p(tmp);
Expand Down
143 changes: 72 additions & 71 deletions linbox/ring/ntl/ntl-lzz_pe.h
Original file line number Diff line number Diff line change
Expand Up @@ -96,18 +96,18 @@ namespace LinBox
NTL::zz_pE::init(irredPoly);
_f = irredPoly;
}

NTL_zz_pE_Initialiser( const Integer & p, const NTL::zz_pX & f) {
NTL::zz_p::init((int64_t) p);
NTL::zz_pE::init(f);
_f = f;
}

NTL_zz_pE_Initialiser(const NTL::zz_pX &f) {
NTL::zz_pE::init(f);
_f = f;
}

const NTL::zz_pX& modulus() const {
return _f;
}
Expand Down Expand Up @@ -143,22 +143,22 @@ namespace LinBox
NTL_zz_pE (const integer &p, const integer &k) :
NTL_zz_pE_Initialiser(p,k),Father_t ()
{
init(const_cast<Element &>(zero), 0);
init(const_cast<Element &>(one), 1);
init(const_cast<Element &>(mOne), p-1);
init(const_cast<Element &>(zero), 0);
init(const_cast<Element &>(one), 1);
init(const_cast<Element &>(mOne), p-1);
}

NTL_zz_pE (const integer &p, const NTL::zz_pX &f) :
NTL_zz_pE_Initialiser(p,f), Father_t()
{
init(const_cast<Element &>(zero), 0);
init(const_cast<Element &>(one), 1);
init(const_cast<Element &>(mOne), p-1);
init(const_cast<Element &>(one), 1);
init(const_cast<Element &>(mOne), p-1);
}

NTL_zz_pE(const NTL_zz_pE &F) :
NTL_zz_pE_Initialiser(F.modulus()), Father_t(),
zero(NTL::to_zz_pE(0)), one(NTL::to_zz_pE(1)), mOne(-one)
NTL_zz_pE_Initialiser(F.modulus()), Father_t(),
zero(NTL::to_zz_pE(0)), one(NTL::to_zz_pE(1)), mOne(-one)
{
}

Expand All @@ -182,15 +182,15 @@ namespace LinBox

bool isUnit (const Element& x) const
{
if (isZero(x)) {
return false;
}
NTL::zz_pX g, tmp;
tmp = NTL::conv<NTL::zz_pX>(x);
NTL::GCD(g, tmp, modulus());
return g == 1;
if (isZero(x)) {
return false;
}

NTL::zz_pX g, tmp;
tmp = NTL::conv<NTL::zz_pX>(x);
NTL::GCD(g, tmp, modulus());

return g == 1;
}

bool isMOne (const Element& x) const
Expand All @@ -207,22 +207,24 @@ namespace LinBox
return f;
}

Element & init(Element & x, integer n = 0) const
Element & init(Element & x) const { return x; }

Element & init(Element & x, integer n) const
{ // assumes n >= 0.
int e = exponent();
n %= cardinality();
init(const_cast<NTL::zz_pX &>(rep(x)), n, e);
//write(std::cout << "init-ed ", x) << std::endl;
return x;
}

// documentation of NTL::conv:
// http://www.shoup.net/ntl/doc/conversions.txt
// XXX = long, ZZ, ZZ_p, ZZ_pE, ZZ_pX
template<class XXX>
Element &init(Element &x, const XXX &y) const {
x = NTL::conv<NTL::zz_pE>(y);
return x;
x = NTL::conv<NTL::zz_pE>(y);
return x;
}

integer & convert(integer & x, const Element & y) const
Expand Down Expand Up @@ -279,81 +281,80 @@ namespace LinBox
x=one/x;
return x;
}

Element& div(Element &x, const Element &y, const Element &z) const {
NTL::zz_pX g, zx;
conv(zx, z);
NTL::GCD(g, zx, modulus());
NTL::zz_pE zg;
conv(zg, zx / g);
x = NTL::conv<NTL::zz_pE>(NTL::conv<NTL::zz_pX>(y) / g);
x /= zg;
return x;
NTL::zz_pX g, zx;
conv(zx, z);
NTL::GCD(g, zx, modulus());

NTL::zz_pE zg;
conv(zg, zx / g);
x = NTL::conv<NTL::zz_pE>(NTL::conv<NTL::zz_pX>(y) / g);
x /= zg;

return x;
}

Element& divin(Element &x, const Element &y) const {
Element r;
div(r, x, y);
return x = r;
Element r;
div(r, x, y);
return x = r;
}

bool isDivisor(const Element &x, const Element &y) const {
if (isZero(y)) {
return false;
}

if (isUnit(y)) {
return true;
}

NTL::zz_pX a, b;
conv(a, x);
conv(b, y);

NTL::zz_pX ga, gb;
NTL::GCD(ga, a, modulus());
NTL::GCD(gb, b, modulus());

NTL::zz_pX r;
r = ga % gb;
return isZero(NTL::conv<Element>(r));
if (isZero(y)) {
return false;
}

if (isUnit(y)) {
return true;
}

NTL::zz_pX a, b;
conv(a, x);
conv(b, y);

NTL::zz_pX ga, gb;
NTL::GCD(ga, a, modulus());
NTL::GCD(gb, b, modulus());
NTL::zz_pX r;
r = ga % gb;
return isZero(NTL::conv<Element>(r));
}

Element& gcd(Element &g, const Element &a, const Element &b) const {
NTL::zz_pX r1, r2, x, y;
conv(x, a);
conv(y, b);

NTL::GCD(r1, x, modulus());
NTL::GCD(r2, y, r1);

return g = NTL::conv<Element>(r2);
}

Element& gcdin(Element &a, const Element &b) const {
NTL::zz_pE g;
gcd(g, a, b);
return a = g;
}

Element& dxgcd(Element &g, Element &s, Element &t, Element &u, Element &v, const Element &a, const Element &b) const {
NTL::zz_pX gx, sx, tx, ux, vx, ax, bx;
conv(ax, a);
conv(bx, b);

NTL::XGCD(gx, sx, tx, ax, bx);

ux = ax / gx;
vx = bx / gx;

conv(g, gx);
conv(s, sx);
conv(t, tx);
conv(u, ux);
conv(v, vx);

return g;
}

Expand All @@ -364,12 +365,12 @@ namespace LinBox
x=NTL::to_zz_pE(tmp);
return is;
}

std::ostream& write( std::ostream& os ) const
{
return os << "Polynomial quotient ring using NTL::zz_pE";
}

std::ostream& write( std::ostream& os, const Element& x) const {
os << x;
return os;
Expand Down Expand Up @@ -429,7 +430,7 @@ namespace LinBox
uint64_t _seed;
const NTL_zz_pE& _ring;
}; // class UnparametricRandIters

} // LinBox

#endif //__LINBOX_ntl_lzz_pe_H
Expand Down
6 changes: 6 additions & 0 deletions linbox/ring/ntl/ntl-zz_px.h
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,12 @@ namespace LinBox
,_CField(cf)
{}

/** Initialize p to 0 */
Element& init( Element& p ) const
{
return p = 0;
}

/** Initialize p to the constant y (p = y*x^0) */
template <class ANY>
Element& init( Element& p, const ANY& y ) const
Expand Down

0 comments on commit b8f2d4c

Please sign in to comment.