2011-11-26 03:18:30 +00:00
|
|
|
/*
|
|
|
|
* Written by Thomas Tsou <ttsou@vt.edu>
|
|
|
|
* Based on code by Harvind S Samra <hssamra@kestrelsp.com>
|
|
|
|
*
|
|
|
|
* Copyright 2011 Free Software Foundation, Inc.
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
* See the COPYING file in the main directory for details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef RADIOVECTOR_H
|
|
|
|
#define RADIOVECTOR_H
|
|
|
|
|
|
|
|
#include "sigProcLib.h"
|
|
|
|
#include "GSMCommon.h"
|
2013-06-16 10:30:58 +00:00
|
|
|
#include "Interthread.h"
|
2011-11-26 03:18:30 +00:00
|
|
|
|
2013-11-14 03:48:11 +00:00
|
|
|
class radioVector {
|
2011-11-26 03:18:30 +00:00
|
|
|
public:
|
2013-11-14 03:48:11 +00:00
|
|
|
radioVector(GSM::Time& wTime, size_t size = 0,
|
|
|
|
size_t start = 0, size_t chans = 1);
|
|
|
|
|
|
|
|
radioVector(GSM::Time& wTime, signalVector *vector);
|
|
|
|
~radioVector();
|
|
|
|
|
2011-11-26 03:18:43 +00:00
|
|
|
GSM::Time getTime() const;
|
2011-11-26 03:18:30 +00:00
|
|
|
void setTime(const GSM::Time& wTime);
|
|
|
|
bool operator>(const radioVector& other) const;
|
|
|
|
|
2013-11-14 23:04:10 +00:00
|
|
|
signalVector *getVector(size_t chan = 0) const;
|
2013-11-14 03:48:11 +00:00
|
|
|
bool setVector(signalVector *vector, size_t chan = 0);
|
|
|
|
size_t chans() const { return vectors.size(); }
|
2011-11-26 03:18:30 +00:00
|
|
|
private:
|
2013-11-14 03:48:11 +00:00
|
|
|
std::vector<signalVector *> vectors;
|
2011-11-26 03:18:30 +00:00
|
|
|
GSM::Time mTime;
|
|
|
|
};
|
|
|
|
|
2013-10-18 01:23:34 +00:00
|
|
|
class noiseVector : std::vector<float> {
|
|
|
|
public:
|
2013-11-14 20:52:04 +00:00
|
|
|
noiseVector(size_t size = 0);
|
2013-10-18 01:23:34 +00:00
|
|
|
bool insert(float val);
|
2013-11-14 23:04:10 +00:00
|
|
|
float avg() const;
|
2013-10-18 01:23:34 +00:00
|
|
|
|
|
|
|
private:
|
2013-11-14 20:52:04 +00:00
|
|
|
size_t itr;
|
2013-10-18 01:23:34 +00:00
|
|
|
};
|
|
|
|
|
2013-10-29 22:34:16 +00:00
|
|
|
class VectorFIFO : public InterthreadQueue<radioVector> { };
|
2011-11-26 03:18:30 +00:00
|
|
|
|
|
|
|
class VectorQueue : public InterthreadPriorityQueue<radioVector> {
|
|
|
|
public:
|
|
|
|
GSM::Time nextTime() const;
|
|
|
|
radioVector* getStaleBurst(const GSM::Time& targTime);
|
|
|
|
radioVector* getCurrentBurst(const GSM::Time& targTime);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* RADIOVECTOR_H */
|