Implement matrix Frobenius (L2) norm
This commit is contained in:
parent
7698e54b18
commit
71bafff64d
1 changed files with 17 additions and 1 deletions
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
#include <psemek/geom/detail/array.hpp>
|
#include <psemek/geom/detail/array.hpp>
|
||||||
#include <psemek/geom/vector.hpp>
|
#include <psemek/geom/vector.hpp>
|
||||||
|
#include <psemek/geom/math.hpp>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
|
|
@ -39,7 +40,6 @@ namespace psemek::geom
|
||||||
static matrix scalar(T const & s);
|
static matrix scalar(T const & s);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
template <typename T, std::size_t R, std::size_t C>
|
template <typename T, std::size_t R, std::size_t C>
|
||||||
matrix<T, R, C> matrix<T, R, C>::zero()
|
matrix<T, R, C> matrix<T, R, C>::zero()
|
||||||
{
|
{
|
||||||
|
|
@ -269,6 +269,22 @@ namespace psemek::geom
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename T, std::size_t R, std::size_t C>
|
||||||
|
T frobenius_norm_sqr(matrix<T, R, C> const & m)
|
||||||
|
{
|
||||||
|
T r{0};
|
||||||
|
for (std::size_t i = 0; i < R; ++i)
|
||||||
|
for (std::size_t j = 0; j < C; ++j)
|
||||||
|
r += sqr(m[i][j]);
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T, std::size_t R, std::size_t C>
|
||||||
|
T frobenius_norm(matrix<T, R, C> const & m)
|
||||||
|
{
|
||||||
|
return std::sqrt(frobenius_norm_sqr(m));
|
||||||
|
}
|
||||||
|
|
||||||
template <typename Stream, typename T, std::size_t R, std::size_t C>
|
template <typename Stream, typename T, std::size_t R, std::size_t C>
|
||||||
Stream & operator << (Stream & os, matrix<T, R, C> const & m)
|
Stream & operator << (Stream & os, matrix<T, R, C> const & m)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue