nidas v1.2.3
TwoDS.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 ** 2007, 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_dynld_raf_2ds_h_
28#define _nidas_dynld_raf_2ds_h_
29
32
34
35namespace nidas { namespace dynld { namespace raf {
36
37using namespace nidas::core;
38
45{
46
47public:
48 TwoDS();
49 ~TwoDS();
50
51 bool process(const Sample * samp, std::list < const Sample * >&results);
52
59 virtual int NumberOfDiodes() const { return 128; }
60
66 void init();
67
68 void printStatus(std::ostream& ostr);
69
70
71protected:
75 virtual void init_parameters();
76
80 bool processHousekeeping(const Sample * samp, std::list < const Sample * >&results);
81
96 bool processImageRecord(const Sample * samp, std::list < const Sample * >&results);
97
99
102 static const unsigned char _syncString[];
103 static const unsigned char _blankString[];
105
106
107
108private:
109
111 TwoDS(const TwoDS&);
112
115};
116
117
118}}} // namespace nidas namespace dynld namespace raf
119
120#endif
Interface to a data sample.
Definition Sample.h:190
Sensor class using a UDPSocketIODevice for reading from a UDP socket.
Definition UDPSocketSensor.h:61
Base class for SPEC 2DS optical array probe on a USB interface.
Definition TwoDS.h:45
virtual int NumberOfDiodes() const
Number of diodes in the probe array.
Definition TwoDS.h:59
void init()
Called by post-processing code.
Definition TwoDS.cc:91
~TwoDS()
Definition TwoDS.cc:55
TwoDS(const TwoDS &)
No copying.
virtual void init_parameters()
Initialize parameters for real-time and post-processing.
Definition TwoDS.cc:76
static const unsigned char _blankString[]
Definition TwoDS.h:103
static const unsigned char _syncString[]
Sync and overload words/masks.
Definition TwoDS.h:102
bool process(const Sample *samp, std::list< const Sample * > &results)
Process a raw sample, which in this case means do a sscanf on the character string contents,...
Definition TwoDS.cc:226
TwoDS()
Definition TwoDS.cc:50
bool processHousekeeping(const Sample *samp, std::list< const Sample * > &results)
Process the UDP ASCII packet.
Definition TwoDS.cc:128
void printStatus(std::ostream &ostr)
Definition TwoDS.cc:240
TwoDS & operator=(const TwoDS &)
No copying.
bool processImageRecord(const Sample *samp, std::list< const Sample * > &results)
Process a single 2D record generating size-distribution data.
Definition TwoDS.cc:133
Base class for SPEC 2DS optical array probe on a USB interface.
Definition TwoD_Processing.h:43
The essential core classes of nidas.
Definition A2DConverter.h:31
Root namespace for the NCAR In-Situ Data Acquisition Software.
Definition A2DConverter.h:31