X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=check%2Fcheck_matrices.cpp;h=edc3032ddec1c4e7f99530e7c3722da327a5afbf;hp=71893bb129ff5cbe6950308ef06b7fd7d4bf2d8b;hb=7905061f6487b278e08b103d4d142decb418535e;hpb=d6dd9e5350d479533b319dd1dfedaa2467627fe3 diff --git a/check/check_matrices.cpp b/check/check_matrices.cpp index 71893bb1..edc3032d 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-2018 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,85 +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 over -// an integral domain. -static unsigned integdom_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