2** EPITECH PROJECT, 2025
5** Vec3.tpp, Vector of 3 class implementation
11** Copyright (c) 2025 Robin Toillon
13** Permission is hereby granted, free of charge, to any person obtaining
14** a copy of this software and associated documentation files (the
15** "Software"), to deal in the Software without restriction, including
16** without limitation the rights to use, copy, modify, merge, publish,
17** distribute, sublicense, and/or sell copies of the Software, and to
18** permit persons to whom the Software is furnished to do so, subject to
19** the following conditions:
21** The above copyright notice and this permission notice shall be
22** included in all copies or substantial portions of the Software.
24** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
27** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
28** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
29** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
30** SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
35 * @brief Implementation of the 3-dimensional vector class.
36 * @author Robin Toillon
42 constexpr Vec3<T>::Vec3(T x_, T y_, T z_) noexcept : x{x_}, y{y_}, z{z_}
47 constexpr auto &Vec3<T>::operator[](this auto &self,
48 std::size_t index) noexcept
56 RTP_ASSERT(false, "Vec3: Index {} out of bounds", index);
61 constexpr auto Vec3<T>::cross(const Vec3 &other) const noexcept
64 return Vec3{y * other.z - z * other.y,
65 z * other.x - x * other.z,
66 x * other.y - y * other.x};