NEML2 2.0.0
Loading...
Searching...
No Matches
macros.h
1// Copyright 2024, UChicago Argonne, LLC
2// All Rights Reserved
3// Software Name: NEML2 -- the New Engineering material Model Library, version 2
4// By: Argonne National Laboratory
5// OPEN SOURCE LICENSE (MIT)
6//
7// Permission is hereby granted, free of charge, to any person obtaining a copy
8// of this software and associated documentation files (the "Software"), to deal
9// in the Software without restriction, including without limitation the rights
10// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11// copies of the Software, and to permit persons to whom the Software is
12// furnished to do so, subject to the following conditions:
13//
14// The above copyright notice and this permission notice shall be included in
15// all copies or substantial portions of the Software.
16//
17// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23// THE SOFTWARE.
24
25#pragma once
26
29#define FOR_ALL_TENSORBASE(f) \
30 FOR_ALL_PRIMITIVETENSOR(f); \
31 f(Tensor)
32
33#define FOR_ALL_PRIMITIVETENSOR(f) \
34 FOR_ALL_VECBASE(f); \
35 FOR_ALL_R2BASE(f); \
36 f(Scalar); \
37 f(SR2); \
38 f(R3); \
39 f(SFR3); \
40 f(R4); \
41 f(SSR4); \
42 f(SFFR4); \
43 f(SWR4); \
44 f(WSR4); \
45 f(WWR4); \
46 f(R5); \
47 f(SSFR5); \
48 f(Quaternion); \
49 f(MillerIndex); \
50 f(SSSSR8); \
51 f(R8)
52
53#define FOR_ALL_VECBASE(f) \
54 f(Vec); \
55 f(Rot); \
56 f(WR2)
57
58#define FOR_ALL_R2BASE(f) f(R2)
60
63#define FOR_ALL_TENSORBASE_COMMA(f) FOR_ALL_PRIMITIVETENSOR_COMMA(f), f(Tensor)
64
65#define FOR_ALL_PRIMITIVETENSOR_COMMA(f) \
66 FOR_ALL_VECBASE_COMMA(f), FOR_ALL_R2BASE_COMMA(f), f(Scalar), f(SR2), f(R3), f(SFR3), f(R4), \
67 f(SSR4), f(SFFR4), f(SWR4), f(WSR4), f(WWR4), f(R5), f(SSFR5), f(Quaternion), \
68 f(MillerIndex), f(SSSSR8), f(R8)
69
70#define FOR_ALL_VECBASE_COMMA(f) f(Vec), f(Rot), f(WR2)
71
72#define FOR_ALL_R2BASE_COMMA(f) f(R2)