3741
|
1 #if !defined (octave_MArray_defs_h) |
|
2 #define octave_MArray_defs_h 1 |
|
3 |
3649
|
4 // Nothing like a little CPP abuse to brighten everyone's day. |
1988
|
5 |
3504
|
6 #define DO_VS_OP(r, l, v, OP, s) \ |
1988
|
7 if (l > 0) \ |
|
8 { \ |
5275
|
9 for (octave_idx_type i = 0; i < l; i++) \ |
3504
|
10 r[i] = v[i] OP s; \ |
1988
|
11 } |
|
12 |
3504
|
13 #define DO_SV_OP(r, l, s, OP, v) \ |
1988
|
14 if (l > 0) \ |
|
15 { \ |
5275
|
16 for (octave_idx_type i = 0; i < l; i++) \ |
3504
|
17 r[i] = s OP v[i]; \ |
1988
|
18 } |
|
19 |
3504
|
20 #define DO_VV_OP(r, l, x, OP, y) \ |
1988
|
21 if (l > 0) \ |
|
22 { \ |
5275
|
23 for (octave_idx_type i = 0; i < l; i++) \ |
3504
|
24 r[i] = x[i] OP y[i]; \ |
1988
|
25 } |
|
26 |
3504
|
27 #define NEG_V(r, l, x) \ |
1988
|
28 if (l > 0) \ |
|
29 { \ |
5275
|
30 for (octave_idx_type i = 0; i < l; i++) \ |
3504
|
31 r[i] = -x[i]; \ |
1988
|
32 } |
|
33 |
4646
|
34 #define DO_VS_OP2(T, a, OP, s) \ |
5275
|
35 octave_idx_type l = a.length (); \ |
1988
|
36 if (l > 0) \ |
|
37 { \ |
|
38 T *tmp = a.fortran_vec (); \ |
5275
|
39 for (octave_idx_type i = 0; i < l; i++) \ |
1988
|
40 tmp[i] OP s; \ |
|
41 } |
|
42 |
4646
|
43 #define DO_VV_OP2(T, a, OP, b) \ |
1988
|
44 do \ |
|
45 { \ |
|
46 T *a_tmp = a.fortran_vec (); \ |
|
47 const T *b_tmp = b.data (); \ |
5275
|
48 for (octave_idx_type i = 0; i < l; i++) \ |
3243
|
49 a_tmp[i] OP b_tmp[i]; \ |
1988
|
50 } \ |
|
51 while (0) |
|
52 |
3573
|
53 // A macro that can be used to declare and instantiate OP= operators. |
6708
|
54 #define MARRAY_OP_ASSIGN_DECL(A_T, E_T, OP, PFX, API, LTGT, RHS_T) \ |
|
55 PFX API A_T<E_T>& \ |
3573
|
56 operator OP LTGT (A_T<E_T>&, const RHS_T&) |
|
57 |
|
58 // All the OP= operators that we care about. |
6708
|
59 #define MARRAY_OP_ASSIGN_DECLS(A_T, E_T, PFX, API, LTGT, RHS_T) \ |
|
60 MARRAY_OP_ASSIGN_DECL (A_T, E_T, +=, PFX, API, LTGT, RHS_T); \ |
|
61 MARRAY_OP_ASSIGN_DECL (A_T, E_T, -=, PFX, API, LTGT, RHS_T); |
3573
|
62 |
|
63 // Generate forward declarations for OP= operators. |
6708
|
64 #define MARRAY_OP_ASSIGN_FWD_DECLS(A_T, RHS_T, API) \ |
|
65 MARRAY_OP_ASSIGN_DECLS (A_T, T, template <typename T>, API, , RHS_T) |
3573
|
66 |
|
67 // Generate friend declarations for the OP= operators. |
6708
|
68 #define MARRAY_OP_ASSIGN_FRIENDS(A_T, RHS_T, API) \ |
|
69 MARRAY_OP_ASSIGN_DECLS (A_T, T, friend, API, <>, RHS_T) |
3573
|
70 |
|
71 // Instantiate the OP= operators. |
6708
|
72 #define MARRAY_OP_ASSIGN_DEFS(A_T, E_T, RHS_T, API) \ |
|
73 MARRAY_OP_ASSIGN_DECLS (A_T, E_T, template, API, , RHS_T) |
3573
|
74 |
|
75 // A function that can be used to forward OP= operations from derived |
|
76 // classes back to us. |
|
77 #define MARRAY_OP_ASSIGN_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \ |
|
78 inline R \ |
|
79 F (X_T& x, const Y_T& y) \ |
|
80 { \ |
|
81 return R (F (C_X (x), C_Y (y))); \ |
|
82 } |
|
83 |
|
84 // All the OP= operators that we care about forwarding. |
|
85 #define MARRAY_OP_ASSIGN_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
86 MARRAY_OP_ASSIGN_FWD_FCN (R, operator +=, T, C_X, X_T, C_Y, Y_T) \ |
|
87 MARRAY_OP_ASSIGN_FWD_FCN (R, operator -=, T, C_X, X_T, C_Y, Y_T) |
|
88 |
|
89 // A macro that can be used to declare and instantiate unary operators. |
6708
|
90 #define MARRAY_UNOP(A_T, E_T, F, PFX, API, LTGT) \ |
|
91 PFX API A_T<E_T> \ |
3573
|
92 F LTGT (const A_T<E_T>&) |
|
93 |
|
94 // All the unary operators that we care about. |
6708
|
95 #define MARRAY_UNOP_DECLS(A_T, E_T, PFX, API, LTGT) \ |
|
96 MARRAY_UNOP (A_T, E_T, operator +, PFX, API, LTGT); \ |
|
97 MARRAY_UNOP (A_T, E_T, operator -, PFX, API, LTGT); |
3573
|
98 |
|
99 // Generate forward declarations for unary operators. |
6708
|
100 #define MARRAY_UNOP_FWD_DECLS(A_T, API) \ |
|
101 MARRAY_UNOP_DECLS (A_T, T, template <typename T>, API, ) |
3573
|
102 |
|
103 // Generate friend declarations for the unary operators. |
6708
|
104 #define MARRAY_UNOP_FRIENDS(A_T, API) \ |
|
105 MARRAY_UNOP_DECLS (A_T, T, friend, API, <>) |
3573
|
106 |
|
107 // Instantiate the unary operators. |
6708
|
108 #define MARRAY_UNOP_DEFS(A_T, E_T, API) \ |
|
109 MARRAY_UNOP_DECLS (A_T, E_T, template, API, ) |
3573
|
110 |
|
111 // A function that can be used to forward unary operations from derived |
|
112 // classes back to us. |
|
113 #define MARRAY_UNOP_FWD_FCN(R, F, T, C_X, X_T) \ |
|
114 inline R \ |
|
115 F (const X_T& x) \ |
|
116 { \ |
|
117 return R (F (C_X (x))); \ |
|
118 } |
|
119 |
|
120 // All the unary operators that we care about forwarding. |
|
121 #define MARRAY_UNOP_FWD_DEFS(R, T, C_X, X_T) \ |
|
122 MARRAY_UNOP_FWD_FCN (R, operator +, T, C_X, X_T) \ |
|
123 MARRAY_UNOP_FWD_FCN (R, operator -, T, C_X, X_T) |
|
124 |
|
125 // A macro that can be used to declare and instantiate binary operators. |
6708
|
126 #define MARRAY_BINOP_DECL(A_T, E_T, F, PFX, API, LTGT, X_T, Y_T) \ |
|
127 PFX API A_T<E_T> \ |
3573
|
128 F LTGT (const X_T&, const Y_T&) |
|
129 |
|
130 // All the binary operators that we care about. We have two |
|
131 // sets of macros since the MArray OP MArray operations use functions |
|
132 // (product and quotient) instead of operators (*, /). |
6708
|
133 #define MARRAY_BINOP_DECLS(A_T, E_T, PFX, API, LTGT, X_T, Y_T) \ |
|
134 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, API, LTGT, X_T, Y_T); \ |
|
135 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, API, LTGT, X_T, Y_T); \ |
|
136 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, API, LTGT, X_T, Y_T); \ |
|
137 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, API, LTGT, X_T, Y_T); |
3573
|
138 |
6708
|
139 #define MARRAY_AA_BINOP_DECLS(A_T, E_T, PFX, API, LTGT) \ |
|
140 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
141 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
142 MARRAY_BINOP_DECL (A_T, E_T, quotient, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
143 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); |
3573
|
144 |
6708
|
145 #define MDIAGARRAY2_DAS_BINOP_DECLS(A_T, E_T, PFX, API, LTGT, X_T, Y_T) \ |
|
146 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, API, LTGT, X_T, Y_T); \ |
|
147 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, API, LTGT, X_T, Y_T); |
3580
|
148 |
6708
|
149 #define MDIAGARRAY2_SDA_BINOP_DECLS(A_T, E_T, PFX, API, LTGT, X_T, Y_T) \ |
|
150 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, API, LTGT, X_T, Y_T); |
3580
|
151 |
6708
|
152 #define MDIAGARRAY2_DADA_BINOP_DECLS(A_T, E_T, PFX, API, LTGT) \ |
|
153 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
154 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
155 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, API, LTGT, A_T<E_T>, A_T<E_T>); |
3580
|
156 |
3573
|
157 // Generate forward declarations for binary operators. |
6708
|
158 #define MARRAY_BINOP_FWD_DECLS(A_T, API) \ |
|
159 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, API, , A_T<T>, T) \ |
|
160 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, API, , T, A_T<T>) \ |
|
161 MARRAY_AA_BINOP_DECLS (A_T, T, template <typename T>, API, ) |
3573
|
162 |
6708
|
163 #define MDIAGARRAY2_BINOP_FWD_DECLS(A_T, API) \ |
|
164 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, template <typename T>, API, , A_T<T>, T) \ |
|
165 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, template <typename T>, API, , T, A_T<T>) \ |
|
166 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, template <typename T>, API, ) |
3580
|
167 |
3573
|
168 // Generate friend declarations for the binary operators. |
6708
|
169 #define MARRAY_BINOP_FRIENDS(A_T, API) \ |
|
170 MARRAY_BINOP_DECLS (A_T, T, friend, API, <>, A_T<T>, T) \ |
|
171 MARRAY_BINOP_DECLS (A_T, T, friend, API, <>, T, A_T<T>) \ |
|
172 MARRAY_AA_BINOP_DECLS (A_T, T, friend, API, <>) |
3573
|
173 |
6708
|
174 #define MDIAGARRAY2_BINOP_FRIENDS(A_T, API) \ |
|
175 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, friend, API, <>, A_T<T>, T) \ |
|
176 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, friend, API, <>, T, A_T<T>) \ |
|
177 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, friend, API, <>) |
3580
|
178 |
3573
|
179 // Instantiate the binary operators. |
6708
|
180 #define MARRAY_BINOP_DEFS(A_T, E_T, API) \ |
|
181 MARRAY_BINOP_DECLS (A_T, E_T, template, API, , A_T<E_T>, E_T) \ |
|
182 MARRAY_BINOP_DECLS (A_T, E_T, template, API, , E_T, A_T<E_T>) \ |
|
183 MARRAY_AA_BINOP_DECLS (A_T, E_T, template, API, ) |
3573
|
184 |
6708
|
185 #define MDIAGARRAY2_BINOP_DEFS(A_T, E_T, API) \ |
|
186 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, E_T, template, API, , A_T<E_T>, E_T) \ |
|
187 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, E_T, template, API, , E_T, A_T<E_T>) \ |
|
188 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, E_T, template, API, ) |
3580
|
189 |
3573
|
190 // A function that can be used to forward binary operations from derived |
|
191 // classes back to us. |
|
192 #define MARRAY_BINOP_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \ |
|
193 inline R \ |
|
194 F (const X_T& x, const Y_T& y) \ |
|
195 { \ |
|
196 return R (F (C_X (x), C_Y (y))); \ |
|
197 } |
|
198 |
|
199 // The binary operators that we care about forwarding. We have two |
|
200 // sets of macros since the MArray OP MArray operations use functions |
|
201 // (product and quotient) instead of operators (*, /). |
|
202 #define MARRAY_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
203 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \ |
|
204 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
205 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) \ |
|
206 MARRAY_BINOP_FWD_FCN (R, operator /, T, C_X, X_T, C_Y, Y_T) |
|
207 |
|
208 #define MARRAY_AA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
209 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \ |
|
210 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
211 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T) \ |
|
212 MARRAY_BINOP_FWD_FCN (R, quotient, T, C_X, X_T, C_Y, Y_T) |
|
213 |
3580
|
214 #define MDIAGARRAY2_DAS_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
215 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) \ |
|
216 MARRAY_BINOP_FWD_FCN (R, operator /, T, C_X, X_T, C_Y, Y_T) |
|
217 |
|
218 #define MDIAGARRAY2_SDA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
219 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) |
|
220 |
|
221 #define MDIAGARRAY2_DADA_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
222 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \ |
|
223 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
224 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T) |
|
225 |
3573
|
226 // Forward declarations for the MArray operators. |
6708
|
227 #define MARRAY_OPS_FORWARD_DECLS(A_T, API) \ |
3573
|
228 template <class T> \ |
|
229 class A_T; \ |
|
230 \ |
6708
|
231 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, T, API) \ |
|
232 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>, API) \ |
|
233 MARRAY_UNOP_FWD_DECLS (A_T, API) \ |
|
234 MARRAY_BINOP_FWD_DECLS (A_T, API) |
3573
|
235 |
6708
|
236 #define MDIAGARRAY2_OPS_FORWARD_DECLS(A_T, API) \ |
3580
|
237 template <class T> \ |
|
238 class A_T; \ |
|
239 \ |
6708
|
240 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>, API) \ |
|
241 MARRAY_UNOP_FWD_DECLS (A_T, API) \ |
|
242 MDIAGARRAY2_BINOP_FWD_DECLS (A_T, API) |
3580
|
243 |
3573
|
244 // Friend declarations for the MArray operators. |
6708
|
245 #define MARRAY_OPS_FRIEND_DECLS(A_T, API) \ |
|
246 MARRAY_OP_ASSIGN_FRIENDS (A_T, T, API) \ |
|
247 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>, API) \ |
|
248 MARRAY_UNOP_FRIENDS (A_T, API) \ |
|
249 MARRAY_BINOP_FRIENDS (A_T, API) |
3573
|
250 |
6708
|
251 #define MDIAGARRAY2_OPS_FRIEND_DECLS(A_T, API) \ |
|
252 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>, API) \ |
|
253 MARRAY_UNOP_FRIENDS (A_T, API) \ |
|
254 MDIAGARRAY2_BINOP_FRIENDS (A_T, API) |
3580
|
255 |
3573
|
256 // The following macros are for external use. |
|
257 |
|
258 // Instantiate all the MArray friends for MArray element type T. |
6708
|
259 #define INSTANTIATE_MARRAY_FRIENDS(T, API) \ |
|
260 MARRAY_OP_ASSIGN_DEFS (MArray, T, T, API) \ |
|
261 MARRAY_OP_ASSIGN_DEFS (MArray, T, MArray<T>, API) \ |
|
262 MARRAY_UNOP_DEFS (MArray, T, API) \ |
|
263 MARRAY_BINOP_DEFS (MArray, T, API) |
3573
|
264 |
4513
|
265 // Instantiate all the MArray2 friends for MArray2 element type T. |
6708
|
266 #define INSTANTIATE_MARRAY2_FRIENDS(T, API) \ |
|
267 MARRAY_OP_ASSIGN_DEFS (MArray2, T, T, API) \ |
|
268 MARRAY_OP_ASSIGN_DEFS (MArray2, T, MArray2<T>, API) \ |
|
269 MARRAY_UNOP_DEFS (MArray2, T, API) \ |
|
270 MARRAY_BINOP_DEFS (MArray2, T, API) |
3573
|
271 |
4513
|
272 // Instantiate all the MArrayN friends for MArrayN element type T. |
6708
|
273 #define INSTANTIATE_MARRAYN_FRIENDS(T, API) \ |
|
274 MARRAY_OP_ASSIGN_DEFS (MArrayN, T, T, API) \ |
|
275 MARRAY_OP_ASSIGN_DEFS (MArrayN, T, MArrayN<T>, API) \ |
|
276 MARRAY_UNOP_DEFS (MArrayN, T, API) \ |
|
277 MARRAY_BINOP_DEFS (MArrayN, T, API) |
4513
|
278 |
|
279 // Instantiate all the MDiagArray2 friends for MDiagArray2 element type T. |
6708
|
280 #define INSTANTIATE_MDIAGARRAY2_FRIENDS(T, API) \ |
|
281 MARRAY_OP_ASSIGN_DEFS (MDiagArray2, T, MDiagArray2<T>, API) \ |
|
282 MARRAY_UNOP_DEFS (MDiagArray2, T, API) \ |
|
283 MDIAGARRAY2_BINOP_DEFS (MDiagArray2, T, API) |
3580
|
284 |
3573
|
285 // Define all the MArray forwarding functions for return type R and |
|
286 // MArray element type T |
|
287 #define MARRAY_FORWARD_DEFS(B, R, T) \ |
|
288 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
289 (R, T, dynamic_cast<B<T>&>, R, , T) \ |
|
290 \ |
|
291 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
292 (R, T, \ |
|
293 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \ |
|
294 \ |
|
295 MARRAY_UNOP_FWD_DEFS \ |
|
296 (R, T, dynamic_cast<const B<T>&>, R) \ |
|
297 \ |
|
298 MARRAY_BINOP_FWD_DEFS \ |
|
299 (R, T, dynamic_cast<const B<T>&>, R, , T) \ |
|
300 \ |
|
301 MARRAY_BINOP_FWD_DEFS \ |
|
302 (R, T, , T, dynamic_cast<const B<T>&>, R) \ |
|
303 \ |
|
304 MARRAY_AA_BINOP_FWD_DEFS \ |
|
305 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R) |
|
306 |
3580
|
307 #define MDIAGARRAY2_FORWARD_DEFS(B, R, T) \ |
|
308 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
309 (R, T, \ |
|
310 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \ |
|
311 \ |
|
312 MARRAY_UNOP_FWD_DEFS \ |
|
313 (R, T, dynamic_cast<const B<T>&>, R) \ |
|
314 \ |
|
315 MDIAGARRAY2_DAS_BINOP_FWD_DEFS \ |
|
316 (R, T, dynamic_cast<const B<T>&>, R, , T) \ |
|
317 \ |
|
318 MDIAGARRAY2_SDA_BINOP_FWD_DEFS \ |
|
319 (R, T, , T, dynamic_cast<const B<T>&>, R) \ |
|
320 \ |
|
321 MDIAGARRAY2_DADA_BINOP_FWD_DEFS \ |
|
322 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R) |
|
323 |
6508
|
324 #define MARRAY_NORM_BODY(TYPE, blas_norm, BLAS_NORM) \ |
|
325 \ |
|
326 double retval = octave_NaN; \ |
|
327 \ |
|
328 octave_idx_type len = length (); \ |
|
329 \ |
|
330 if (len > 0) \ |
|
331 { \ |
|
332 const TYPE *d = data (); \ |
|
333 \ |
|
334 if (p == -1) \ |
|
335 { \ |
|
336 /* Frobenius norm. */ \ |
|
337 retval = 0; \ |
|
338 \ |
|
339 for (octave_idx_type i = 0; i < len; i++) \ |
|
340 { \ |
|
341 double d_abs = std::abs (d[i]); \ |
|
342 retval += d_abs * d_abs; \ |
|
343 } \ |
|
344 \ |
|
345 retval = ::sqrt (retval); \ |
|
346 } \ |
|
347 else if (p == 2) \ |
|
348 F77_FCN (blas_norm, BLAS_NORM) (len, d, 1, retval); \ |
|
349 else if (xisinf (p)) \ |
|
350 { \ |
|
351 octave_idx_type i = 0; \ |
|
352 \ |
|
353 while (i < len && xisnan (d[i])) \ |
|
354 i++; \ |
|
355 \ |
|
356 if (i < len) \ |
|
357 retval = std::abs (d[i]); \ |
|
358 \ |
|
359 if (p > 0) \ |
|
360 { \ |
|
361 while (i < len) \ |
|
362 { \ |
|
363 double d_abs = std::abs (d[i++]); \ |
|
364 \ |
|
365 if (d_abs > retval) \ |
|
366 retval = d_abs; \ |
|
367 } \ |
|
368 } \ |
|
369 else \ |
|
370 { \ |
|
371 while (i < len) \ |
|
372 { \ |
|
373 double d_abs = std::abs (d[i++]); \ |
|
374 \ |
|
375 if (d_abs < retval) \ |
|
376 retval = d_abs; \ |
|
377 } \ |
|
378 } \ |
|
379 } \ |
|
380 else \ |
|
381 { \ |
|
382 retval = 0; \ |
|
383 \ |
|
384 for (octave_idx_type i = 0; i < len; i++) \ |
|
385 { \ |
|
386 double d_abs = std::abs (d[i]); \ |
|
387 retval += pow (d_abs, p); \ |
|
388 } \ |
|
389 \ |
|
390 retval = pow (retval, 1/p); \ |
|
391 } \ |
|
392 } \ |
|
393 \ |
|
394 return retval |
|
395 |
3573
|
396 // Now we have all the definitions we need. |
|
397 |
3741
|
398 #endif |