-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathFourParameterCorrelationModel.cpp
193 lines (163 loc) · 7.1 KB
/
FourParameterCorrelationModel.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
//#############################################################################
//
// FILENAME: FourParameterCorrelationModel.cpp
//
// CLASSIFICATION: Unclassified
//
// DESCRIPTION:
//
// This class is used to compute the correlation between model
// parameters in a community sensor model (CSM).
//
// LIMITATIONS: None
//
// SOFTWARE HISTORY:
// Date Author Comment
// ----------- ------ -------
// 29-Mar-2012 SCM Refactored interface.
// 22-Jun-2012 SCM Made Parameters public, added accessor.
// 30-Oct-2012 SCM Renamed to FourParameterCorrelationModel.h
// 06-Nov-2012 JPK Updated equation per CR 2012 10 17 001
// 17-Dec-2012 BAH Documentation updates.
// 20-Dec-2012 JPK Fixed bug in constructor.
// 18-Feb-2013 JPK Removed getNumCorrelationParameterGroups,
// now provided on base class.
// 03-Sep-2021 SCM Removed IRIX support.
// 01-Dec-2021 JPK Modified to use FourParameterCorrelationFunction
// 12-Nov-2023 JPK More updates to simplify accessibility of
// parameters
// 21-Nov-2023 JPK Modified to use FourParameterCorrelationFunction::
// correlationCoefficientFor() static method.
// 22-Nov-2023 JPK Modified to use FourParameterCorrelationFunction::
// checkParameters() static method.
//
// NOTES:
// Refer to FourParameterCorrelationModel.h for more information.
//
//#############################################################################
#define CSM_LIBRARY
#include "FourParameterCorrelationModel.h"
#include "FourParameterCorrelationFunction.h"
#include "ConstantCorrelationFunction.h"
#include "Error.h"
#include <cmath>
using std::exp;
using std::fabs;
static const std::string FPCM_NAME = "Four-parameter model (A, alpha, beta, tau)";
namespace csm {
FourParameterCorrelationModel::FourParameterCorrelationModel(size_t numSMParams,
size_t numCPGroups)
:
CorrelationModel(FPCM_NAME,
numCPGroups),
theGroupMapping (numSMParams, -1),
theCorrParams (numCPGroups)
{}
FourParameterCorrelationModel::~FourParameterCorrelationModel()
{}
size_t FourParameterCorrelationModel::getNumSensorModelParameters() const
{
return theGroupMapping.size();
}
int FourParameterCorrelationModel::getCorrelationParameterGroup(size_t smParamIndex) const
{
static const std::string METHOD_NAME = "getCorrelationParameterGroup";
// make sure the index falls within the acceptable range
checkSensorModelParameterIndex(smParamIndex,METHOD_NAME);
// return the correlation parameter group index by reference
return theGroupMapping[smParamIndex];
}
void FourParameterCorrelationModel::setCorrelationParameterGroup(size_t smParamIndex,
size_t cpGroupIndex)
{
static const std::string METHOD_NAME = "setCorrelationParameterGroup";
// make sure the indices fall within the acceptable ranges
checkSensorModelParameterIndex(smParamIndex,METHOD_NAME);
checkParameterGroupIndex(cpGroupIndex,METHOD_NAME);
// set the group index for the given model parameter
theGroupMapping[smParamIndex] = cpGroupIndex;
}
void FourParameterCorrelationModel::setCorrelationGroupParameters(
size_t cpGroupIndex, double a, double alpha, double beta, double tau)
{
setCorrelationGroupParameters(cpGroupIndex, Parameters(a, alpha, beta, tau));
}
void FourParameterCorrelationModel::setCorrelationGroupParameters(
size_t cpGroupIndex, const Parameters& params)
{
static const std::string METHOD_NAME = "setCorrelationGroupParameters";
// make sure the index falls within the acceptable range
checkParameterGroupIndex(cpGroupIndex,METHOD_NAME);
// make sure the values of each correlation model parameter fall within
// acceptable ranges. Previous implementation allowed for A to be 0.0
// (i.e. correlation coefficient = 0.0 for all non-zero delta time) and
// alpha = 1.0 (i.e. correlation coeeficient = A for all non-zero delta time)
// even though the these values are not considered "in range" for the
// four parameter correlation function.
// Allow these values her for backward compatibility by using the
// ConstantCorrelationFunction for these cases.
// Attempt to construct the appropriate correlation function. If parameters
// are out of range, an exception will be thrown.
if ((params.a == 0.0) || (params.alpha == 1.0))
{
ConstantCorrelationFunction::checkParameter(params.a);
}
else
{
FourParameterCorrelationFunction::checkParameters(params.a,
params.alpha,
params.beta,
params.tau);
}
// store the correlation parameter values
theCorrParams[cpGroupIndex] = params;
}
double FourParameterCorrelationModel::getCorrelationCoefficient(
size_t cpGroupIndex, double deltaTime) const
{
static const std::string METHOD_NAME = "getCorrelationCoefficient";
// make sure the index falls within the acceptable range
checkParameterGroupIndex(cpGroupIndex,METHOD_NAME);
const Parameters& params = theCorrParams[cpGroupIndex];
//***
// No need to range check values, since they have already been
// checked. Note that params.a = 0 or params.alha = 1 result in
// the value params.a being returned, i.e. constant correlation.
//***
return (FourParameterCorrelationFunction::
correlationCoefficientFor(deltaTime,
params.a,
params.alpha,
params.beta,
params.tau,
0.0));
}
const FourParameterCorrelationModel::Parameters&
FourParameterCorrelationModel::getCorrelationGroupParameters(size_t cpGroupIndex) const
{
static const std::string METHOD_NAME = "getCorrelationGroupParameters";
// make sure the index falls within the acceptable range
checkParameterGroupIndex(cpGroupIndex,METHOD_NAME);
return theCorrParams[cpGroupIndex];
}
void FourParameterCorrelationModel::checkSensorModelParameterIndex(
size_t smParamIndex, const std::string& functionName) const
{
if (smParamIndex >= theGroupMapping.size())
{
throw Error(Error::INDEX_OUT_OF_RANGE,
"Sensor model parameter index is out of range.",
"csm::FourParameterCorrelationModel::" + functionName);
}
}
void FourParameterCorrelationModel::checkParameterGroupIndex(
size_t groupIndex, const std::string& functionName) const
{
if (groupIndex >= theCorrParams.size())
{
throw Error(Error::INDEX_OUT_OF_RANGE,
"Correlation parameter group index is out of range.",
"csm::FourParameterCorrelationModel::" + functionName);
}
}
} // namespace csm