aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
median_tpl.h
Go to the documentation of this file.
1/****************************************************************************
2 * This file is part of the aGrUM/pyAgrum library. *
3 * *
4 * Copyright (c) 2005-2025 by *
5 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
6 * - Christophe GONZALES(_at_AMU) *
7 * *
8 * The aGrUM/pyAgrum library is free software; you can redistribute it *
9 * and/or modify it under the terms of either : *
10 * *
11 * - the GNU Lesser General Public License as published by *
12 * the Free Software Foundation, either version 3 of the License, *
13 * or (at your option) any later version, *
14 * - the MIT license (MIT), *
15 * - or both in dual license, as here. *
16 * *
17 * (see https://agrum.gitlab.io/articles/dual-licenses-lgplv3mit.html) *
18 * *
19 * This aGrUM/pyAgrum library is distributed in the hope that it will be *
20 * useful, but WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
21 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES MERCHANTABILITY or FITNESS *
22 * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
25 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR *
26 * OTHER DEALINGS IN THE SOFTWARE. *
27 * *
28 * See LICENCES for more details. *
29 * *
30 * SPDX-FileCopyrightText: Copyright 2005-2025 *
31 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
32 * - Christophe GONZALES(_at_AMU) *
33 * SPDX-License-Identifier: LGPL-3.0-or-later OR MIT *
34 * *
35 * Contact : info_at_agrum_dot_org *
36 * homepage : http://agrum.gitlab.io *
37 * gitlab : https://gitlab.com/agrumery/agrum *
38 * *
39 ****************************************************************************/
40#pragma once
41
42
49
50#include <sstream>
51#include <vector>
52
53// to ease parser in IDEs
56
57namespace gum {
58
59 namespace aggregator {
60 template < typename GUM_SCALAR >
62 GUM_CONSTRUCTOR(Median);
63 }
64
65 template < typename GUM_SCALAR >
67 MultiDimAggregator< GUM_SCALAR >(from) {
68 GUM_CONS_CPY(Median);
69 }
70
71 template < typename GUM_SCALAR >
73 GUM_DESTRUCTOR(Median);
74 }
75
76 template < typename GUM_SCALAR >
77 INLINE std::string Median< GUM_SCALAR >::aggregatorName() const {
78 std::stringstream ss;
79 ss << "median";
80 return ss.str();
81 }
82
83 template < typename GUM_SCALAR >
87
88 template < typename GUM_SCALAR >
90 if (i.nbrDim() < 2) return i.nbrDim() / 2; // arbitrary. Guess = (max-min)/2 .
91
92 // we assume that every (parent) variable has the same domainSize
93 Idx maxVal = i.variable(1).domainSize();
94
95 std::vector< Idx > cum(maxVal, 0);
96
97 for (Idx j = 1; j < this->nbrDim(); j++)
98 cum[i.val(j)]++;
99
100 Idx half = (this->nbrDim() + 1) / 2; // 50% of the population
101
102 Idx max = maxVal;
103 for (Idx j = 0, sumcum = 0; j < maxVal; j++)
104 if ((sumcum += cum[j]) >= half) {
105 max = j;
106 break;
107 }
108 Idx maxR = maxVal;
109 for (Idx j = maxVal - 1, jj = 0, sumcum = 0; jj < maxVal; jj++, j--)
110 if ((sumcum += cum[j]) >= half) {
111 maxR = j;
112 break;
113 }
114
115 // multiDimAggregator::get will truncate if needed.
116 return (maxR + max) / 2;
117 }
118
119 template < typename GUM_SCALAR >
121 Idx i1,
122 Idx i2,
123 bool& stop_iteration) const {
124 return 0;
125 }
126
127 } // namespace aggregator
128} // namespace gum
Base class for discrete random variable.
virtual Size domainSize() const =0
Class for assigning/browsing values to tuples of discrete variables.
Idx val(Idx i) const
Returns the current value of the variable at position i.
const DiscreteVariable & variable(Idx i) const final
Returns the variable at position i in the tuple.
Idx nbrDim() const final
Returns the number of variables in the Instantiation.
Abstract base class for all multi dimensionnal containers.
virtual Idx nbrDim() const override
Returns the number of vars in the multidimensional container.
virtual Idx buildValue_(const gum::Instantiation &i) const
by default, buildValue_ uses a "fold" scheme and the user has to implement neutralElt_ and fold_ but ...
Definition median_tpl.h:89
virtual std::string aggregatorName() const
Definition median_tpl.h:77
virtual MultiDimContainer< GUM_SCALAR > * newFactory() const
This method creates a clone of this object, withouth its content (including variable),...
Definition median_tpl.h:84
virtual Idx fold_(const DiscreteVariable &v, Idx i1, Idx i2, bool &stop_iteration) const
fold_ is applied on value i1 for variable v. the actual result for precedent applications is i2.
Definition median_tpl.h:120
Size Idx
Type for indexes.
Definition types.h:79
median aggregator
MultiDimAggregator.
Aggregators are functional description of CPTs.
Definition agrum.h:55
gum is the global namespace for all aGrUM entities
Definition agrum.h:46