-
Notifications
You must be signed in to change notification settings - Fork 10
/
LabeledAxisAccessor.h
125 lines (99 loc) · 4.31 KB
/
LabeledAxisAccessor.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
// Copyright 2023, UChicago Argonne, LLC
// All Rights Reserved
// Software Name: NEML2 -- the New Engineering material Model Library, version 2
// By: Argonne National Laboratory
// OPEN SOURCE LICENSE (MIT)
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#pragma once
#include <vector>
#include <iostream>
namespace neml2
{
/**
* @brief The accessor containing all the information needed to access an item in a `LabeledAxis`.
*
* The accessor consists of an arbitrary number of item names. The last item name can be either a
* variable name or a sub-axis name. All the other item names are considered to be sub-axis names.
*
* The LabeledAxisAccessor stores the item labels and does not resolve the actual layout of the
* item. This way an accessor can be used access the same variable from different tensor layouts.
*
* The item names cannot contain whitespace, ".", ",", ";", or "/".
*/
class LabeledAxisAccessor
{
public:
LabeledAxisAccessor() = default;
template <typename... S>
LabeledAxisAccessor(const char * name, S &&... names)
{
validate_item_name(name);
_item_names.push_back(name);
(validate_item_name(names), ...);
(_item_names.push_back(names), ...);
}
template <typename... S>
LabeledAxisAccessor(const std::string & name, S &&... names)
{
validate_item_name(name);
_item_names.push_back(name);
(validate_item_name(names), ...);
(_item_names.push_back(names), ...);
}
LabeledAxisAccessor(const std::vector<std::string> & names);
LabeledAxisAccessor(const LabeledAxisAccessor & other);
/// Assignment operator
LabeledAxisAccessor & operator=(const LabeledAxisAccessor & other);
operator std::vector<std::string>() const;
const std::vector<std::string> & vec() const { return _item_names; }
bool empty() const;
size_t size() const;
/// Append a suffix to the item name.
LabeledAxisAccessor with_suffix(const std::string & suffix) const;
/// Add a new item
LabeledAxisAccessor append(const LabeledAxisAccessor & axis) const;
/// Re-mount the LabeledAxisAccessor on an axis by the axis accessor
LabeledAxisAccessor on(const LabeledAxisAccessor & axis) const;
/// Remove the leading \p n items from the labels.
LabeledAxisAccessor slice(size_t n) const;
/// Extract out the labels from \p n1 to \p n2
LabeledAxisAccessor slice(size_t n1, size_t n2) const;
/// Check if this accessor begins with another accessor
bool start_with(const LabeledAxisAccessor & axis) const;
private:
/// Throws if the item name has invalid format
void validate_item_name(const std::string &) const;
std::vector<std::string> _item_names;
};
/// Compare for equality between two LabeledAxisAccessor
bool operator==(const LabeledAxisAccessor & a, const LabeledAxisAccessor & b);
/// Compare for equality between two LabeledAxisAccessor
bool operator!=(const LabeledAxisAccessor & a, const LabeledAxisAccessor & b);
/**
* @brief The (strict) smaller than operator is created so as to use LabeledAxisAccessor in sorted
* data structures.
*/
bool operator<(const LabeledAxisAccessor & a, const LabeledAxisAccessor & b);
/**
* @brief Serialize the \p accessor into a string. The format is simply the concatenation of all the
* item names delimited by "/".
*/
std::ostream & operator<<(std::ostream & os, const LabeledAxisAccessor & accessor);
} // namespace neml2