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