X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=check%2Fcheck_lsolve.cpp;h=d39938a0504fcf835f4ea66b00827308d5bcb1ff;hp=4d1f23730aeda0acb20b388ec522a692835acb75;hb=01bc98316ce188dfdd7b239933cf2a70f2fd630e;hpb=f4ea690a3f118bf364190f0ef3c3f6d2ccdf6206 diff --git a/check/check_lsolve.cpp b/check/check_lsolve.cpp index 4d1f2373..d39938a0 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-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,111 +19,189 @@ * * 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; -static unsigned lsolve1(int size) +#include // for rand() +#include +#include +using namespace std; + +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