NEML2 1.4.0
Loading...
Searching...
No Matches
Transformable.cxx
1// Copyright 2023, 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#include "neml2/tensors/Transformable.h"
26
27#include "neml2/tensors/tensors.h"
28
29namespace neml2
30{
31
32R2
34{
35 return q.to_R2();
36}
37
38R2
39identity_transform(const torch::TensorOptions & options)
40{
41 return R2::identity(options);
42}
43
44R2
46{
47 return rot.euler_rodrigues();
48}
49
50R2
52{
53 Vec v = rot / rot.norm();
54 return rot.euler_rodrigues() * (R2::identity(rot.options()) - 2 * v.outer(v));
55}
56
57R2
59{
60 return R2::identity(v.options()) - 2 * v.outer(v);
61}
62
63R2
64inversion_transform(const torch::TensorOptions & option)
65{
66 return R2::fill(-1.0, option);
67}
68
69} // namespace neml2
The wrapper (decorator) for cross-referencing unresolved values at parse time.
Definition CrossRef.h:52
A batched quaternion.
Definition Quaternion.h:44
static R2 fill(const Real &a, const torch::TensorOptions &options=default_tensor_options())
Fill the diagonals with a11 = a22 = a33 = a.
Definition R2Base.cxx:40
static R2 identity(const torch::TensorOptions &options=default_tensor_options())
Identity.
Definition R2Base.cxx:170
Rotation stored as modified Rodrigues parameters.
Definition Rot.h:49
The (logical) vector.
Definition Vec.h:42
Definition CrossRef.cxx:32
R2 identity_transform(const torch::TensorOptions &options)
The identity transformation, i.e.e the Rank2 identity tensor.
Definition Transformable.cxx:39
R2 inversion_transform(const torch::TensorOptions &option)
An inversion center.
Definition Transformable.cxx:64
R2 transform_from_quaternion(const Quaternion &q)
Construct from quaternions, useful for comparison to old NEML.
Definition Transformable.cxx:33
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
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