Alexandria 2.31.0
SDC-CH common library for the Euclid project
Loading...
Searching...
No Matches
SOMProjector.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2012-2022 Euclid Science Ground Segment
3 *
4 * This library is free software; you can redistribute it and/or modify it under
5 * the terms of the GNU Lesser General Public License as published by the Free
6 * Software Foundation; either version 3.0 of the License, or (at your option)
7 * any later version.
8 *
9 * This library is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11 * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
12 * details.
13 *
14 * You should have received a copy of the GNU Lesser General Public License
15 * along with this library; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18
19/*
20 * @file SOMProjector.h
21 * @author nikoapos
22 */
23
24#ifndef SOM_SOMPROJECTOR_H
25#define SOM_SOMPROJECTOR_H
26
28#include "SOM/SOM.h"
29#include <functional>
30#include <iterator>
31
32namespace Euclid {
33namespace SOM {
35
36public:
37 template <typename T>
39
40 template <typename T, typename DistFunc, typename InputIter, typename WeightFunc, typename AdderFunc>
41 static ProjectGrid<T> project(const SOM<DistFunc>& som, InputIter begin, InputIter end, WeightFunc weight_func,
42 AdderFunc adder_func, const T& init_cell = T{});
43
44 template <typename T, typename DistFunc, typename InputIter, typename WeightFunc,
45 typename UncertaintyFunc, typename AdderFunc>
46 static ProjectGrid<T> project(const SOM<DistFunc>& som, InputIter begin, InputIter end, WeightFunc weight_func,
47 UncertaintyFunc uncertainty_func, AdderFunc adder_func, const T& init_cell = T{});
48};
49
50} // namespace SOM
51} // namespace Euclid
52
54
55#endif /* SOM_SOMPROJECTOR_H */
Representation of a multi-dimensional grid which contains axis information.
static ProjectGrid< T > project(const SOM< DistFunc > &som, InputIter begin, InputIter end, WeightFunc weight_func, AdderFunc adder_func, const T &init_cell=T{})
static ProjectGrid< T > project(const SOM< DistFunc > &som, InputIter begin, InputIter end, WeightFunc weight_func, UncertaintyFunc uncertainty_func, AdderFunc adder_func, const T &init_cell=T{})