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
fCColVector.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_fCColVector_h)
27 #define octave_fCColVector_h 1
28 
29 #include "octave-config.h"
30 
31 #include "MArray.h"
32 #include "mx-defs.h"
33 
34 class
37 {
38  friend class FloatComplexMatrix;
39  friend class FloatComplexRowVector;
40 
41 public:
42 
44  : MArray<FloatComplex> (dim_vector (0, 1)) { }
45 
47  : MArray<FloatComplex> (dim_vector (n, 1)) { }
48 
49  explicit FloatComplexColumnVector (const dim_vector& dv)
50  : MArray<FloatComplex> (dv.as_column ()) { }
51 
53  : MArray<FloatComplex> (dim_vector (n, 1), val) { }
54 
56  : MArray<FloatComplex> (a) { }
57 
59  : MArray<FloatComplex> (a.as_column ()) { }
60 
62  : MArray<FloatComplex> (a.as_column ()) { }
63 
65 
67  {
69  return *this;
70  }
71 
73 
76 
77  // destructive insert/delete/reorder operations
78 
83 
87  fill (float val, octave_idx_type r1, octave_idx_type r2);
89  fill (const FloatComplex& val, octave_idx_type r1, octave_idx_type r2);
90 
93  stack (const FloatComplexColumnVector& a) const;
94 
97 
100 
101  // resize is the destructive equivalent for this one
102 
104  extract (octave_idx_type r1, octave_idx_type r2) const;
105 
108 
109  // column vector by column vector -> column vector operations
110 
115 
116  // matrix by column vector -> column vector operations
117 
120 
123 
124  // matrix by column vector -> column vector operations
125 
128 
129  // diagonal matrix by column vector -> column vector operations
130 
133 
136 
139 
140  // other operations
141 
142  OCTAVE_API FloatComplex min () const;
143  OCTAVE_API FloatComplex max () const;
144 
146 
147  // i/o
148 
149  friend OCTAVE_API std::ostream&
150  operator << (std::ostream& os, const FloatComplexColumnVector& a);
151  friend OCTAVE_API std::istream&
152  operator >> (std::istream& is, FloatComplexColumnVector& a);
153 
155  {
157  }
158 
160  { Array<FloatComplex>::clear (n, 1); }
161 
162 };
163 
165 
166 #endif
template std::ostream & operator<<(std::ostream &, const Array< bool > &)
ComplexColumnVector conj(const ComplexColumnVector &a)
Definition: CColVector.cc:217
#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
N Dimensional Array with copy-on-write semantics.
Definition: Array.h:130
void clear()
Definition: Array-base.cc:109
Array< T, Alloc > as_column() const
Return the array as a column vector.
Definition: Array.h:420
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 FloatComplex &rfv=FloatComplex(0))
Definition: fCColVector.h:154
FloatComplexColumnVector(octave_idx_type n)
Definition: fCColVector.h:46
FloatComplexColumnVector(const MArray< FloatComplex > &a)
Definition: fCColVector.h:58
void clear(octave_idx_type n)
Definition: fCColVector.h:159
FloatComplexColumnVector(const dim_vector &dv)
Definition: fCColVector.h:49
~FloatComplexColumnVector()=default
FloatComplexColumnVector(const Array< FloatComplex > &a)
Definition: fCColVector.h:61
FloatComplexColumnVector(const FloatComplexColumnVector &a)
Definition: fCColVector.h:55
FloatComplexColumnVector(octave_idx_type n, const FloatComplex &val)
Definition: fCColVector.h:52
FloatComplexRowVector & operator=(const FloatComplexRowVector &a)
Definition: fCRowVector.h:67
FloatComplexColumnVector hermitian() const
Definition: fCRowVector.cc:197
FloatComplexColumnVector transpose() const
Definition: fCRowVector.cc:203
FloatComplexRowVector & fill(float val)
Definition: fCRowVector.cc:100
FloatComplexRowVector & insert(const FloatRowVector &a, octave_idx_type c)
Definition: fCRowVector.cc:61
FloatComplexRowVector extract_n(octave_idx_type c1, octave_idx_type n) const
Definition: fCRowVector.cc:232
FloatComplexRowVector extract(octave_idx_type c1, octave_idx_type c2) const
Definition: fCRowVector.cc:217
friend class FloatComplexColumnVector
Definition: fCRowVector.h:39
MArray< T > & operator=(const MArray< T > &a)
Definition: MArray.h:81
Vector representing the dimensions (size) of an Array.
Definition: dim-vector.h:94
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
FloatComplexColumnVector operator*(const FloatComplexColumnVector &x, const FloatComplex &y)
Definition: fCColVector.h:164
FloatComplexColumnVector operator+=(FloatComplexColumnVector &x, const FloatComplex &y)
Definition: fCColVector.h:164
FloatComplexColumnVector operator-=(FloatComplexColumnVector &x, const FloatComplex &y)
Definition: fCColVector.h:164
#define OCTAVE_API
Definition: main.cc:55
octave_idx_type n
Definition: mx-inlines.cc:761
T * r
Definition: mx-inlines.cc:781
std::complex< float > FloatComplex
Definition: oct-cmplx.h:34
template int8_t abs(int8_t)