X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=check%2Fcheck_lsolve.cpp;h=4c98fc510c5605454795a6d166e20fb508b041b2;hp=4d1f23730aeda0acb20b388ec522a692835acb75;hb=b3283b8904fbc9617cb6293791c7a653e255ebbe;hpb=f4ea690a3f118bf364190f0ef3c3f6d2ccdf6206 diff --git a/check/check_lsolve.cpp b/check/check_lsolve.cpp index 4d1f2373..4c98fc51 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-2003 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 @@ -22,107 +23,180 @@ */ #include "checks.h" +#include -static unsigned lsolve1(int size) +static unsigned check_matrix_solve(unsigned m, unsigned n, unsigned p, + unsigned degree) { - // A dense size x size matrix in dense univariate random polynomials - // of order 4. - unsigned result = 0; - symbol a("a"); - ex sol; - - // Create two dense linear matrices A and B where all entries are random - // univariate polynomials - matrix A(size,size), B(size,2), X(size,2); - for (int ro=0; ro x; + matrix X(n,p); + for (unsigned i=0; i a; + vector x; + for (unsigned i=0; i