NEML2 2.0.0
All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Modules Pages
Transformable.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/misc/defaults.h"
29
30namespace neml2
31{
32class R2;
33class Quaternion;
34class Rot;
35class Vec;
36
39template <class Derived>
41{
42public:
43 Transformable() = default;
44
45 Transformable(const Transformable &) = default;
46 Transformable(Transformable &&) noexcept = default;
47 Transformable & operator=(const Transformable &) = default;
48 Transformable & operator=(Transformable &&) noexcept = default;
49 virtual ~Transformable() = default;
50
54 virtual Derived transform(const R2 & op) const = 0;
55};
56
59
67R2 reflection_transform(const Vec & v);
70} // namespace neml2
A batched quaternion.
Definition Quaternion.h:45
Second order tensor without symmetry.
Definition R2.h:42
Rotation stored as modified Rodrigues parameters.
Definition Rot.h:49
Transformable(const Transformable &)=default
Transformable(Transformable &&) noexcept=default
virtual Derived transform(const R2 &op) const =0
apply a transformation operator
3-vector.
Definition Vec.h:42
Definition DiagnosticsInterface.cxx:30
TensorOptions default_tensor_options()
Default floating point tensor options.
Definition defaults.cxx:44
R2 transform_from_quaternion(const Quaternion &q)
Construct from quaternions, useful for comparison to old NEML.
Definition Transformable.cxx:33
R2 inversion_transform(const TensorOptions &option)
An inversion center.
Definition Transformable.cxx:64
R2 identity_transform(const TensorOptions &options)
The identity transformation, i.e.e the Rank2 identity tensor.
Definition Transformable.cxx:39
R2 improper_rotation_transform(const Rot &rot)
An improper rotation (rotation + reflection), here provided by a rot object giving the rotation and r...
Definition Transformable.cxx:51
c10::TensorOptions TensorOptions
Definition types.h:63
R2 reflection_transform(const Vec &v)
A reflection, defined by the reflection plane.
Definition Transformable.cxx:58
R2 proper_rotation_transform(const Rot &rot)
A proper rotation, here provided by a Rot object.
Definition Transformable.cxx:45