Branch data Line data Source code
1 : : /*
2 : : * tvector.h - simple vector template class definitions
3 : : *
4 : : * Copyright (C) 2004, 2005, 2006 Stefan Jahn <stefan@lkcc.org>
5 : : *
6 : : * This is free software; you can redistribute it and/or modify
7 : : * it under the terms of the GNU General Public License as published by
8 : : * the Free Software Foundation; either version 2, or (at your option)
9 : : * any later version.
10 : : *
11 : : * This software is distributed in the hope that it will be useful,
12 : : * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 : : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 : : * GNU General Public License for more details.
15 : : *
16 : : * You should have received a copy of the GNU General Public License
17 : : * along with this package; see the file COPYING. If not, write to
18 : : * the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
19 : : * Boston, MA 02110-1301, USA.
20 : : *
21 : : * $Id$
22 : : *
23 : : */
24 : :
25 : : #ifndef __TVECTOR_H__
26 : : #define __TVECTOR_H__
27 : :
28 : : #include <assert.h>
29 : :
30 : : #include <limits>
31 : :
32 : : #include "precision.h"
33 : :
34 : : namespace qucs {
35 : :
36 : : template <class nr_type_t>
37 : : class tvector;
38 : :
39 : : // Forward declarations of friend functions.
40 : : template <class nr_type_t>
41 : : nr_type_t scalar (tvector<nr_type_t>, tvector<nr_type_t>);
42 : : template <class nr_type_t>
43 : : nr_double_t maxnorm (tvector<nr_type_t>);
44 : : template <class nr_type_t>
45 : : nr_double_t norm (tvector<nr_type_t>);
46 : : template <class nr_type_t>
47 : : nr_type_t sum (tvector<nr_type_t>);
48 : : template <class nr_type_t>
49 : : tvector<nr_type_t> conj (tvector<nr_type_t>);
50 : : template <class nr_type_t>
51 : : tvector<nr_type_t> operator + (tvector<nr_type_t>, tvector<nr_type_t>);
52 : : template <class nr_type_t>
53 : : tvector<nr_type_t> operator + (tvector<nr_type_t>, nr_type_t);
54 : : template <class nr_type_t>
55 : : tvector<nr_type_t> operator + (nr_type_t, tvector<nr_type_t>);
56 : : template <class nr_type_t>
57 : : tvector<nr_type_t> operator - (tvector<nr_type_t>, tvector<nr_type_t>);
58 : : template <class nr_type_t>
59 : : tvector<nr_type_t> operator * (tvector<nr_type_t>, nr_double_t);
60 : : template <class nr_type_t>
61 : : tvector<nr_type_t> operator * (nr_double_t, tvector<nr_type_t>);
62 : : template <class nr_type_t>
63 : : tvector<nr_type_t> operator * (tvector<nr_type_t>, tvector<nr_type_t>);
64 : : template <class nr_type_t>
65 : : tvector<nr_type_t> operator - (tvector<nr_type_t>);
66 : : template <class nr_type_t>
67 : : bool operator < (tvector<nr_type_t>, tvector<nr_type_t>);
68 : : template <class nr_type_t>
69 : : bool operator > (tvector<nr_type_t>, tvector<nr_type_t>);
70 : :
71 : : template <class nr_type_t>
72 : : class tvector
73 : : {
74 : : public:
75 : : tvector ();
76 : : tvector (int);
77 : : tvector (const tvector &);
78 : : const tvector& operator = (const tvector &);
79 : : ~tvector ();
80 : : nr_type_t get (int);
81 : : void set (int, nr_type_t);
82 : : void set (nr_type_t);
83 : : void set (nr_type_t, int, int);
84 : : void set (tvector, int, int);
85 : 878710 : int getSize (void) { return size; }
86 : 74 : nr_type_t * getData (void) { return data; }
87 : : void setData (nr_type_t *, int);
88 : : void add (nr_type_t);
89 : : void clear (void);
90 : : void drop (int);
91 : : void truncate (int);
92 : : void exchangeRows (int, int);
93 : : int isFinite (void);
94 : : void print (void);
95 : : void reorder (int *);
96 [ + - ]: 1 : int contains (nr_type_t, nr_double_t eps = std::numeric_limits<nr_double_t>::epsilon());
97 : :
98 : : // some basic vector operations
99 : : #ifndef _MSC_VER
100 : : friend tvector operator +<> (tvector, tvector);
101 : : friend tvector operator -<> (tvector, tvector);
102 : : friend tvector operator *<> (tvector, nr_double_t);
103 : : friend tvector operator *<> (nr_double_t, tvector);
104 : : friend tvector operator *<> (tvector, tvector);
105 : : friend tvector operator -<> (tvector);
106 : : friend tvector operator +<> (tvector, nr_type_t);
107 : : friend tvector operator +<> (nr_type_t, tvector);
108 : : #endif
109 : :
110 : : // other operations
111 : : #ifndef _MSC_VER
112 : : friend nr_double_t norm<> (tvector);
113 : : friend nr_double_t maxnorm<> (tvector);
114 : : friend nr_type_t sum<> (tvector);
115 : : friend nr_type_t scalar<> (tvector, tvector);
116 : : friend tvector conj<> (tvector);
117 : : #endif
118 : :
119 : : // comparisons
120 : : #ifndef _MSC_VER
121 : : friend bool operator < <> (tvector, tvector);
122 : : friend bool operator > <> (tvector, tvector);
123 : : #endif
124 : :
125 : : // intrinsic operators
126 : : tvector operator += (tvector);
127 : : tvector operator -= (tvector);
128 : : tvector operator *= (nr_double_t);
129 : : tvector operator /= (nr_double_t);
130 : :
131 : : // assignment operators
132 : : tvector operator = (const nr_type_t);
133 : :
134 : : // easy accessor operators
135 : : nr_type_t operator () (int i) const {
136 : : assert (i >= 0 && i < size); return data[i]; }
137 : 79666248 : nr_type_t& operator () (int i) {
138 [ + - ][ - + ]: 79666248 : assert (i >= 0 && i < size); return data[i]; }
[ - + ][ + - ]
[ - + ][ - + ]
139 : :
140 : : private:
141 : : int external;
142 : : int size;
143 : : int capacity;
144 : : nr_type_t * data;
145 : : };
146 : :
147 : : } // namespace qucs
148 : :
149 : : #include "tvector.cpp"
150 : :
151 : : #endif /* __TVECTOR_H__ */
|