4 XCSoar Glide Computer - http://www.xcsoar.org/
5 Copyright (C) 2000-2013 The XCSoar Project
6 A detailed list of copyright holders can be found in the file "AUTHORS".
8 This program is free software; you can redistribute it and/or
9 modify it under the terms of the GNU General Public License
10 as published by the Free Software Foundation; either version 2
11 of the License, or (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 #ifndef XCSOAR_NMEA_THERMAL_BAND_H
25 #define XCSOAR_NMEA_THERMAL_BAND_H
27 #include "Math/fixed.hpp"
29 #include <type_traits>
32 * Derived thermal climb rate histogram by altitude (time averaged)
34 struct ThermalBandInfo
36 static constexpr unsigned NUMTHERMALBUCKETS
= 10;
38 /** Height above working band/safety (m) */
39 fixed working_band_height
;
41 /** Absolute ceiling of climbs (m) */
42 fixed working_band_ceiling
;
44 /** Fraction of working band height */
45 fixed working_band_fraction
;
47 /** Maximum height achieved in circling */
48 fixed max_thermal_height
;
49 /** Number of samples in each bucket */
50 int thermal_profile_n
[NUMTHERMALBUCKETS
];
51 /** Average climb rate in each bucket */
52 fixed thermal_profile_w
[NUMTHERMALBUCKETS
];
57 * Calculates the bucket number for the specified height.
59 unsigned BucketForHeight(fixed height
) const;
62 * Calculates the base height of the specified bucket.
64 fixed
BucketHeight(unsigned bucket
) const;
66 void Add(const fixed height
, const fixed total_energy_vario
);
69 void Expand(const fixed height
);
72 static_assert(std::is_trivial
<ThermalBandInfo
>::value
, "type is not trivial");