1 /** @file exam_factor.cpp
3 * Factorization test suite. */
6 * GiNaC Copyright (C) 1999-2010 Johannes Gutenberg University Mainz, Germany
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
24 using namespace GiNaC;
29 static symbol w("w"), x("x"), y("y"), z("z");
31 static unsigned check_factor(const ex& e)
34 ex answer = factor(ee);
35 if ( answer.expand() != ee || answer != e ) {
36 clog << "factorization of " << e << " == " << ee << " gave wrong result: " << answer << endl;
42 static unsigned exam_factor1()
50 e = ex("1+x-x^3", syms);
51 result += check_factor(e);
53 e = ex("1+x^6+x", syms);
54 result += check_factor(e);
56 e = ex("1-x^6+x", syms);
57 result += check_factor(e);
59 e = ex("(1+x)^3", syms);
60 result += check_factor(e);
62 e = ex("(x+1)*(x+4)", syms);
63 result += check_factor(e);
65 e = ex("x^6-3*x^5+x^4-3*x^3-x^2-3*x+1", syms);
66 result += check_factor(e);
68 e = ex("(-1+x)^3*(1+x)^3*(1+x^2)", syms);
69 result += check_factor(e);
71 e = ex("-(-168+20*x-x^2)*(30+x)", syms);
72 result += check_factor(e);
74 e = ex("x^2*(x-3)^2*(x^3-5*x+7)", syms);
75 result += check_factor(e);
77 e = ex("-6*x^2*(x-3)", syms);
78 result += check_factor(e);
80 e = ex("x^16+11*x^4+121", syms);
81 result += check_factor(e);
83 e = ex("x^8-40*x^6+352*x^4-960*x^2+576", syms);
84 result += check_factor(e);
86 e = ex("x*(2+x^2)*(1+x+x^3+x^2+x^6+x^5+x^4)*(1+x)^2*(1-x+x^2)^2*(-1+x)", syms);
87 result += check_factor(e);
89 e = ex("(x+4+x^2-x^3+43*x^4)*(x+1-x^2-3*x^3+4*x^4)", syms);
90 result += check_factor(e);
92 e = ex("-x^2*(x-1)*(1+x^2)", syms);
93 result += check_factor(e);
96 result += check_factor(e);
99 e = ex("(1+x)*(1+x^2-x^29-x^11-x^25-x^9-x^35+x^20-x^3+x^16-x^15-x-x^13+x^28+x^24-x^33+x^8-x^19+x^36+x^12-x^27+x^10-x^23+x^18+x^14+x^34-x^31+x^32+x^30-x^5+x^26+x^4+x^22-x^21-x^7-x^17+x^6)", syms);
100 result += check_factor(e);
102 e = ex("(1+4*x)*x^2*(1-4*x+16*x^2)*(3+5*x+92*x^3)", syms);
103 result += check_factor(e);
105 e = ex("(77+11*x^3+25*x^2+27*x+102*x^4)*(85+57*x^3+92*x^2+29*x+66*x^4)", syms);
106 result += check_factor(e);
111 static unsigned exam_factor2()
115 symbol x("x"), y("y"), z("z");
120 result += check_factor(e);
122 e = ex("(x^2-y+1)*(x+y)", syms);
123 result += check_factor(e);
125 e = ex("-2*(x+y)*(x-y)", syms);
126 result += check_factor(e);
128 e = ex("(16+x^2*z^3)*(-17+3*x-5*z)*(2*x+3*z)*(x-y^2-z^3)", syms);
129 result += check_factor(e);
131 e = ex("(x-y*z)*(x-y^2-z^3)*(x+y+z)", syms);
132 result += check_factor(e);
134 e = ex("-(y^2-x+z^3)*x*(x+y+z)", syms);
135 result += check_factor(e);
137 e = ex("-316*(3*x-4*z)*(2*x+3*z)*(x+y)*(-1+x)", syms);
138 result += check_factor(e);
140 e = ex("(x+x^3+z^2)*(3*x-4*z)", syms);
141 result += check_factor(e);
143 e = ex("250*(-3+x)*(4*z-3*x)*(x^3+z^2+x)*x", syms);
144 result += check_factor(e);
146 e = ex("327*(x+z^2+x^3)*(3*x-4*z)*(-7+5*x-x^3)*(1+x+x^2)", syms);
147 result += check_factor(e);
149 e = ex("x-y^2-z^3", syms);
150 result += check_factor(e);
152 e = ex("-390*(7+3*x^4)*(2+x^2)*(x-z^3-y^2)", syms);
153 result += check_factor(e);
155 e = ex("55*(1+x)^2*(3*x-4*z)*(1+x+x^2)*(x+x^3+z^2)", syms);
156 result += check_factor(e);
158 e = ex("x+y*x-1", syms);
159 result += check_factor(e);
161 e = ex("390*(-1+x^6-x)*(7+3*x^4)*(2+x^2)*(y+x)*(-1+y-x^2)*(1+x^2+x)^2", syms);
162 result += check_factor(e);
164 e = ex("310*(y+x)*(-1+y-x^2)", syms);
165 result += check_factor(e);
170 static unsigned exam_factor3()
174 symbol k("k"), n("n");
178 e = ex("1/2*(-3+3*k-n)*(-2+3*k-n)*(-1+3*k-n)", syms);
179 result += check_factor(e);
181 e = ex("1/4*(2*k-n)*(-1+2*k-n)", syms);
182 result += check_factor(e);
187 unsigned exam_factor()
191 cout << "examining polynomial factorization" << flush;
193 result += exam_factor1(); cout << '.' << flush;
194 result += exam_factor2(); cout << '.' << flush;
195 result += exam_factor3(); cout << '.' << flush;
200 int main(int argc, char** argv)
202 return exam_factor();