// truncate2(). // General includes. #include "cl_sysdep.h" // Specification. #include "cln/integer.h" // Implementation. #include "cl_I.h" namespace cln { const cl_I_div_t truncate2 (const cl_I& x, const cl_I& y) { // Methode: // (truncate x y) :== // (DIVIDE (abs x) (abs y)) -> q,r // Falls x<0, setze r:=-r. // Falls x,y verschiedene Vorzeichen haben, setze q:=-q. // Liefere q,r. var cl_I_div_t q_r = cl_divide(abs(x),abs(y)); var cl_I& q = q_r.quotient; var cl_I& r = q_r.remainder; if (minusp(x)) { r = -r; } if (minusp(x) != minusp(y)) { q = -q; } return q_r; } } // namespace cln