Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #if !defined (octave_DiagMatrix_h)
00024 #define octave_DiagMatrix_h 1
00025
00026 #include "MDiagArray2.h"
00027
00028 #include "dRowVector.h"
00029 #include "dColVector.h"
00030 #include "DET.h"
00031
00032 #include "mx-defs.h"
00033
00034 class
00035 OCTAVE_API
00036 DiagMatrix : public MDiagArray2<double>
00037 {
00038 friend class SVD;
00039 friend class ComplexSVD;
00040
00041 public:
00042
00043 DiagMatrix (void) : MDiagArray2<double> () { }
00044
00045 DiagMatrix (octave_idx_type r, octave_idx_type c) : MDiagArray2<double> (r, c) { }
00046
00047 DiagMatrix (octave_idx_type r, octave_idx_type c, double val) : MDiagArray2<double> (r, c, val) { }
00048
00049 DiagMatrix (const DiagMatrix& a) : MDiagArray2<double> (a) { }
00050
00051 DiagMatrix (const MDiagArray2<double>& a) : MDiagArray2<double> (a) { }
00052
00053 template <class U>
00054 DiagMatrix (const DiagArray2<U>& a) : MDiagArray2<double> (a) { }
00055
00056 explicit DiagMatrix (const Array<double>& a) : MDiagArray2<double> (a) { }
00057
00058 DiagMatrix (const Array<double>& a, octave_idx_type r, octave_idx_type c)
00059 : MDiagArray2<double> (a, r, c) { }
00060
00061 DiagMatrix& operator = (const DiagMatrix& a)
00062 {
00063 MDiagArray2<double>::operator = (a);
00064 return *this;
00065 }
00066
00067 bool operator == (const DiagMatrix& a) const;
00068 bool operator != (const DiagMatrix& a) const;
00069
00070 DiagMatrix& fill (double val);
00071 DiagMatrix& fill (double val, octave_idx_type beg, octave_idx_type end);
00072 DiagMatrix& fill (const ColumnVector& a);
00073 DiagMatrix& fill (const RowVector& a);
00074 DiagMatrix& fill (const ColumnVector& a, octave_idx_type beg);
00075 DiagMatrix& fill (const RowVector& a, octave_idx_type beg);
00076
00077 DiagMatrix transpose (void) const { return MDiagArray2<double>::transpose(); }
00078 DiagMatrix abs (void) const;
00079
00080 friend OCTAVE_API DiagMatrix real (const ComplexDiagMatrix& a);
00081 friend OCTAVE_API DiagMatrix imag (const ComplexDiagMatrix& a);
00082
00083
00084
00085 Matrix extract (octave_idx_type r1, octave_idx_type c1, octave_idx_type r2, octave_idx_type c2) const;
00086
00087
00088
00089 RowVector row (octave_idx_type i) const;
00090 RowVector row (char *s) const;
00091
00092 ColumnVector column (octave_idx_type i) const;
00093 ColumnVector column (char *s) const;
00094
00095 DiagMatrix inverse (void) const;
00096 DiagMatrix inverse (octave_idx_type& info) const;
00097 DiagMatrix pseudo_inverse (void) const;
00098
00099
00100
00101 ColumnVector diag (octave_idx_type k = 0) const
00102 { return MDiagArray2<double>::diag (k); }
00103
00104 DET determinant (void) const;
00105 double rcond (void) const;
00106
00107
00108
00109 friend OCTAVE_API std::ostream& operator << (std::ostream& os, const DiagMatrix& a);
00110
00111 };
00112
00113 OCTAVE_API DiagMatrix real (const ComplexDiagMatrix& a);
00114 OCTAVE_API DiagMatrix imag (const ComplexDiagMatrix& a);
00115
00116
00117
00118 OCTAVE_API DiagMatrix
00119 operator * (const DiagMatrix& a, const DiagMatrix& b);
00120
00121 MDIAGARRAY2_FORWARD_DEFS (MDiagArray2, DiagMatrix, double)
00122
00123 #endif