X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Fmatrix.cpp;h=3e9b28bba1133e16b4758c3ef68566398dffea52;hp=20c80d15a1f198e140bdc99819fe6fa2f7babc37;hb=073bf40a73e419a3dbcb6dfa190947ce2cc3bdce;hpb=fc6d6774bb3d125be622bd84edb7e2ed4f77655c diff --git a/ginac/matrix.cpp b/ginac/matrix.cpp index 20c80d15..3e9b28bb 100644 --- a/ginac/matrix.cpp +++ b/ginac/matrix.cpp @@ -3,7 +3,7 @@ * Implementation of symbolic matrices */ /* - * GiNaC Copyright (C) 1999-2006 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2011 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 @@ -20,13 +20,6 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ -#include -#include -#include -#include -#include -#include - #include "matrix.h" #include "numeric.h" #include "lst.h" @@ -40,6 +33,13 @@ #include "archive.h" #include "utils.h" +#include +#include +#include +#include +#include +#include + namespace GiNaC { GINAC_IMPLEMENT_REGISTERED_CLASS_OPT(matrix, basic, @@ -53,7 +53,7 @@ GINAC_IMPLEMENT_REGISTERED_CLASS_OPT(matrix, basic, ////////// /** Default ctor. Initializes to 1 x 1-dimensional zero-matrix. */ -matrix::matrix() : inherited(&matrix::tinfo_static), row(1), col(1), m(1, _ex0) +matrix::matrix() : row(1), col(1), m(1, _ex0) { setflag(status_flags::not_shareable); } @@ -68,8 +68,7 @@ matrix::matrix() : inherited(&matrix::tinfo_static), row(1), col(1), m(1, _ex0) * * @param r number of rows * @param c number of cols */ -matrix::matrix(unsigned r, unsigned c) - : inherited(&matrix::tinfo_static), row(r), col(c), m(r*c, _ex0) +matrix::matrix(unsigned r, unsigned c) : row(r), col(c), m(r*c, _ex0) { setflag(status_flags::not_shareable); } @@ -78,7 +77,7 @@ matrix::matrix(unsigned r, unsigned c) /** Ctor from representation, for internal use only. */ matrix::matrix(unsigned r, unsigned c, const exvector & m2) - : inherited(&matrix::tinfo_static), row(r), col(c), m(m2) + : row(r), col(c), m(m2) { setflag(status_flags::not_shareable); } @@ -88,7 +87,7 @@ matrix::matrix(unsigned r, unsigned c, const exvector & m2) * If the list has more elements than the matrix, the excessive elements are * thrown away. */ matrix::matrix(unsigned r, unsigned c, const lst & l) - : inherited(&matrix::tinfo_static), row(r), col(c), m(r*c, _ex0) + : row(r), col(c), m(r*c, _ex0) { setflag(status_flags::not_shareable); @@ -106,22 +105,25 @@ matrix::matrix(unsigned r, unsigned c, const lst & l) // archiving ////////// -matrix::matrix(const archive_node &n, lst &sym_lst) : inherited(n, sym_lst) +void matrix::read_archive(const archive_node &n, lst &sym_lst) { - setflag(status_flags::not_shareable); + inherited::read_archive(n, sym_lst); if (!(n.find_unsigned("row", row)) || !(n.find_unsigned("col", col))) throw (std::runtime_error("unknown matrix dimensions in archive")); m.reserve(row * col); + // XXX: default ctor inserts a zero element, we need to erase it here. + m.pop_back(); archive_node::archive_node_cit first = n.find_first("m"); archive_node::archive_node_cit last = n.find_last("m"); ++last; - for (archive_node::archive_node_cit i=first; isetflag(status_flags::dynallocated | - status_flags::evaluated); + status_flags::evaluated); } ex matrix::subs(const exmap & mp, unsigned options) const @@ -1414,18 +1414,27 @@ int matrix::fraction_free_elimination(const bool det) unsigned r0 = 0; for (unsigned c0=0; c0=0) { - if (indx>0) { + } else { + if (indx>r0) { + // Matrix needs pivoting, swap rows r0 and indx of tmp_n and tmp_d. sign = -sign; - // tmp_n's rows r0 and indx were swapped, do the same in tmp_d: - for (unsigned c=c0; c