X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=check%2Fcheck_matrices.cpp;h=a714523be57da6d64356958f4d886bf0bd249c92;hp=ec7efefc523132fae8b701c2864a674d26c3927e;hb=8cffcdf13d817a47f217f1a1043317d95969e070;hpb=f4ea690a3f118bf364190f0ef3c3f6d2ccdf6206 diff --git a/check/check_matrices.cpp b/check/check_matrices.cpp index ec7efefc..a714523b 100644 --- a/check/check_matrices.cpp +++ b/check/check_matrices.cpp @@ -1,9 +1,11 @@ /** @file check_matrices.cpp * - * Here we test manipulations on GiNaC's symbolic matrices. */ + * Here we test manipulations on GiNaC's symbolic matrices. 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-2019 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 @@ -17,54 +19,210 @@ * * 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; -// determinants of some sparse symbolic size x size matrices -static unsigned matrix_determinants(void) +#include // for rand(), RAND_MAX +#include +using namespace std; + +extern const ex +sparse_tree(const symbol & x, const symbol & y, const symbol & z, + int level, bool trig = false, bool rational = true, + bool complex = false); +extern const ex +dense_univariate_poly(const symbol & x, unsigned degree); + +/* determinants of some sparse symbolic matrices with coefficients in + * an integral domain. */ +static unsigned integdom_matrix_determinants() +{ + unsigned result = 0; + symbol a("a"); + + for (unsigned size=3; size<22; ++size) { + matrix A(size,size); + // populate one element in each row: + for (unsigned r=0; r