From 221f632d6600ce03e09c2a44074ae100a507dd92 Mon Sep 17 00:00:00 2001 From: Mel Date: Sat, 1 Jul 2023 22:03:51 +0200 Subject: Replace bespoke Generator maps with tensors and matrices --- src/Math/Tensor.hpp | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 src/Math/Tensor.hpp (limited to 'src/Math/Tensor.hpp') diff --git a/src/Math/Tensor.hpp b/src/Math/Tensor.hpp new file mode 100644 index 0000000..e373c1f --- /dev/null +++ b/src/Math/Tensor.hpp @@ -0,0 +1,43 @@ +#pragma once + +template +struct Tensor { + static constexpr size_t element_size = (S*...); + + template + using EnableArgs = std::enable_if_t; + template + using EnableArgsPerElement = std::enable_if_t; + using Enable = std::enable_if_t; + + template + Tensor() : elements{} {} + + template + explicit Tensor(T scalar) { + std::fill(elements, elements + element_size, scalar); + } + + template = true> + Tensor(Args... args) : elements{ args... } {} + + template = true> + auto& operator()(Args... args) { + return elements[pos(args...)]; + } + + template = true> + static constexpr size_t pos(Args... args) { + size_t positions[O] = {static_cast(args)...}; + size_t dimensions[O] = {S...}; + + size_t p = 0; + for (int i = 0; i < O; i++) { + p *= dimensions[i]; + p += positions[i]; + } + return p; + } + + T elements[element_size]; +}; -- cgit 1.4.1