X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?a=blobdiff_plain;f=check%2Fcheck_lsolve.cpp;h=226b6c2d3a0d8144d126f0f6f83fb584c43767ec;hb=47b7f9c9b4a5bd91c7c83b12bac8481b55bf4b92;hp=4d1f23730aeda0acb20b388ec522a692835acb75;hpb=f4ea690a3f118bf364190f0ef3c3f6d2ccdf6206;p=ginac.git diff --git a/check/check_lsolve.cpp b/check/check_lsolve.cpp index 4d1f2373..226b6c2d 100644 --- a/check/check_lsolve.cpp +++ b/check/check_lsolve.cpp @@ -1,10 +1,11 @@ /** @file check_lsolve.cpp * * These test routines do some simple checks on solving linear systems of - * symbolic equations. */ + * symbolic equations. They are a well-tried resource for cross-checking + * the underlying symbolic manipulations. */ /* - * GiNaC Copyright (C) 1999-2000 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2008 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,111 +19,188 @@ * * 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 +#include +#include // rand() +#include "ginac.h" +using namespace std; +using namespace GiNaC; -static unsigned lsolve1(int size) +extern const ex +dense_univariate_poly(const symbol & x, unsigned degree); + +static unsigned check_matrix_solve(unsigned m, unsigned n, unsigned p, + unsigned degree) +{ + const symbol a("a"); + matrix A(m,n); + matrix B(m,p); + // set the first min(m,n) rows of A and B + for (unsigned ro=0; (ro x; + matrix X(n,p); + for (unsigned i=0; i a; + vector x; + for (unsigned i=0; i