3649
|
1 // Nothing like a little CPP abuse to brighten everyone's day. |
1988
|
2 |
3504
|
3 #define DO_VS_OP(r, l, v, OP, s) \ |
1988
|
4 if (l > 0) \ |
|
5 { \ |
|
6 for (int i = 0; i < l; i++) \ |
3504
|
7 r[i] = v[i] OP s; \ |
1988
|
8 } |
|
9 |
3504
|
10 #define DO_SV_OP(r, l, s, OP, v) \ |
1988
|
11 if (l > 0) \ |
|
12 { \ |
|
13 for (int i = 0; i < l; i++) \ |
3504
|
14 r[i] = s OP v[i]; \ |
1988
|
15 } |
|
16 |
3504
|
17 #define DO_VV_OP(r, l, x, OP, y) \ |
1988
|
18 if (l > 0) \ |
|
19 { \ |
|
20 for (int i = 0; i < l; i++) \ |
3504
|
21 r[i] = x[i] OP y[i]; \ |
1988
|
22 } |
|
23 |
3504
|
24 #define NEG_V(r, l, x) \ |
1988
|
25 if (l > 0) \ |
|
26 { \ |
|
27 for (int i = 0; i < l; i++) \ |
3504
|
28 r[i] = -x[i]; \ |
1988
|
29 } |
|
30 |
|
31 #define DO_VS_OP2(OP) \ |
|
32 int l = a.length (); \ |
|
33 if (l > 0) \ |
|
34 { \ |
|
35 T *tmp = a.fortran_vec (); \ |
|
36 for (int i = 0; i < l; i++) \ |
|
37 tmp[i] OP s; \ |
|
38 } |
|
39 |
|
40 #define DO_VV_OP2(OP) \ |
|
41 do \ |
|
42 { \ |
|
43 T *a_tmp = a.fortran_vec (); \ |
|
44 const T *b_tmp = b.data (); \ |
|
45 for (int i = 0; i < l; i++) \ |
3243
|
46 a_tmp[i] OP b_tmp[i]; \ |
1988
|
47 } \ |
|
48 while (0) |
|
49 |
3573
|
50 // A macro that can be used to declare and instantiate OP= operators. |
|
51 #define MARRAY_OP_ASSIGN_DECL(A_T, E_T, OP, PFX, LTGT, RHS_T) \ |
|
52 PFX A_T<E_T>& \ |
|
53 operator OP LTGT (A_T<E_T>&, const RHS_T&) |
|
54 |
|
55 // All the OP= operators that we care about. |
|
56 #define MARRAY_OP_ASSIGN_DECLS(A_T, E_T, PFX, LTGT, RHS_T) \ |
|
57 MARRAY_OP_ASSIGN_DECL (A_T, E_T, +=, PFX, LTGT, RHS_T); \ |
|
58 MARRAY_OP_ASSIGN_DECL (A_T, E_T, -=, PFX, LTGT, RHS_T); |
|
59 |
|
60 // Generate forward declarations for OP= operators. |
3580
|
61 #define MARRAY_OP_ASSIGN_FWD_DECLS(A_T, RHS_T) \ |
|
62 MARRAY_OP_ASSIGN_DECLS (A_T, T, template <typename T>, , RHS_T) |
3573
|
63 |
|
64 // Generate friend declarations for the OP= operators. |
3580
|
65 #define MARRAY_OP_ASSIGN_FRIENDS(A_T, RHS_T) \ |
|
66 MARRAY_OP_ASSIGN_DECLS (A_T, T, friend, <>, RHS_T) |
3573
|
67 |
|
68 // Instantiate the OP= operators. |
3580
|
69 #define MARRAY_OP_ASSIGN_DEFS(A_T, E_T, RHS_T) \ |
|
70 MARRAY_OP_ASSIGN_DECLS (A_T, E_T, template, , RHS_T) |
3573
|
71 |
|
72 // A function that can be used to forward OP= operations from derived |
|
73 // classes back to us. |
|
74 #define MARRAY_OP_ASSIGN_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \ |
|
75 inline R \ |
|
76 F (X_T& x, const Y_T& y) \ |
|
77 { \ |
|
78 return R (F (C_X (x), C_Y (y))); \ |
|
79 } |
|
80 |
|
81 // All the OP= operators that we care about forwarding. |
|
82 #define MARRAY_OP_ASSIGN_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
83 MARRAY_OP_ASSIGN_FWD_FCN (R, operator +=, T, C_X, X_T, C_Y, Y_T) \ |
|
84 MARRAY_OP_ASSIGN_FWD_FCN (R, operator -=, T, C_X, X_T, C_Y, Y_T) |
|
85 |
|
86 // A macro that can be used to declare and instantiate unary operators. |
|
87 #define MARRAY_UNOP(A_T, E_T, F, PFX, LTGT) \ |
|
88 PFX A_T<E_T> \ |
|
89 F LTGT (const A_T<E_T>&) |
|
90 |
|
91 // All the unary operators that we care about. |
|
92 #define MARRAY_UNOP_DECLS(A_T, E_T, PFX, LTGT) \ |
|
93 MARRAY_UNOP (A_T, E_T, operator +, PFX, LTGT); \ |
|
94 MARRAY_UNOP (A_T, E_T, operator -, PFX, LTGT); |
|
95 |
|
96 // Generate forward declarations for unary operators. |
|
97 #define MARRAY_UNOP_FWD_DECLS(A_T) \ |
|
98 MARRAY_UNOP_DECLS (A_T, T, template <typename T>, ) |
|
99 |
|
100 // Generate friend declarations for the unary operators. |
|
101 #define MARRAY_UNOP_FRIENDS(A_T) \ |
|
102 MARRAY_UNOP_DECLS (A_T, T, friend, <>) |
|
103 |
|
104 // Instantiate the unary operators. |
|
105 #define MARRAY_UNOP_DEFS(A_T, E_T) \ |
|
106 MARRAY_UNOP_DECLS (A_T, E_T, template, ) |
|
107 |
|
108 // A function that can be used to forward unary operations from derived |
|
109 // classes back to us. |
|
110 #define MARRAY_UNOP_FWD_FCN(R, F, T, C_X, X_T) \ |
|
111 inline R \ |
|
112 F (const X_T& x) \ |
|
113 { \ |
|
114 return R (F (C_X (x))); \ |
|
115 } |
|
116 |
|
117 // All the unary operators that we care about forwarding. |
|
118 #define MARRAY_UNOP_FWD_DEFS(R, T, C_X, X_T) \ |
|
119 MARRAY_UNOP_FWD_FCN (R, operator +, T, C_X, X_T) \ |
|
120 MARRAY_UNOP_FWD_FCN (R, operator -, T, C_X, X_T) |
|
121 |
|
122 // A macro that can be used to declare and instantiate binary operators. |
|
123 #define MARRAY_BINOP_DECL(A_T, E_T, F, PFX, LTGT, X_T, Y_T) \ |
|
124 PFX A_T<E_T> \ |
|
125 F LTGT (const X_T&, const Y_T&) |
|
126 |
|
127 // All the binary operators that we care about. We have two |
|
128 // sets of macros since the MArray OP MArray operations use functions |
|
129 // (product and quotient) instead of operators (*, /). |
|
130 #define MARRAY_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \ |
|
131 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, X_T, Y_T); \ |
|
132 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, X_T, Y_T); \ |
|
133 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T); \ |
|
134 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, LTGT, X_T, Y_T); |
|
135 |
|
136 #define MARRAY_AA_BINOP_DECLS(A_T, E_T, PFX, LTGT) \ |
|
137 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
138 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
139 MARRAY_BINOP_DECL (A_T, E_T, quotient, PFX, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
140 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, LTGT, A_T<E_T>, A_T<E_T>); |
|
141 |
3580
|
142 #define MDIAGARRAY2_DAS_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \ |
|
143 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T); \ |
|
144 MARRAY_BINOP_DECL (A_T, E_T, operator /, PFX, LTGT, X_T, Y_T); |
|
145 |
|
146 #define MDIAGARRAY2_SDA_BINOP_DECLS(A_T, E_T, PFX, LTGT, X_T, Y_T) \ |
|
147 MARRAY_BINOP_DECL (A_T, E_T, operator *, PFX, LTGT, X_T, Y_T); |
|
148 |
|
149 #define MDIAGARRAY2_DADA_BINOP_DECLS(A_T, E_T, PFX, LTGT) \ |
|
150 MARRAY_BINOP_DECL (A_T, E_T, operator +, PFX, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
151 MARRAY_BINOP_DECL (A_T, E_T, operator -, PFX, LTGT, A_T<E_T>, A_T<E_T>); \ |
|
152 MARRAY_BINOP_DECL (A_T, E_T, product, PFX, LTGT, A_T<E_T>, A_T<E_T>); |
|
153 |
3573
|
154 // Generate forward declarations for binary operators. |
|
155 #define MARRAY_BINOP_FWD_DECLS(A_T) \ |
|
156 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, , A_T<T>, T) \ |
|
157 MARRAY_BINOP_DECLS (A_T, T, template <typename T>, , T, A_T<T>) \ |
|
158 MARRAY_AA_BINOP_DECLS (A_T, T, template <typename T>, ) |
|
159 |
3580
|
160 #define MDIAGARRAY2_BINOP_FWD_DECLS(A_T) \ |
|
161 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, template <typename T>, , A_T<T>, T) \ |
|
162 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, template <typename T>, , T, A_T<T>) \ |
|
163 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, template <typename T>, ) |
|
164 |
3573
|
165 // Generate friend declarations for the binary operators. |
|
166 #define MARRAY_BINOP_FRIENDS(A_T) \ |
|
167 MARRAY_BINOP_DECLS (A_T, T, friend, <>, A_T<T>, T) \ |
|
168 MARRAY_BINOP_DECLS (A_T, T, friend, <>, T, A_T<T>) \ |
|
169 MARRAY_AA_BINOP_DECLS (A_T, T, friend, <>) |
|
170 |
3580
|
171 #define MDIAGARRAY2_BINOP_FRIENDS(A_T) \ |
|
172 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, T, friend, <>, A_T<T>, T) \ |
|
173 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, T, friend, <>, T, A_T<T>) \ |
|
174 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, T, friend, <>) |
|
175 |
3573
|
176 // Instantiate the binary operators. |
|
177 #define MARRAY_BINOP_DEFS(A_T, E_T) \ |
|
178 MARRAY_BINOP_DECLS (A_T, E_T, template, , A_T<E_T>, E_T) \ |
|
179 MARRAY_BINOP_DECLS (A_T, E_T, template, , E_T, A_T<E_T>) \ |
|
180 MARRAY_AA_BINOP_DECLS (A_T, E_T, template, ) |
|
181 |
3580
|
182 #define MDIAGARRAY2_BINOP_DEFS(A_T, E_T) \ |
|
183 MDIAGARRAY2_DAS_BINOP_DECLS (A_T, E_T, template, , A_T<E_T>, E_T) \ |
|
184 MDIAGARRAY2_SDA_BINOP_DECLS (A_T, E_T, template, , E_T, A_T<E_T>) \ |
|
185 MDIAGARRAY2_DADA_BINOP_DECLS (A_T, E_T, template, ) |
|
186 |
3573
|
187 // A function that can be used to forward binary operations from derived |
|
188 // classes back to us. |
|
189 #define MARRAY_BINOP_FWD_FCN(R, F, T, C_X, X_T, C_Y, Y_T) \ |
|
190 inline R \ |
|
191 F (const X_T& x, const Y_T& y) \ |
|
192 { \ |
|
193 return R (F (C_X (x), C_Y (y))); \ |
|
194 } |
|
195 |
|
196 // The binary operators that we care about forwarding. We have two |
|
197 // sets of macros since the MArray OP MArray operations use functions |
|
198 // (product and quotient) instead of operators (*, /). |
|
199 #define MARRAY_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
200 MARRAY_BINOP_FWD_FCN (R, operator +, T, C_X, X_T, C_Y, Y_T) \ |
|
201 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
202 MARRAY_BINOP_FWD_FCN (R, operator *, 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 |
|
205 #define MARRAY_AA_BINOP_FWD_DEFS(R, 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 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
208 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T) \ |
|
209 MARRAY_BINOP_FWD_FCN (R, quotient, T, C_X, X_T, C_Y, Y_T) |
|
210 |
3580
|
211 #define MDIAGARRAY2_DAS_BINOP_FWD_DEFS(R, T, C_X, X_T, C_Y, Y_T) \ |
|
212 MARRAY_BINOP_FWD_FCN (R, operator *, T, C_X, X_T, C_Y, Y_T) \ |
|
213 MARRAY_BINOP_FWD_FCN (R, operator /, T, C_X, X_T, C_Y, Y_T) |
|
214 |
|
215 #define MDIAGARRAY2_SDA_BINOP_FWD_DEFS(R, 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_DADA_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 MARRAY_BINOP_FWD_FCN (R, operator -, T, C_X, X_T, C_Y, Y_T) \ |
|
221 MARRAY_BINOP_FWD_FCN (R, product, T, C_X, X_T, C_Y, Y_T) |
|
222 |
3573
|
223 // Forward declarations for the MArray operators. |
|
224 #define MARRAY_OPS_FORWARD_DECLS(A_T) \ |
|
225 template <class T> \ |
|
226 class A_T; \ |
|
227 \ |
3580
|
228 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, T) \ |
|
229 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>) \ |
3573
|
230 MARRAY_UNOP_FWD_DECLS (A_T) \ |
|
231 MARRAY_BINOP_FWD_DECLS (A_T) |
|
232 |
3580
|
233 #define MDIAGARRAY2_OPS_FORWARD_DECLS(A_T) \ |
|
234 template <class T> \ |
|
235 class A_T; \ |
|
236 \ |
|
237 MARRAY_OP_ASSIGN_FWD_DECLS (A_T, A_T<T>) \ |
|
238 MARRAY_UNOP_FWD_DECLS (A_T) \ |
|
239 MDIAGARRAY2_BINOP_FWD_DECLS (A_T) |
|
240 |
3573
|
241 // Friend declarations for the MArray operators. |
|
242 #define MARRAY_OPS_FRIEND_DECLS(A_T) \ |
3580
|
243 MARRAY_OP_ASSIGN_FRIENDS (A_T, T) \ |
|
244 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>) \ |
3573
|
245 MARRAY_UNOP_FRIENDS (A_T) \ |
|
246 MARRAY_BINOP_FRIENDS (A_T) |
|
247 |
3580
|
248 #define MDIAGARRAY2_OPS_FRIEND_DECLS(A_T) \ |
|
249 MARRAY_OP_ASSIGN_FRIENDS (A_T, A_T<T>) \ |
|
250 MARRAY_UNOP_FRIENDS (A_T) \ |
|
251 MDIAGARRAY2_BINOP_FRIENDS (A_T) |
|
252 |
3573
|
253 // The following macros are for external use. |
|
254 |
|
255 // Instantiate all the MArray friends for MArray element type T. |
|
256 #define INSTANTIATE_MARRAY_FRIENDS(T) \ |
3581
|
257 MARRAY_OP_ASSIGN_DEFS (MArray, T, T) \ |
|
258 MARRAY_OP_ASSIGN_DEFS (MArray, T, MArray<T>) \ |
3573
|
259 MARRAY_UNOP_DEFS (MArray, T) \ |
|
260 MARRAY_BINOP_DEFS (MArray, T) |
|
261 |
|
262 // Instantiate all the MArray friends for MArray element type T. |
|
263 #define INSTANTIATE_MARRAY2_FRIENDS(T) \ |
3580
|
264 MARRAY_OP_ASSIGN_DEFS (MArray2, T, T) \ |
|
265 MARRAY_OP_ASSIGN_DEFS (MArray2, T, MArray2<T>) \ |
3573
|
266 MARRAY_UNOP_DEFS (MArray2, T) \ |
|
267 MARRAY_BINOP_DEFS (MArray2, T) |
|
268 |
3580
|
269 // Instantiate all the MArray friends for MArray element type T. |
|
270 #define INSTANTIATE_MDIAGARRAY2_FRIENDS(T) \ |
3581
|
271 MARRAY_OP_ASSIGN_DEFS (MDiagArray2, T, MDiagArray2<T>) \ |
|
272 MARRAY_UNOP_DEFS (MDiagArray2, T) \ |
|
273 MDIAGARRAY2_BINOP_DEFS (MDiagArray2, T) |
3580
|
274 |
3573
|
275 // Define all the MArray forwarding functions for return type R and |
|
276 // MArray element type T |
|
277 #define MARRAY_FORWARD_DEFS(B, R, T) \ |
|
278 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
279 (R, T, dynamic_cast<B<T>&>, R, , T) \ |
|
280 \ |
|
281 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
282 (R, T, \ |
|
283 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \ |
|
284 \ |
|
285 MARRAY_UNOP_FWD_DEFS \ |
|
286 (R, T, dynamic_cast<const B<T>&>, R) \ |
|
287 \ |
|
288 MARRAY_BINOP_FWD_DEFS \ |
|
289 (R, T, dynamic_cast<const B<T>&>, R, , T) \ |
|
290 \ |
|
291 MARRAY_BINOP_FWD_DEFS \ |
|
292 (R, T, , T, dynamic_cast<const B<T>&>, R) \ |
|
293 \ |
|
294 MARRAY_AA_BINOP_FWD_DEFS \ |
|
295 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R) |
|
296 |
3580
|
297 #define MDIAGARRAY2_FORWARD_DEFS(B, R, T) \ |
|
298 MARRAY_OP_ASSIGN_FWD_DEFS \ |
|
299 (R, T, \ |
|
300 dynamic_cast<B<T>&>, R, dynamic_cast<const B<T>&>, R) \ |
|
301 \ |
|
302 MARRAY_UNOP_FWD_DEFS \ |
|
303 (R, T, dynamic_cast<const B<T>&>, R) \ |
|
304 \ |
|
305 MDIAGARRAY2_DAS_BINOP_FWD_DEFS \ |
|
306 (R, T, dynamic_cast<const B<T>&>, R, , T) \ |
|
307 \ |
|
308 MDIAGARRAY2_SDA_BINOP_FWD_DEFS \ |
|
309 (R, T, , T, dynamic_cast<const B<T>&>, R) \ |
|
310 \ |
|
311 MDIAGARRAY2_DADA_BINOP_FWD_DEFS \ |
|
312 (R, T, dynamic_cast<const B<T>&>, R, dynamic_cast<const B<T>&>, R) |
|
313 |
3573
|
314 // Now we have all the definitions we need. |
|
315 |