Loading of landsat meta data file and coordinates, displays schematic cuboid
[tecorrec.git] / geo / tcRangeSpectrum.cpp
blob7e26fa46c6af28e7338ddddecebf980c1a2b0d0c
1 /***************************************************************************
2 * This file is part of Tecorrec. *
3 * Copyright 2008 James Hogan <james@albanarts.com> *
4 * *
5 * Tecorrec is free software: you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation, either version 2 of the License, or *
8 * (at your option) any later version. *
9 * *
10 * Tecorrec is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
14 * *
15 * You should have received a copy of the GNU General Public License *
16 * along with Tecorrec. If not, write to the Free Software Foundation, *
17 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
18 ***************************************************************************/
20 /**
21 * @file tcRangeSpectrum.h
22 * @brief Frequency spectrum of a uniform value in a range.
25 #include "tcRangeSpectrum.h"
27 #include <QtGlobal>
30 * Constructors + destructor
33 /// Default constructor.
34 tcRangeSpectrum::tcRangeSpectrum(float max, float x, float y)
35 : tcSpectrum()
36 , m_max(max)
37 , m_x(x)
38 , m_y(y)
40 Q_ASSERT(y >= x);
43 /// Destructor.
44 tcRangeSpectrum::~tcRangeSpectrum()
49 * Virtual interface
52 float tcRangeSpectrum::mean() const
54 return (m_x + m_y) / 2.0f;
57 float tcRangeSpectrum::integrate() const
59 return (m_y - m_x) * m_max;
62 float tcRangeSpectrum::integrate(float x) const
64 if (x <= m_x)
66 return 0.0f;
68 else
70 if (x >= m_y)
72 x = m_y;
74 return (x - m_x) * m_max;