X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?a=blobdiff_plain;f=check%2Fcheck_numeric.cpp;h=f9a7203eb5d688b7584744fe5b95946a6f450c81;hb=8fa654f2637fa755e890499ece1a7bc498779ea3;hp=ae15454566d77c9c855b92b87e01f273501b0275;hpb=05c47b615d0d309d4868c688cd26f68376fa4277;p=ginac.git diff --git a/check/check_numeric.cpp b/check/check_numeric.cpp index ae154545..f9a7203e 100644 --- a/check/check_numeric.cpp +++ b/check/check_numeric.cpp @@ -4,7 +4,7 @@ * tests on these numbers like is_integer() etc... */ /* - * GiNaC Copyright (C) 1999-2001 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2010 Johannes Gutenberg University Mainz, Germany * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -18,14 +18,19 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ -#include "checks.h" +#include "ginac.h" +using namespace GiNaC; + +#include // for rand() +#include +using namespace std; /* Simple and maybe somewhat pointless consistency tests of assorted tests and * conversions. */ -static unsigned check_numeric1(void) +static unsigned check_numeric1() { unsigned result = 0; bool errorflag = false; @@ -53,7 +58,7 @@ static unsigned check_numeric1(void) return result; } -static unsigned check_numeric2(void) +static unsigned check_numeric2() { unsigned result = 0; bool errorflag = false; @@ -66,22 +71,32 @@ static unsigned check_numeric2(void) numeric nm(1,j); nm += numeric(int(20.0*rand()/(RAND_MAX+1.0))-10); // ...a numerator... - do { i_num = rand(); } while (i_num == 0); + do { + i_num = rand(); + } while (i_num<=0); numeric num(i_num); // ...and a denominator. - do { i_den = (rand())/100; } while (i_den == 0); + do { + i_den = (rand())/100; + } while (i_den<=0); numeric den(i_den); // construct the radicals: ex radical = pow(ex(num)/ex(den),ex(nm)); numeric floating = pow(num/den,nm); // test the result: if (is_a(radical)) { - clog << "(" << num << "/" << den << ")^(" << nm - << ") should have been a product, instead it's " - << radical << endl; - errorflag = true; + // This is very improbable with decent random numbers but it + // still can happen, so we better check if it is correct: + if (pow(radical,inverse(nm))==num/den) { + // Aha! We drew some lucky numbers. Nothing to see here... + } else { + clog << "(" << num << "/" << den << ")^(" << nm + << ") should have been a product, instead it's " + << radical << endl; + errorflag = true; + } } - numeric ratio = ex_to(abs(evalf(radical)))/floating; + numeric ratio = abs(ex_to(evalf(radical))/floating); if (ratio>1.0001 && ratio<0.9999) { clog << "(" << num << "/" << den << ")^(" << nm << ") erroneously evaluated to " << radical; @@ -95,7 +110,7 @@ static unsigned check_numeric2(void) return result; } -unsigned check_numeric(void) +unsigned check_numeric() { unsigned result = 0; @@ -105,12 +120,10 @@ unsigned check_numeric(void) result += check_numeric1(); cout << '.' << flush; result += check_numeric2(); cout << '.' << flush; - if (!result) { - cout << " passed " << endl; - clog << "(no output)" << endl; - } else { - cout << " failed " << endl; - } - return result; } + +int main(int argc, char** argv) +{ + return check_numeric(); +}