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