888 int xkoord, r, rtest, xk, mtest;
892 for ( xkoord= 0; xkoord < anzm; xkoord++ ) {
894 for ( r= 0; r < anzr; r++ ) {
898 for ( xk =0; xk <= xkoord; xk++ )
900 tmp -= (*
roots[xk])[r] *
mu[xkoord]->evPointCoord(xk+1);
904 for ( rtest= r; rtest < anzr; rtest++ ) {
905 zwerg = tmp - (*
roots[xk])[rtest] *
mu[xkoord]->evPointCoord(xk+1);
906 for ( mtest= 0; mtest < anzr; mtest++ )
910 if ( ((zwerg.
real() <= (*
mu[xkoord])[mtest].real() + mprec) &&
911 (zwerg.
real() >= (*
mu[xkoord])[mtest].real() - mprec)) &&
912 ((zwerg.
imag() <= (*
mu[xkoord])[mtest].imag() + mprec) &&
913 (zwerg.
imag() >= (*
mu[xkoord])[mtest].imag() - mprec)) )
923 WarnS(
"rootArranger::arrange: precision lost");
930 Warn(
"rootArranger::arrange: No match? coord %d, root %d.",xkoord,r);
932 WarnS(
"One of these ...");
933 for ( rtest= r; rtest < anzr; rtest++ )
936 for ( xk =0; xk <= xkoord; xk++ )
938 tmp-= (*
roots[xk])[r] *
mu[xkoord]->evPointCoord(xk+1);
940 tmp-= (*
roots[xk])[rtest] *
mu[xkoord]->evPointCoord(xk+1);
943 WarnS(
" ... must match to one of these:");
944 for ( mtest= 0; mtest < anzr; mtest++ )
Rational pow(const Rational &a, int e)
gmp_complex numbers based on
bool swapRoots(const int from, const int to)
EXTERN_VAR size_t gmp_output_digits
char * complexToStr(gmp_complex &c, const unsigned int oprec, const coeffs src)