nidas v1.2.3
WindOrienter.h
Go to the documentation of this file.
1// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 4; tab-width: 4; -*-
2// vim: set shiftwidth=4 softtabstop=4 expandtab:
3/*
4 ********************************************************************
5 ** NIDAS: NCAR In-situ Data Acquistion Software
6 **
7 ** 2018, Copyright University Corporation for Atmospheric Research
8 **
9 ** This program is free software; you can redistribute it and/or modify
10 ** it under the terms of the GNU General Public License as published by
11 ** the Free Software Foundation; either version 2 of the License, or
12 ** (at your option) any later version.
13 **
14 ** This program is distributed in the hope that it will be useful,
15 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
16 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 ** GNU General Public License for more details.
18 **
19 ** The LICENSE.txt file accompanying this software contains
20 ** a copy of the GNU General Public License. If it is not found,
21 ** write to the Free Software Foundation, Inc.,
22 ** 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 **
24 ********************************************************************
25*/
26
27#ifndef NIDAS_DNYLD_ISFF_WINDORIENTER_H
28#define NIDAS_DNYLD_ISFF_WINDORIENTER_H
29
30#include <string>
31
32namespace nidas {
33
34namespace core {
35 class Parameter;
36}
37
38namespace dynld { namespace isff {
39
45{
46public:
47
49
55 void
56 applyOrientation(float* uvwt);
57
69 bool
70 applyOrientation2D(float* u, float *v);
71
80 void
81 setOrientation(const std::string& orientation, const std::string& name="");
82
91 bool
93 const std::string& name);
94
95protected:
96
101
108 int _tx[3];
109
115 int _sx[3];
116
117};
118
119}}} // namespace nidas namespace dynld namespace isff
120
121#endif // NIDAS_DNYLD_ISFF_WINDORIENTER_H
Definition Parameter.h:47
A class for rotating winds according to different orientations of the wind sensor.
Definition WindOrienter.h:45
int _tx[3]
Index transform vector for wind components.
Definition WindOrienter.h:108
void setOrientation(const std::string &orientation, const std::string &name="")
Parse the orientation parameter and set the vectors which translate the axes and signs of the wind se...
Definition WindOrienter.cc:58
WindOrienter()
Definition WindOrienter.cc:43
void applyOrientation(float *uvwt)
Apply orientation changes to the wind components.
Definition WindOrienter.cc:176
bool _unusualOrientation
Is the sonic oriented in a unusual way, e.g.
Definition WindOrienter.h:100
int _sx[3]
Wind component sign conversion.
Definition WindOrienter.h:115
bool applyOrientation2D(float *u, float *v)
Apply the current orientation to 2D components.
Definition WindOrienter.cc:191
bool handleParameter(const nidas::core::Parameter *parameter, const std::string &name)
If the given parameter is "orientation", call setOrientation() with the value.
Definition WindOrienter.cc:206
Root namespace for the NCAR In-Situ Data Acquisition Software.
Definition A2DConverter.h:31