matrix.h

00001 //
00002 // matrix.h
00003 //
00004 // Copyright (C) 1996 Limit Point Systems, Inc.
00005 //
00006 // Author: Curtis Janssen <cljanss@limitpt.com>
00007 // Maintainer: LPS
00008 //
00009 // This file is part of the SC Toolkit.
00010 //
00011 // The SC Toolkit is free software; you can redistribute it and/or modify
00012 // it under the terms of the GNU Library General Public License as published by
00013 // the Free Software Foundation; either version 2, or (at your option)
00014 // any later version.
00015 //
00016 // The SC Toolkit is distributed in the hope that it will be useful,
00017 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00018 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00019 // GNU Library General Public License for more details.
00020 //
00021 // You should have received a copy of the GNU Library General Public License
00022 // along with the SC Toolkit; see the file COPYING.LIB.  If not, write to
00023 // the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
00024 //
00025 // The U.S. Government is granted a limited license as per AL 91-7.
00026 //
00027 
00028 #ifndef _math_scmat_matrix_h
00029 #define _math_scmat_matrix_h
00030 #ifdef __GNUC__
00031 #pragma interface
00032 #endif
00033 
00034 #include <iostream>
00035 
00036 #include <math/scmat/abstract.h>
00037 
00038 namespace sc {
00039 
00040 class SCVectordouble;
00041 class SCMatrixdouble;
00042 class SymmSCMatrixdouble;
00043 class DiagSCMatrixdouble;
00044 
00045 class SCMatrixBlockIter;
00046 class SCMatrixRectBlock;
00047 class SCMatrixLTriBlock;
00048 class SCMatrixDiagBlock;
00049 class SCVectorSimpleBlock;
00050 
00051 class RefSCMatrix;
00052 class RefSymmSCMatrix;
00055 class RefSCVector: public Ref<SCVector> {
00056     // standard overrides
00057   public:
00060     RefSCVector();
00062     RefSCVector(const RefSCVector& v);
00064     RefSCVector(SCVector *v);
00065     // don't allow automatic conversion from any reference to a
00066     // described class
00067     ~RefSCVector();
00069     RefSCVector& operator=(SCVector* v);
00071     RefSCVector& operator=(const RefSCVector& v);
00072 
00073     // vector specific members
00074   public:
00077     RefSCVector(const RefSCDimension& dim,const Ref<SCMatrixKit>&);
00078 
00080     SCVectordouble operator()(int) const;
00082     SCVectordouble operator[](int) const;
00084     RefSCVector operator+(const RefSCVector&a) const;
00086     RefSCVector operator-(const RefSCVector&a) const;
00088     RefSCVector operator*(double) const;
00090     RefSCMatrix outer_product(const RefSCVector& v) const;
00092     RefSymmSCMatrix symmetric_outer_product() const;
00093 
00094     void set_element(int i,double val) const;
00095     void accumulate_element(int i,double val) const;
00096     double get_element(int) const;
00097     int n() const;
00098     RefSCDimension dim() const;
00099     Ref<SCMatrixKit> kit() const;
00100     RefSCVector clone() const;
00101     RefSCVector copy() const;
00102     double maxabs() const;
00103     double scalar_product(const RefSCVector&) const;
00104     double dot(const RefSCVector&) const;
00105     void normalize() const;
00106     void randomize() const;
00107     void assign(const RefSCVector& v) const;
00108     void assign(double val) const;
00109     void assign(const double* v) const;
00110     void convert(double*) const;
00111     void scale(double val) const;
00112     void accumulate(const RefSCVector& v) const;
00113     void accumulate_product(const RefSymmSCMatrix&, const RefSCVector&);
00114     void accumulate_product(const RefSCMatrix&, const RefSCVector&);
00115     void element_op(const Ref<SCElementOp>& op) const;
00116     void element_op(const Ref<SCElementOp2>&,
00117                     const RefSCVector&) const;
00118     void element_op(const Ref<SCElementOp3>&,
00119                     const RefSCVector&,
00120                     const RefSCVector&) const;
00121     void print(std::ostream&out) const;
00122     void print(const char*title=0,
00123                std::ostream&out=ExEnv::out0(), int precision=10) const;
00124     void save(StateOut&);
00126     void restore(StateIn&);
00127 };
00128 RefSCVector operator*(double,const RefSCVector&);
00129 
00130 class RefSymmSCMatrix;
00131 class RefDiagSCMatrix;
00135 class RefSCMatrix: public Ref<SCMatrix> {
00136     // standard overrides
00137   public:
00140     RefSCMatrix();
00142     RefSCMatrix(const RefSCMatrix& m);
00144      RefSCMatrix(SCMatrix* m);
00145     ~RefSCMatrix();
00147     RefSCMatrix& operator=(SCMatrix* m);
00149     RefSCMatrix& operator=(const RefSCMatrix& m);
00150 
00151     // matrix specific members
00152   public:
00155     RefSCMatrix(const RefSCDimension& d1,const RefSCDimension& d2,
00156                 const Ref<SCMatrixKit>&);
00157 
00159     RefSCVector operator*(const RefSCVector&) const;
00160 
00162     RefSCMatrix operator*(const RefSCMatrix&) const;
00163     RefSCMatrix operator*(const RefSymmSCMatrix&) const;
00164     RefSCMatrix operator*(const RefDiagSCMatrix&) const;
00165 
00167     RefSCMatrix operator*(double) const;
00168 
00170     RefSCMatrix operator+(const RefSCMatrix&) const;
00172     RefSCMatrix operator-(const RefSCMatrix&) const;
00173 
00175     RefSCMatrix t() const;
00177     RefSCMatrix i() const;
00179     RefSCMatrix gi() const;
00180 
00183     RefSCMatrix clone() const;
00184     RefSCMatrix copy() const;
00185 
00186     RefSCMatrix get_subblock(int br, int er, int bc, int ec);
00187     void assign_subblock(const RefSCMatrix&, int br, int er, int bc, int ec,
00188                          int source_br = 0, int source_bc = 0);
00189     void accumulate_subblock(const RefSCMatrix&, int, int, int, int,
00190                              int source_br = 0, int source_bc = 0);
00191     RefSCVector get_row(int) const;
00192     RefSCVector get_column(int) const;
00193     void assign_row(const RefSCVector&, int) const;
00194     void assign_column(const RefSCVector&, int) const;
00195     void accumulate_row(const RefSCVector&, int) const;
00196     void accumulate_column(const RefSCVector&, int) const;
00197 
00198     void accumulate_outer_product(const RefSCVector&,const RefSCVector&) const;
00199     void accumulate_product(const RefSCMatrix&,const RefSCMatrix&) const;
00200     void assign(const RefSCMatrix&) const;
00201     void scale(double) const;
00202     void randomize() const;
00203     void assign(double) const;
00204     void assign(const double*) const;
00205     void assign(const double**) const;
00206     void convert(double*) const;
00207     void convert(double**) const;
00208     void accumulate(const RefSCMatrix&) const;
00209     void accumulate(const RefSymmSCMatrix&) const;
00210     void accumulate(const RefDiagSCMatrix&) const;
00211     void element_op(const Ref<SCElementOp>&) const;
00212     void element_op(const Ref<SCElementOp2>&,
00213                     const RefSCMatrix&) const;
00214     void element_op(const Ref<SCElementOp3>&,
00215                     const RefSCMatrix&,
00216                     const RefSCMatrix&) const;
00217     int nrow() const;
00218     int ncol() const;
00219     RefSCDimension rowdim() const;
00220     RefSCDimension coldim() const;
00221     Ref<SCMatrixKit> kit() const;
00222     void set_element(int,int,double) const;
00223     void accumulate_element(int,int,double) const;
00224     double get_element(int,int) const;
00225     void print(std::ostream&) const;
00226     void print(const char*title=0,
00227                std::ostream&out=ExEnv::out0(), int =10) const;
00228     double trace() const;
00229     void save(StateOut&);
00231     void restore(StateIn&);
00232 
00237     void svd(const RefSCMatrix &U,
00238              const RefDiagSCMatrix &sigma,
00239              const RefSCMatrix &V);
00241     double solve_lin(const RefSCVector& v) const;
00243     double determ() const;
00245     SCMatrixdouble operator()(int i,int j) const;
00246 
00250     int nblock() const;
00254     RefSCMatrix block(int i) const;
00255 };
00257 RefSCMatrix operator*(double,const RefSCMatrix&);
00258 
00261 class RefSymmSCMatrix: public Ref<SymmSCMatrix> {
00262     // standard overrides
00263   public:
00266     RefSymmSCMatrix();
00268     RefSymmSCMatrix(const RefSymmSCMatrix& m);
00270     RefSymmSCMatrix(SymmSCMatrix *m);
00271     ~RefSymmSCMatrix();
00273     RefSymmSCMatrix& operator=(SymmSCMatrix* m);
00275     RefSymmSCMatrix& operator=(const RefSymmSCMatrix& m);
00276 
00277     // matrix specific members
00278   public:
00281     RefSymmSCMatrix(const RefSCDimension& d,const Ref<SCMatrixKit>&);
00283     RefSCMatrix operator*(const RefSCMatrix&) const;
00284     RefSCMatrix operator*(const RefSymmSCMatrix&) const;
00285     RefSCMatrix operator*(const RefDiagSCMatrix&) const;
00287     RefSCVector operator*(const RefSCVector&a) const;
00288     RefSymmSCMatrix operator*(double) const;
00290     RefSymmSCMatrix operator+(const RefSymmSCMatrix&) const;
00291     RefSymmSCMatrix operator-(const RefSymmSCMatrix&) const;
00293     RefSymmSCMatrix i() const;
00295     RefSymmSCMatrix gi() const;
00298     RefSymmSCMatrix clone() const;
00299     RefSymmSCMatrix copy() const;
00300     void set_element(int,int,double) const;
00301     void accumulate_element(int,int,double) const;
00302     double get_element(int,int) const;
00303 
00304     RefSCMatrix get_subblock(int br, int er, int bc, int ec);
00305     RefSymmSCMatrix get_subblock(int br, int er);
00306     void assign_subblock(const RefSCMatrix&, int br, int er, int bc, int ec);
00307     void assign_subblock(const RefSymmSCMatrix&, int br, int er);
00308     void accumulate_subblock(const RefSCMatrix&, int, int, int, int);
00309     void accumulate_subblock(const RefSymmSCMatrix&, int, int);
00310     RefSCVector get_row(int);
00311     void assign_row(const RefSCVector&, int);
00312     void accumulate_row(const RefSCVector&, int);
00313 
00314     void accumulate_symmetric_outer_product(const RefSCVector&) const;
00315     double scalar_product(const RefSCVector&) const;
00316     void accumulate_symmetric_product(const RefSCMatrix&) const;
00317     void accumulate_symmetric_sum(const RefSCMatrix&) const;
00319     void accumulate_transform(const RefSCMatrix&a,const RefSymmSCMatrix&b,
00320                         SCMatrix::Transform = SCMatrix::NormalTransform) const;
00321     void accumulate_transform(const RefSCMatrix&a,const RefDiagSCMatrix&b,
00322                         SCMatrix::Transform = SCMatrix::NormalTransform) const;
00323     void accumulate_transform(const RefSymmSCMatrix&a,
00324                               const RefSymmSCMatrix&b) const;
00325 
00326     void randomize() const;
00327     void assign(const RefSymmSCMatrix&) const;
00328     void scale(double) const;
00329     void assign(double) const;
00330     void assign(const double*) const;
00331     void assign(const double**) const;
00332     void convert(double*) const;
00333     void convert(double**) const;
00334     void accumulate(const RefSymmSCMatrix&) const;
00335     void element_op(const Ref<SCElementOp>&) const;
00336     void element_op(const Ref<SCElementOp2>&,
00337                     const RefSymmSCMatrix&) const;
00338     void element_op(const Ref<SCElementOp3>&,
00339                     const RefSymmSCMatrix&,
00340                     const RefSymmSCMatrix&) const;
00341     double trace() const;
00342     int n() const;
00343     RefSCDimension dim() const;
00344     Ref<SCMatrixKit> kit() const;
00345     void print(std::ostream&) const;
00346     void print(const char*title=0,
00347                std::ostream&out=ExEnv::out0(), int =10) const;
00348     void save(StateOut&);
00350     void restore(StateIn&);
00351 
00353     double solve_lin(const RefSCVector&) const;
00355     double determ() const;
00357     RefDiagSCMatrix eigvals() const;
00359     RefSCMatrix eigvecs() const;
00363     void diagonalize(const RefDiagSCMatrix& eigvals,
00364                      const RefSCMatrix& eigvecs) const;
00366     SymmSCMatrixdouble operator()(int i,int j) const;
00370     int nblock() const;
00374     RefSymmSCMatrix block(int i) const;
00375 };
00377 RefSymmSCMatrix operator*(double,const RefSymmSCMatrix&);
00378 
00381 class RefDiagSCMatrix: public Ref<DiagSCMatrix> {
00382     // standard overrides
00383   public:
00386     RefDiagSCMatrix();
00388     RefDiagSCMatrix(const RefDiagSCMatrix& m);
00390     RefDiagSCMatrix(DiagSCMatrix *m);
00391     ~RefDiagSCMatrix();
00393     RefDiagSCMatrix& operator=(DiagSCMatrix* m);
00395     RefDiagSCMatrix& operator=(const RefDiagSCMatrix & m);
00396 
00397     // matrix specific members
00398   public:
00401     RefDiagSCMatrix(const RefSCDimension&,const Ref<SCMatrixKit>&);
00403     RefSCMatrix operator*(const RefSCMatrix&) const;
00404     RefSCMatrix operator*(const RefSymmSCMatrix&) const;
00405     RefDiagSCMatrix operator*(const RefDiagSCMatrix&) const;
00406     RefDiagSCMatrix operator*(double) const;
00408     RefDiagSCMatrix operator+(const RefDiagSCMatrix&) const;
00409     RefDiagSCMatrix operator-(const RefDiagSCMatrix&) const;
00411     RefDiagSCMatrix i() const;
00413     RefDiagSCMatrix gi() const;
00416     RefDiagSCMatrix clone() const;
00417     RefDiagSCMatrix copy() const;
00418     void set_element(int,double) const;
00419     void accumulate_element(int,double) const;
00420     double get_element(int) const;
00421     void randomize() const;
00422     void assign(const RefDiagSCMatrix&) const;
00423     void scale(double) const;
00424     void assign(double) const;
00425     void assign(const double*) const;
00426     void convert(double*) const;
00427     void accumulate(const RefDiagSCMatrix&) const;
00428     void element_op(const Ref<SCElementOp>&) const;
00429     void element_op(const Ref<SCElementOp2>&,
00430                     const RefDiagSCMatrix&) const;
00431     void element_op(const Ref<SCElementOp3>&,
00432                     const RefDiagSCMatrix&,
00433                     const RefDiagSCMatrix&) const;
00434     int n() const;
00435     RefSCDimension dim() const;
00436     Ref<SCMatrixKit> kit() const;
00437     double trace() const;
00438     void print(std::ostream&) const;
00439     void print(const char*title=0,
00440                std::ostream&out=ExEnv::out0(), int =10) const;
00441     void save(StateOut&);
00443     void restore(StateIn&);
00445     double determ() const;
00447     DiagSCMatrixdouble operator()(int i) const;
00451     int nblock() const;
00455     RefDiagSCMatrix block(int i) const;
00456 };
00458 RefDiagSCMatrix operator*(double,const RefDiagSCMatrix&);
00459 
00460 class SCVectordouble {
00461    friend class RefSCVector;
00462   private:
00463     RefSCVector vector;
00464     int i;
00465     
00466     SCVectordouble(SCVector*,int);
00467   public:
00468     SCVectordouble(const SCVectordouble&);
00469     ~SCVectordouble();
00470     double operator=(double a);
00471     double operator=(const SCVectordouble&);
00472     operator double();
00473     double val() const;
00474 };
00475 
00476 class SCMatrixdouble {
00477    friend class RefSCMatrix;
00478   private:
00479     RefSCMatrix matrix;
00480     int i;
00481     int j;
00482     
00483     SCMatrixdouble(SCMatrix*,int,int);
00484   public:
00485     SCMatrixdouble(const SCMatrixdouble&);
00486     ~SCMatrixdouble();
00487     double operator=(double a);
00488     double operator=(const SCMatrixdouble&);
00489     operator double();
00490     double val() const;
00491 };
00492 
00493 class SymmSCMatrixdouble {
00494    friend class RefSymmSCMatrix;
00495   private:
00496     RefSymmSCMatrix matrix;
00497     int i;
00498     int j;
00499     
00500     SymmSCMatrixdouble(SymmSCMatrix*,int,int);
00501   public:
00502     SymmSCMatrixdouble(const SCMatrixdouble&);
00503     ~SymmSCMatrixdouble();
00504     double operator=(double a);
00505     double operator=(const SymmSCMatrixdouble&);
00506     operator double();
00507     double val() const;
00508 };
00509 
00510 class DiagSCMatrixdouble {
00511    friend class RefDiagSCMatrix;
00512   private:
00513     RefDiagSCMatrix matrix;
00514     int i;
00515     int j;
00516     
00517     DiagSCMatrixdouble(DiagSCMatrix*,int,int);
00518   public:
00519     DiagSCMatrixdouble(const SCMatrixdouble&);
00520     ~DiagSCMatrixdouble();
00521     double operator=(double a);
00522     double operator=(const DiagSCMatrixdouble&);
00523     operator double();
00524     double val() const;
00525 };
00526 
00527 }
00528 
00529 #ifdef INLINE_FUNCTIONS
00530 #include <math/scmat/matrix_i.h>
00531 #endif
00532 
00533 #endif
00534 
00535 // Local Variables:
00536 // mode: c++
00537 // c-file-style: "CLJ"
00538 // End:

Generated at Wed Sep 5 14:02:30 2007 for MPQC 3.0.0-alpha using the documentation package Doxygen 1.5.2.
These pages are hosted on SourceForge.net