50 template<
typename dtype>
55 double squareSum = 0.0;
56 const auto function = [&squareSum](dtype value) ->
void
57 { squareSum +=
utils::sqr(
static_cast<double>(value)); };
74 returnArray(0, row) =
std::sqrt(squareSum /
static_cast<double>(inArray.
numCols()));
87 returnArray(0, row) =
std::sqrt(squareSum /
static_cast<double>(transposedArray.
numCols()));
109 template<
typename dtype>
114 std::complex<double> squareSum = 0.0;
115 const auto function = [&squareSum](std::complex<dtype> value) ->
void
116 { squareSum +=
utils::sqr(complex_cast<double>(value)); };
124 static_cast<double>(inArray.size())) };
130 for (
uint32 row = 0; row < inArray.numRows(); ++row)
132 squareSum = std::complex<double>(0.0, 0.0);
133 std::for_each(inArray.cbegin(row), inArray.cend(row),
function);
134 returnArray(0, row) =
std::sqrt(squareSum /
static_cast<double>(inArray.numCols()));
145 squareSum = std::complex<double>(0.0, 0.0);
147 returnArray(0, row) =
std::sqrt(squareSum /
static_cast<double>(transposedArray.
numCols()));
#define THROW_INVALID_ARGUMENT_ERROR(msg)
Definition: Error.hpp:36
#define STATIC_ASSERT_ARITHMETIC(dtype)
Definition: StaticAsserts.hpp:37
uint32 numCols() const noexcept
Definition: NdArrayCore.hpp:3416
size_type size() const noexcept
Definition: NdArrayCore.hpp:4289
const_iterator cbegin() const noexcept
Definition: NdArrayCore.hpp:1221
uint32 numRows() const noexcept
Definition: NdArrayCore.hpp:3428
NdArray< dtype > transpose() const
Definition: NdArrayCore.hpp:4650
const_iterator cend() const noexcept
Definition: NdArrayCore.hpp:1529
void for_each(InputIt first, InputIt last, UnaryFunction f)
Definition: StlAlgorithms.hpp:227
constexpr dtype sqr(dtype inValue) noexcept
Definition: sqr.hpp:44
Definition: Coordinate.hpp:45
NdArray< double > rms(const NdArray< dtype > &inArray, Axis inAxis=Axis::NONE)
Definition: rms.hpp:51
Axis
Enum To describe an axis.
Definition: Types.hpp:47
auto sqrt(dtype inValue) noexcept
Definition: sqrt.hpp:48
std::uint32_t uint32
Definition: Types.hpp:40