/************************************************************************* * * * Open Dynamics Engine, Copyright (C) 2001,2002 Russell L. Smith. * * All rights reserved. Email: russ@q12.org Web: www.q12.org * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of EITHER: * * (1) The GNU Lesser General Public License as published by the Free * * Software Foundation; either version 2.1 of the License, or (at * * your option) any later version. The text of the GNU Lesser * * General Public License is included with this library in the * * file LICENSE.TXT. * * (2) The BSD-style license that is included with this library in * * the file LICENSE-BSD.TXT. * * * * This library is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the files * * LICENSE.TXT and LICENSE-BSD.TXT for more details. * * * *************************************************************************/ #include #include #include #include #include "config.h" #include "matrix.h" #include "mat.h" dMatrix::dMatrix() { n = 0; m = 0; data = 0; } dMatrix::dMatrix (int rows, int cols) { if (rows < 1 || cols < 1) dDebug (0,"bad matrix size"); n = rows; m = cols; data = (dReal*) dAlloc (n*m*sizeof(dReal)); dSetZero (data,n*m); } dMatrix::dMatrix (const dMatrix &a) { n = a.n; m = a.m; data = (dReal*) dAlloc (n*m*sizeof(dReal)); memcpy (data,a.data,n*m*sizeof(dReal)); } dMatrix::dMatrix (int rows, int cols, dReal *_data, int rowskip, int colskip) { if (rows < 1 || cols < 1) dDebug (0,"bad matrix size"); n = rows; m = cols; data = (dReal*) dAlloc (n*m*sizeof(dReal)); for (int i=0; i= n || j < 0 || j >= m) dDebug (0,"bad matrix (i,j)"); return data [i*m+j]; } void dMatrix::operator= (const dMatrix &a) { if (data) dFree (data,n*m*sizeof(dReal)); n = a.n; m = a.m; if (n > 0 && m > 0) { data = (dReal*) dAlloc (n*m*sizeof(dReal)); memcpy (data,a.data,n*m*sizeof(dReal)); } else data = 0; } void dMatrix::operator= (dReal a) { for (int i=0; i= n || q[i] < 0 || q[i] >= m) dDebug (0,"Matrix select, bad index arrays"); r.data[i*nq+j] = data[p[i]*m+q[j]]; } } return r; } dMatrix dMatrix::operator + (const dMatrix &a) { if (n != a.n || m != a.m) dDebug (0,"matrix +, mismatched sizes"); dMatrix r (n,m); for (int i=0; i max) max = diff; } } return max; }