/usr/include/givaro/givrnscstor.inl is in libgivaro-dev 3.2.13-1.2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
| 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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 | // ==========================================================================
// $Source: /var/lib/cvs/Givaro/src/kernel/zpz/givrnscstor.inl,v $
// Copyright(c)'94-97 by Givaro Team
// see the copyright file.
// Authors: T. Gaut%ier
// $Id: givrnscstor.inl,v 1.2 2004/10/12 14:36:46 jgdumas Exp $
// ==========================================================================
// Description:
// -- free memory allocated in array !
template<class RING, class Domain>
RNSsystem<RING,Domain>::~RNSsystem()
{}
template<class RING, class Domain>
RNSsystem<RING,Domain>::RNSsystem ()
 : _primes(0), _ck(0)
{}
template<class RING, class Domain>
RNSsystem<RING,Domain>::RNSsystem (const RNSsystem<RING,Domain>& R)
 : _primes(R._primes, givWithCopy()), 
   _ck(R._ck, givWithCopy())
{}
  // -- Array of primes are given
template<class RING, class Domain>
RNSsystem<RING,Domain>::RNSsystem( const RNSsystem<RING,Domain>::domains& inprimes) 
 : _primes(inprimes, givWithCopy()),
   _ck(0)
{
   GIVARO_ASSERT( inprimes.size()>0, "[RNSsystem<RING,Domain>::RNSsystem] bad size of array");
}
  // -- Computes Ck , Ck = (\prod_{i=0}^{k-1} primes[i])^(-1) % primes[k],
  // for k=1..(_sz-1)
template<class RING, class Domain>
void RNSsystem<RING,Domain>::ComputeCk()
{
  if (_ck.size() !=0) return; // -- already computed
  // - reallocation of a new array :
  size_t size = _primes.size();
  _ck.reallocate(size);
//  _ck[0] = Neutral::zero; // -- undefined and never used
  for (size_t k=1; k < size; ++k)
  {
    modulo prod, tmp;
    _primes[k].init(prod, _primes[0].characteristic());
    for (size_t i= 1; i < k; ++i)
        _primes[k].mulin(prod, _primes[k].init(tmp,_primes[i].characteristic()));
    _primes[k].inv(_ck[k],  prod);
  }
}
template<class RING, class Domain>
const typename RNSsystem<RING,Domain>::domains& RNSsystem<RING,Domain>::Primes() const
{ 
  return _primes; 
}
template<class RING, class Domain>
const Domain RNSsystem<RING,Domain>::ith(const size_t i) const
{
  return _primes[i];
}
template<class RING, class Domain>
const typename RNSsystem<RING,Domain>::array& RNSsystem<RING,Domain>::Reciprocals() const
{
  if (_ck.size() ==0) ((RNSsystem<RING,Domain>*)this)->ComputeCk();
  return _ck;
}
template<class RING, class Domain>
const typename RNSsystem<RING,Domain>::modulo RNSsystem<RING,Domain>::reciprocal(const size_t i) const
{
  if (_ck.size() ==0) ((RNSsystem<RING,Domain>*)this)->ComputeCk();
  return _ck[i];
}
 |