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
fCRowVector.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_fCRowVector_h)
27 #define octave_fCRowVector_h 1
28 
29 #include "octave-config.h"
30 
31 #include "MArray.h"
32 #include "fRowVector.h"
33 #include "mx-defs.h"
34 
35 class
38 {
40 
41 public:
42 
44  : MArray<FloatComplex> (dim_vector (1, 0)) { }
45 
47  : MArray<FloatComplex> (dim_vector (1, n)) { }
48 
49  explicit FloatComplexRowVector (const dim_vector& dv)
50  : MArray<FloatComplex> (dv.as_row ()) { }
51 
53  : MArray<FloatComplex> (dim_vector (1, n), val) { }
54 
56  : MArray<FloatComplex> (a) { }
57 
59  : MArray<FloatComplex> (a.as_row ()) { }
60 
62  : MArray<FloatComplex> (a.as_row ()) { }
63 
65  : MArray<FloatComplex> (a) { }
66 
68  {
70  return *this;
71  }
72 
73  ~FloatComplexRowVector () = default;
74 
75  OCTAVE_API bool operator == (const FloatComplexRowVector& a) const;
76  OCTAVE_API bool operator != (const FloatComplexRowVector& a) const;
77 
78  // destructive insert/delete/reorder operations
79 
84 
88  fill (float val, octave_idx_type c1, octave_idx_type c2);
90  fill (const FloatComplex& val, octave_idx_type c1, octave_idx_type c2);
91 
92  OCTAVE_API FloatComplexRowVector append (const FloatRowVector& a) const;
94  append (const FloatComplexRowVector& a) const;
95 
98 
100  conj (const FloatComplexRowVector& a);
101 
102  // resize is the destructive equivalent for this one
103 
105  extract (octave_idx_type c1, octave_idx_type c2) const;
106 
109 
110  // row vector by row vector -> row vector operations
111 
114 
115  // row vector by matrix -> row vector
116 
119 
121  operator * (const FloatRowVector& a, const FloatComplexMatrix& b);
122 
123  // other operations
124 
125  OCTAVE_API FloatComplex min () const;
126  OCTAVE_API FloatComplex max () const;
127 
128  // i/o
129 
130  friend OCTAVE_API std::ostream&
131  operator << (std::ostream& os, const FloatComplexRowVector& a);
132  friend OCTAVE_API std::istream&
133  operator >> (std::istream& is, FloatComplexRowVector& a);
134 
136  {
138  }
139 
141  { Array<FloatComplex>::clear (1, n); }
142 
143 };
144 
145 // row vector by column vector -> scalar
146 
149 
152 
153 // other operations
154 
156 linspace (const FloatComplex& x1, const FloatComplex& x2, octave_idx_type n);
157 
159 
160 #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_row() const
Return the array as a row vector.
Definition: Array.h:431
void resize(const dim_vector &dv, const T &rfv)
Size of the specified dimension.
Definition: Array-base.cc:1023
FloatComplexColumnVector extract_n(octave_idx_type r1, octave_idx_type n) const
Definition: fCColVector.cc:242
FloatComplexColumnVector & operator=(const FloatComplexColumnVector &a)
Definition: fCColVector.h:66
FloatComplexRowVector hermitian() const
Definition: fCColVector.cc:201
FloatComplexColumnVector & insert(const FloatColumnVector &a, octave_idx_type r)
Definition: fCColVector.cc:64
FloatComplexColumnVector & fill(float val)
Definition: fCColVector.cc:103
FloatComplexColumnVector extract(octave_idx_type r1, octave_idx_type r2) const
Definition: fCColVector.cc:227
FloatComplexRowVector transpose() const
Definition: fCColVector.cc:207
void clear(octave_idx_type n)
Definition: fCRowVector.h:140
FloatComplexRowVector(octave_idx_type n)
Definition: fCRowVector.h:46
void resize(octave_idx_type n, const FloatComplex &rfv=FloatComplex(0))
Definition: fCRowVector.h:135
FloatComplexRowVector(const Array< FloatComplex > &a)
Definition: fCRowVector.h:61
~FloatComplexRowVector()=default
FloatComplexRowVector(const FloatComplexRowVector &a)
Definition: fCRowVector.h:55
FloatComplexRowVector(const MArray< FloatComplex > &a)
Definition: fCRowVector.h:58
FloatComplexRowVector(const FloatRowVector &a)
Definition: fCRowVector.h:64
FloatComplexRowVector(octave_idx_type n, const FloatComplex &val)
Definition: fCRowVector.h:52
FloatComplexRowVector(const dim_vector &dv)
Definition: fCRowVector.h:49
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
FloatComplexRowVector linspace(const FloatComplex &x1, const FloatComplex &x2, octave_idx_type n)
Definition: fCRowVector.cc:430
FloatComplexRowVector operator-=(FloatComplexRowVector &x, const FloatComplex &y)
Definition: fCRowVector.h:158
FloatComplex operator*(const FloatComplexRowVector &a, const ColumnVector &b)
FloatComplexRowVector operator+=(FloatComplexRowVector &x, const FloatComplex &y)
Definition: fCRowVector.h:158
#define OCTAVE_API
Definition: main.cc:55
octave_idx_type n
Definition: mx-inlines.cc:761
std::complex< float > FloatComplex
Definition: oct-cmplx.h:34