X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=check%2Fexam_normalization.cpp;h=b42a2c7fd5d3866e6a8af3c9be8b8798c186d738;hp=3a73e47ba97b0c6da9b90021a80eaa1d8121dfbd;hb=781107fc309db9eadc2e0540d35d9813da0afd4d;hpb=e7cc6a764ff67b5885d6633385fac23ccc1dc9a7 diff --git a/check/exam_normalization.cpp b/check/exam_normalization.cpp index 3a73e47b..b42a2c7f 100644 --- a/check/exam_normalization.cpp +++ b/check/exam_normalization.cpp @@ -3,7 +3,7 @@ * Rational function normalization test suite. */ /* - * GiNaC Copyright (C) 1999-2002 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2004 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 @@ -27,7 +27,7 @@ static symbol w("w"), x("x"), y("y"), z("z"); static unsigned check_normal(const ex &e, const ex &d) { ex en = e.normal(); - if (en.compare(d) != 0) { + if (!en.is_equal(d)) { clog << "normal form of " << e << " erroneously returned " << en << " (should be " << d << ")" << endl; return 1; @@ -35,7 +35,7 @@ static unsigned check_normal(const ex &e, const ex &d) return 0; } -static unsigned exam_normal1(void) +static unsigned exam_normal1() { unsigned result = 0; ex e, d; @@ -62,7 +62,7 @@ static unsigned exam_normal1(void) return result; } -static unsigned exam_normal2(void) +static unsigned exam_normal2() { unsigned result = 0; ex e, d; @@ -101,7 +101,7 @@ static unsigned exam_normal2(void) return result; } -static unsigned exam_normal3(void) +static unsigned exam_normal3() { unsigned result = 0; ex e, d; @@ -124,7 +124,7 @@ static unsigned exam_normal3(void) return result; } -static unsigned exam_normal4(void) +static unsigned exam_normal4() { unsigned result = 0; ex e, d; @@ -157,17 +157,69 @@ static unsigned exam_normal4(void) return result; } -unsigned exam_normalization(void) +/* Test content(), integer_content(), primpart(). */ +static unsigned check_content(const ex & e, const ex & x, const ex & ic, const ex & c, const ex & pp) +{ + unsigned result = 0; + + ex r_ic = e.integer_content(); + if (!r_ic.is_equal(ic)) { + clog << "integer_content(" << e << ") erroneously returned " + << r_ic << " instead of " << ic << endl; + ++result; + } + + ex r_c = e.content(x); + if (!r_c.is_equal(c)) { + clog << "content(" << e << ", " << x << ") erroneously returned " + << r_c << " instead of " << c << endl; + ++result; + } + + ex r_pp = e.primpart(x); + if (!r_pp.is_equal(pp)) { + clog << "primpart(" << e << ", " << x << ") erroneously returned " + << r_pp << " instead of " << pp << endl; + ++result; + } + + ex r = r_c*r_pp*e.unit(x); + if (!(r - e).expand().is_zero()) { + clog << "product of unit, content, and primitive part of " << e << " yielded " + << r << " instead of " << e << endl; + ++result; + } + + return result; +} + +static unsigned exam_content() +{ + unsigned result = 0; + symbol x("x"), y("y"); + + result += check_content(ex(-3)/4, x, ex(3)/4, ex(3)/4, 1); + result += check_content(-x/4, x, ex(1)/4, ex(1)/4, x); + result += check_content(5*x-15, x, 5, 5, x-3); + result += check_content(5*x*y-15*y*y, x, 5, 5*y, x-3*y); + result += check_content(-15*x/2+ex(25)/3, x, ex(5)/6, ex(5)/6, 9*x-10); + result += check_content(-x*y, x, 1, y, x); + + return result; +} + +unsigned exam_normalization() { unsigned result = 0; cout << "examining rational function normalization" << flush; clog << "----------rational function normalization:" << endl; - result += exam_normal1(); cout << '.' << flush; - result += exam_normal2(); cout << '.' << flush; - result += exam_normal3(); cout << '.' << flush; - result += exam_normal4(); cout << '.' << flush; + result += exam_normal1(); cout << '.' << flush; + result += exam_normal2(); cout << '.' << flush; + result += exam_normal3(); cout << '.' << flush; + result += exam_normal4(); cout << '.' << flush; + result += exam_content(); cout << '.' << flush; if (!result) { cout << " passed " << endl;