diff --git a/src/core/math/RotationFunctions.h b/src/core/math/RotationFunctions.h new file mode 100644 index 0000000000000000000000000000000000000000..99511168cd488504464eb9945119b1015bae6c7a --- /dev/null +++ b/src/core/math/RotationFunctions.h @@ -0,0 +1,41 @@ +//====================================================================================================================== +// +// This file is part of waLBerla. waLBerla is free software: you can +// redistribute it and/or modify it under the terms of the GNU General Public +// License as published by the Free Software Foundation, either version 3 of +// the License, or (at your option) any later version. +// +// waLBerla is distributed in the hope that it will be useful, but WITHOUT +// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +// for more details. +// +// You should have received a copy of the GNU General Public License along +// with waLBerla (see COPYING.txt). If not, see <http://www.gnu.org/licenses/>. +// +//! \file RotationFunctions.h +//! \author Sebastian Eibl <sebastian.eibl@fau.de> +// +//====================================================================================================================== + +#pragma once + +#include <core/math/Rot3.h> +#include <core/math/Vector3.h> + +namespace walberla { +namespace math { + +template< typename Type > +inline void rotateAroundPoint( Vector3<Type>& pos, + Rot3<Type>& rot, + const Vector3<Type>& rotateAround, + const Rot3<Type>& dRot ) +{ + const auto dp = pos - rotateAround; + pos = rotateAround + dRot.getMatrix() * dp; + rot.rotate(dRot); +} + +} // mpi +} // walberla