GNU Octave  9.1.0
A high-level interpreted language, primarily intended for numerical computations, mostly compatible with Matlab
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
dColVector.h
Go to the documentation of this file.
1 ////////////////////////////////////////////////////////////////////////
2 //
3 // Copyright (C) 1994-2024 The Octave Project Developers
4 //
5 // See the file COPYRIGHT.md in the top-level directory of this
6 // distribution or <https://octave.org/copyright/>.
7 //
8 // This file is part of Octave.
9 //
10 // Octave is free software: you can redistribute it and/or modify it
11 // under the terms of the GNU General Public License as published by
12 // the Free Software Foundation, either version 3 of the License, or
13 // (at your option) any later version.
14 //
15 // Octave is distributed in the hope that it will be useful, but
16 // WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
19 //
20 // You should have received a copy of the GNU General Public License
21 // along with Octave; see the file COPYING. If not, see
22 // <https://www.gnu.org/licenses/>.
23 //
24 ////////////////////////////////////////////////////////////////////////
25 
26 #if ! defined (octave_dColVector_h)
27 #define octave_dColVector_h 1
28 
29 #include "octave-config.h"
30 
31 #include "MArray.h"
32 #include "mx-defs.h"
33 
34 class
37 {
38 public:
39 
40  ColumnVector () : MArray<double> (dim_vector (0, 1)) { }
41 
43  : MArray<double> (dim_vector (n, 1)) { }
44 
45  explicit ColumnVector (const dim_vector& dv)
46  : MArray<double> (dv.as_column ()) { }
47 
49  : MArray<double> (dim_vector (n, 1), val) { }
50 
51  ColumnVector (const ColumnVector& a) : MArray<double> (a) { }
52 
53  ColumnVector (const MArray<double>& a) : MArray<double> (a.as_column ()) { }
54  ColumnVector (const Array<double>& a) : MArray<double> (a.as_column ()) { }
55 
56  ColumnVector& operator = (const ColumnVector& a)
57  {
59  return *this;
60  }
61 
62  ~ColumnVector () = default;
63 
64  OCTAVE_API bool operator == (const ColumnVector& a) const;
65  OCTAVE_API bool operator != (const ColumnVector& a) const;
66 
67  // destructive insert/delete/reorder operations
68 
70 
71  OCTAVE_API ColumnVector& fill (double val);
73  fill (double val, octave_idx_type r1, octave_idx_type r2);
74 
75  OCTAVE_API ColumnVector stack (const ColumnVector& a) const;
76 
77  OCTAVE_API RowVector transpose () const;
78 
81 
82  // resize is the destructive equivalent for this one
83 
85  extract (octave_idx_type r1, octave_idx_type r2) const;
86 
88  extract_n (octave_idx_type r1, octave_idx_type n) const;
89 
90  // matrix by column vector -> column vector operations
91 
92  friend OCTAVE_API ColumnVector operator * (const Matrix& a,
93  const ColumnVector& b);
94 
95  // diagonal matrix by column vector -> column vector operations
96 
98  const ColumnVector& b);
99 
100  // other operations
101 
102  OCTAVE_API double min () const;
103  OCTAVE_API double max () const;
104 
105  OCTAVE_API ColumnVector abs () const;
106 
107  // i/o
108 
109  friend OCTAVE_API std::ostream& operator << (std::ostream& os,
110  const ColumnVector& a);
111  friend OCTAVE_API std::istream& operator >> (std::istream& is,
112  ColumnVector& a);
113 
114  void resize (octave_idx_type n, const double& rfv = 0)
115  {
116  Array<double>::resize (dim_vector (n, 1), rfv);
117  }
118 
120  { Array<double>::clear (n, 1); }
121 
122 };
123 
124 // Publish externally used friend functions.
125 
128 
130 
131 #endif
template std::ostream & operator<<(std::ostream &, const Array< bool > &)
#define MARRAY_FORWARD_DEFS(B, R, T)
Definition: MArray.h:130
std::istream & operator>>(std::istream &is, SparseBoolMatrix &a)
Definition: boolSparse.cc:279
charNDArray max(char d, const charNDArray &m)
Definition: chNDArray.cc:230
charNDArray min(char d, const charNDArray &m)
Definition: chNDArray.cc:207
void clear()
Definition: Array-base.cc:109
void resize(const dim_vector &dv, const T &rfv)
Size of the specified dimension.
Definition: Array-base.cc:1023
void resize(octave_idx_type n, const double &rfv=0)
Definition: dColVector.h:114
ColumnVector(const dim_vector &dv)
Definition: dColVector.h:45
ColumnVector(octave_idx_type n)
Definition: dColVector.h:42
ColumnVector(octave_idx_type n, double val)
Definition: dColVector.h:48
ColumnVector(const MArray< double > &a)
Definition: dColVector.h:53
void clear(octave_idx_type n)
Definition: dColVector.h:119
~ColumnVector()=default
ColumnVector(const ColumnVector &a)
Definition: dColVector.h:51
ColumnVector(const Array< double > &a)
Definition: dColVector.h:54
MArray< T > & operator=(const MArray< T > &a)
Definition: MArray.h:81
Definition: dMatrix.h:42
Vector representing the dimensions (size) of an Array.
Definition: dim-vector.h:94
ColumnVector real(const ComplexColumnVector &a)
Definition: dColVector.cc:137
ColumnVector imag(const ComplexColumnVector &a)
Definition: dColVector.cc:143
ColumnVector operator*(const ColumnVector &x, const double &y)
Definition: dColVector.h:129
bool operator!=(const dim_vector &a, const dim_vector &b)
Definition: dim-vector.h:536
bool operator==(const dim_vector &a, const dim_vector &b)
Definition: dim-vector.h:520
#define OCTAVE_API
Definition: main.cc:55
octave_idx_type n
Definition: mx-inlines.cc:761
T * r
Definition: mx-inlines.cc:781
template int8_t abs(int8_t)