NEML2 2.0.0
Loading...
Searching...
No Matches
TensorName.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
27#include "neml2/misc/types.h"
28#include "neml2/tensors/tensors.h"
29
30namespace neml2
31{
32class Model;
33class Factory;
34
45template <typename T>
46struct TensorName
47{
48public:
49 TensorName() = default;
50
51 TensorName(std::string raw)
52 : _raw_str(std::move(raw))
53 {
54 }
55
61 TensorName & operator=(const std::string & other)
62 {
63 _raw_str = other;
64 return *this;
65 }
66
73 const T & resolve(Factory * factory = nullptr) const;
74 const T & resolve(Model * caller, const std::string & pname) const;
75
77 bool operator==(const TensorName & other) const { return _raw_str == other.raw(); }
78
84 std::string & raw() { return _raw_str; }
85 const std::string & raw() const { return _raw_str; }
86
87private:
89 T resolve_number(double val) const;
90
92 std::string _raw_str;
93
95 mutable T _value;
96
98 mutable std::shared_ptr<T> _tensor = nullptr;
99};
100
101// Export TensorName so other TU don't repeat the instantiation
102#define EXPORT_TENSORNAME(T) extern template struct TensorName<T>
103FOR_ALL_TENSORBASE(EXPORT_TENSORNAME);
104#undef EXPORT_TENSORNAME
105
107template <typename T>
108std::stringstream &
109operator>>(std::stringstream & ss, TensorName<T> & t)
110{
111 ss >> t.raw();
112 return ss;
113}
114
116template <typename T>
117std::ostream &
118operator<<(std::ostream & os, const TensorName<T> & t)
119{
120 os << t.raw();
121 return os;
122}
123} // namespace neml2
Definition Factory.h:65
The base class for all constitutive models.
Definition Model.h:70
Definition DiagnosticsInterface.cxx:30
std::ostream & operator<<(std::ostream &os, const EnumSelection &es)
Definition EnumSelection.cxx:31
std::stringstream & operator>>(std::stringstream &ss, EnumSelection &es)
Definition EnumSelection.cxx:38
The name of a tensor object that can be referenced in the input files.
Definition VariableStore.h:43
const T & resolve(Model *caller, const std::string &pname) const
std::string & raw()
Get the raw string literal.
Definition TensorName.h:84
TensorName(std::string raw)
Definition TensorName.h:51
TensorName & operator=(const std::string &other)
Assignment operator.
Definition TensorName.h:61
TensorName()=default
bool operator==(const TensorName &other) const
Test equality.
Definition TensorName.h:77
const std::string & raw() const
Definition TensorName.h:85
const T & resolve(Factory *factory=nullptr) const
Resolve the TensorName to a Tensor object.
Definition TensorName.cxx:36