OpenStructure
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
Examples
File List
Globals
•
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Groups
Pages
stage
include
ost
img
alg
stat.hh
Go to the documentation of this file.
1
//------------------------------------------------------------------------------
2
// This file is part of the OpenStructure project <www.openstructure.org>
3
//
4
// Copyright (C) 2008-2011 by the OpenStructure authors
5
// Copyright (C) 2003-2010 by the IPLT authors
6
//
7
// This library is free software; you can redistribute it and/or modify it under
8
// the terms of the GNU Lesser General Public License as published by the Free
9
// Software Foundation; either version 3.0 of the License, or (at your option)
10
// any later version.
11
// This library is distributed in the hope that it will be useful, but WITHOUT
12
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
13
// FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
14
// details.
15
//
16
// You should have received a copy of the GNU Lesser General Public License
17
// along with this library; if not, write to the Free Software Foundation, Inc.,
18
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
//------------------------------------------------------------------------------
20
21
/*
22
Authors: Andreas Schenk, Ansgar Philippsen
23
*/
24
25
#ifndef IMG_ALG_STAT_H
26
#define IMG_ALG_STAT_H
27
28
#include <iosfwd>
29
30
#include <
ost/img/algorithm.hh
>
31
#include <
ost/img/image_state.hh
>
32
#include <
ost/img/alg/module_config.hh
>
33
34
namespace
ost {
namespace
img {
namespace
alg {
35
49
class
DLLEXPORT_IMG_ALG
StatBase
50
{
51
public
:
52
StatBase
():
53
mean_(0.0),
54
var_(0.0),
55
std_dev_(0.0),
56
sum_(0.0),
57
min_(0.0),
58
max_(0.0),
59
maxpos_(),
60
minpos_(),
61
rms_(0.0),
62
skewness_(0.0),
63
kurtosis_(0.0),
64
center_of_mass_(0.0,0.0,0.0)
65
{}
66
67
// image state algorithm interface
68
template
<
typename
T,
class
D>
69
void
VisitState(
const
ImageStateImpl<T,D>& isi);
70
71
void
VisitFunction(
const
Function
& f);
72
73
static
String
GetAlgorithmName
() {
return
"Stat"
;}
74
75
// other interface
76
77
Real
GetMean
()
const
{
return
mean_;}
78
void
SetMean
(
Real
m) {mean_=m;}
79
Real
GetMinimum
()
const
{
return
min_;}
80
Point
GetMinimumPosition
()
const
{
return
minpos_;}
81
void
SetMinimum
(
Real
m) {min_=m;}
82
Real
GetMaximum
()
const
{
return
max_;}
83
Point
GetMaximumPosition
()
const
{
return
maxpos_;}
84
void
SetMaximum
(
Real
m) {max_=m;}
85
Real
GetSum
()
const
{
return
sum_;}
86
void
SetSum
(
Real
s) {sum_=s;}
87
Real
GetVariance
()
const
{
return
var_;}
88
void
SetVariance
(
Real
v) {var_=v;}
89
Real
GetStandardDeviation
()
const
{
return
std_dev_;}
90
void
SetStandardDeviation
(
Real
s) {std_dev_=s;}
91
Real
GetRootMeanSquare
()
const
{
return
rms_;}
92
Real
GetSkewness
()
const
{
return
skewness_;}
93
Real
GetKurtosis
()
const
{
return
kurtosis_;}
94
Vec3
GetCenterOfMass
()
const
{
return
center_of_mass_;}
95
protected
:
96
Real
mean_,
var_
, std_dev_;
97
Real
sum_
, min_, max_;
98
Point
maxpos_,
minpos_
;
99
Real
rms_,
skewness_
,kurtosis_;
100
Vec3
center_of_mass_
;
101
};
102
103
typedef
ImageStateNonModAlgorithm<StatBase>
Stat
;
104
105
DLLEXPORT_IMG_ALG
std::ostream&
operator<<
(std::ostream& o,
const
Stat
& s);
106
}
107
108
OST_IMG_ALG_EXPLICIT_INST_DECL
(
class
,ImageStateNonModAlgorithm<alg::StatBase>)
109
110
}}
// ns
111
112
#endif
113
Generated on Mon Nov 5 2012 13:31:01 for OpenStructure by
1.8.1.1