NEML2 2.0.0
All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Modules Pages
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_VECBASE(f) \
30 f(Vec); \
31 f(Rot); \
32 f(WR2)
33
34#define FOR_ALL_R2BASE(f) f(R2)
35
36#define FOR_ALL_NONSCALAR_PRIMITIVETENSOR(f) \
37 FOR_ALL_VECBASE(f); \
38 FOR_ALL_R2BASE(f); \
39 f(SR2); \
40 f(R3); \
41 f(SFR3); \
42 f(R4); \
43 f(SFR4); \
44 f(WFR4); \
45 f(SSR4); \
46 f(SFFR4); \
47 f(SWR4); \
48 f(WSR4); \
49 f(WWR4); \
50 f(R5); \
51 f(SSFR5); \
52 f(Quaternion); \
53 f(MillerIndex); \
54 f(SSSSR8); \
55 f(R8)
56
57#define FOR_ALL_NONSCALAR_TENSORBASE(f) \
58 FOR_ALL_NONSCALAR_PRIMITIVETENSOR(f); \
59 f(Tensor)
60
61#define FOR_ALL_PRIMITIVETENSOR(f) \
62 FOR_ALL_NONSCALAR_PRIMITIVETENSOR(f); \
63 f(Scalar)
64
65#define FOR_ALL_TENSORBASE(f) \
66 FOR_ALL_NONSCALAR_TENSORBASE(f); \
67 f(Scalar)
68
69#define FOR_SCALAR_AND_TENSOR(f) \
70 f(Scalar); \
71 f(Tensor)
73
76#define FOR_ALL_TENSORBASE_COMMA(f) FOR_ALL_PRIMITIVETENSOR_COMMA(f), f(Tensor)
77
78#define FOR_ALL_PRIMITIVETENSOR_COMMA(f) \
79 FOR_ALL_VECBASE_COMMA(f), FOR_ALL_R2BASE_COMMA(f), f(Scalar), f(SR2), f(R3), f(SFR3), f(R4), \
80 f(SFR4), f(WFR4), f(SSR4), f(SFFR4), f(SWR4), f(WSR4), f(WWR4), f(R5), f(SSFR5), \
81 f(Quaternion), f(MillerIndex), f(SSSSR8), f(R8)
82
83#define FOR_ALL_VECBASE_COMMA(f) f(Vec), f(Rot), f(WR2)
84
85#define FOR_ALL_R2BASE_COMMA(f) f(R2)